@charset "utf-8";

@import url('https://fonts.googleapis.com/css?family=Lato:100,300,400,700,900|Montserrat:100,200,300,400,500,600,700,800,900|Open+Sans:300,400,600,700,800');

/************************************************
Base
************************************************/

html,body,div,
dl,dt,dd,ul,ol,li,
h1,h2,h3,h4,h5,h6,
pre,form,fieldset,input,textarea,
blockquote,th,td,p,img {
    margin:0;
    padding:0;
}

html.error-page,
.error-page > body {
    height: 100%;
}

body {
    font-family: 'Lato', "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    color: #2d2d2d;
    line-height: 1;
    font-feature-settings : "palt";
}

.error-page > body {
    background: #fff7f7;
}

a {
    color: #2d2d2d;
    transition: 0.5s ease;
}

a:hover,
a:focus,
a:active {
    color: #ff4654;
}

.front_page a:hover img,
.front_page .item a:hover {
    opacity: 1;
}

.front_page .item a {
    display: block;
}

.clear:after,
.wrapper:after {
    content: "";
    display: block;
    clear: both;
    height: 0;
    visibility: hidden
}

@media only screen and (min-width: 1024px) {

    .wrapper {
        max-width: 1040px;
        margin: 0 auto;
        position: relative;
    }

}

/************************************************
Layouts
************************************************/

/****************************************
Layouts / Header
****************************************/

.header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 2;
    background: #fff;
    box-shadow: 0px 2px 8px rgba(0,0,0,0.1);
}

.header-top {
    display: none;
}

.header-bottom {
    height: 56px;
}

@media only screen and (min-width: 768px) {

    .header-bottom {
        height: 96px;
    }

}

@media only screen and (min-width: 1024px) {

    .header {
        box-shadow: 0px 2px 8px rgba(0,0,0,0.06);
        top: 0;
        transition: 0.5s ease;
    }

    .header.stikcy {
        top: -210px;
    }

    .header-top {
        display: block;
        height: 40px;
        line-height: 40px;
        background: #3e3e3e;
        background: #ff5c69;
    }

    .header-bottom {
        height: 120px;
        transition: 0.5s ease;
        overflow: visible;
    }

}

/****************************************
Layouts / Contents
****************************************/

.contents {
    padding-top: 56px;
    z-index: 1;
}

.contents-top {
    overflow: hidden;
}

.contents-middle {
    background: #f7f7f7;
}

.front_page .contents-middle,
.item_list_page .contents-middle {
    background: #fff;
}

@media only screen and (min-width: 768px) {

    .contents {
        padding-top: 96px;
    }

}

@media only screen and (min-width: 1024px) {

    .contents {
        padding-top: 208px;
    }

    .contents-middle {
        padding: 64px 0;
    }

}

/****************************************
Layouts / Feature Items
****************************************/

.feature-items {
    padding: 32px 16px 16px;
    background: #f7f7f7;
}

.front_page .feature-items {
    padding-top: 59px;
}

@media only screen and (min-width: 768px) {

    .feature-items {
        padding: 56px 48px 40px;
    }

    .front_page .feature-items {
        padding-top: 92px;
    }

}

@media only screen and (min-width: 1024px) {

    .feature-items {
        padding: 64px 0 48px;
    }

    .front_page .feature-items {
        padding-top: 92px;
    }

    .product_page .feature-items {
        padding: 0 0 48px;
    }

}

/****************************************
Layouts / New Arrival
****************************************/

.new-items {
    padding: 32px 16px;
}

@media only screen and (min-width: 768px) {

    .new-items {
        padding: 48px;
    }

}

@media only screen and (min-width: 1024px) {

    .new-items {
        padding: 0;
    }

}

/****************************************
Layouts / Popular Items
****************************************/

.popular-items {
    padding: 32px 16px 16px;
    background: #ffea72;
}


@media only screen and (min-width: 768px) {

    .popular-items {
        padding: 56px 48px 40px;
    }

}

@media only screen and (min-width: 1024px) {

    .popular-items {
        padding: 64px 0 48px;
    }

}

/****************************************
Layouts / FC2ログイン
****************************************/

.container-fluid {
  padding: 0 16px;
}

.page-heading {
  padding: 32px 16px;
  background: #ff5c69;
  text-align: center;
  color: #fff;
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: bold;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  border: none;
  margin-bottom: 24px;
}

#mypage_login_wrap > p {
  font-size: 13px;
  font-size: 1.3rem;
  line-height: 1.6;
  text-align: left;
  margin-bottom: 16px;
}

#top_box__button_menu > p > a {
  display: block;
  width: 100%;
  height: 50px;
  line-height: 50px;
  text-align: center;
  background: #34324a;
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: bold;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  color: #fff;
  border: none;
  border-radius: 5px;
  outline: none;
  transition: 0.5s ease;
  position: relative;
  padding: 0;
  margin-bottom: 16px;
}

#top_box__button_menu > a {
  text-align: center;
  display: block;
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: bold;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  color: #34324a;
  border: 2px solid #34324a;
  border-radius: 5px;
  height: 48px;
  line-height: 44px;
}

@media only screen and (min-width: 768px) {

  .container-fluid {
    padding: 0 16px;
  }

  .page-heading {
    font-size: 21px;
    font-size: 2.1rem;
    padding: 64px 48px;
    margin: 0 0 48px;
  }

  #login_box {
    margin: 0 0 48px;
    padding: 0;
  }

  #mypage_login_wrap {
    width: 660px;
    padding: 0;
    margin: 0 auto;
    float: none;
  }

  #mypage_login_wrap > p {
    font-size: 16px;
    font-size: 1.6rem;
    line-height: 1.8;
    margin-bottom: 32px;
    text-align: center;
  }

  #top_box__footer {
    margin: 0;
  }

  #top_box__button_menu {
    padding: 0;
    margin: 0;
    float: none;
    width: 100%;
  }

  #top_box__button_menu > p > a {
    height: 58px;
    line-height: 58px;
    font-size: 15px;
    font-size: 1.5rem;
    margin-bottom: 20px;
  }

  #top_box__button_menu > a {
    height: 56px;
    line-height: 52px;
    font-size: 15px;
    font-size: 1.5rem;
  }

}

@media only screen and (min-width: 1024px) {

  .page-heading {
    font-size: 23px;
    font-size: 2.3rem;
    padding: 0;
    color: #212121;
    background: none;
    margin-bottom: 64px;
  }

  #mypage_login_wrap > p {
    text-align: center;
    margin-bottom: 40px;
  }

  #login_box {
    background: #fff;
    padding: 64px;
  }

}

/****************************************
Layouts / Main
****************************************/

@media only screen and (min-width: 1024px) {

  .theme_side_right .main {
      width: 683px;
      float: left;
  }

}

/****************************************
Layouts / Side
****************************************/

.side-right {
    padding: 0 16px 32px;
}

@media only screen and (min-width: 768px) {

    .side-right {
        padding: 0 32px 56px;
        font-size: 0;
    }

}

@media only screen and (min-width: 1024px) {

  .side-right {
      float: right;
      width: 301px;
      padding: 0;
      margin: 0 0 0 56px;
      font-size: inherit;
  }

}

/****************************************
Layouts / NEWS and Banners
****************************************/

.news-and-banners {
    background: #fff;
}

.news-area {
    padding: 32px 16px;
}

@media only screen and (min-width: 768px) {

    .news-area {
        padding: 56px 48px;
    }

    .banners {
        padding: 0 48px 56px;
    }

}

@media only screen and (min-width: 1024px) {

    .news-and-banners {
        padding: 64px 0;
    }

    .news-area {
        padding: 0;
        width: 42%;
        float: left;
        padding: 0 24px 0 0;
    }

    .banners {
        float: right;
        width: 58%;
        padding: 0 0 0 24px;
    }

}

/****************************************
Layouts / Shop Guide
****************************************/

.guide {
    background: #f7f7f7;
    padding: 32px 0;
}

@media only screen and (min-width: 768px) {

    .guide {
        padding: 56px 0;
    }

}

@media only screen and (min-width: 1024px) {

    .guide {
        padding: 64px 0;
    }

}

/****************************************
Layouts / Single
****************************************/

.item-single-detail {
    padding-top: 43px;
}

@media only screen and (min-width: 768px) {

    .item-single {
        background: #fff;
        padding: 48px;
    }

    .item-single-images {
        width: 50%;
        float: left;
        padding-right: 20px;
    }

    .item-single-detail {
        width: 50%;
        float: right;
        padding: 0 0 0 20px;
    }

}

@media only screen and (min-width: 1024px) {

    .item-single {
        padding: 64px;
    }

    .item-single-images {
        padding-right: 24px;
    }

    .item-single-detail {
        padding: 0 0 0 24px;
    }

}

/****************************************
Layouts / Sub Pages
****************************************/

.sub-page {
    padding: 0 16px 32px;
    background: #fff;
}

@media only screen and (min-width: 768px) {

    .sub-page {
        padding: 0 48px 56px;
        background: #fff;
    }

}

@media only screen and (min-width: 1024px) {

    .sub-page {
        padding: 64px;
    }

    .item_list_page .sub-page {
        padding: 0;
    }

    .sub-page.forgot-page {
        width: 535px;
        margin: 0 auto;
    }

    .sub-page.page-multiple {
        width: 678px;
        margin: 0 auto;
    }

}

/****************************************
Layouts / Order
****************************************/

.order-main {
    margin-bottom: 16px;
}

@media only screen and (min-width: 768px) {

    .order-main {
        margin-bottom: 24px;
    }

}

@media only screen and (min-width: 1024px) {

    .order-main {
        float: left;
        margin-bottom: 0;
        width: 550px;
    }

    .order-sub {
        float: right;
        width: 306px;
        margin-left: 56px;
    }

}

/****************************************
Layouts / Footer
****************************************/

.footer {
    background: #fff;
    border-top: 1px solid #eee;
    margin: 0;
    padding: 36px 16px 32px;
}

@media only screen and (min-width: 768px) {

    .footer {
        padding: 48px;
    }

}

@media only screen and (min-width: 1024px) {

    .footer {
        padding: 64px 0 50px;
    }

    .footer-top {
        float: left;
        width: 700px;
    }

    .footer-bottom {
        float: right;
        width: 250px;
        padding-top: 8px;
    }

}

/************************************************
Components
************************************************/

/****************************************
Components / Logo
****************************************/

/********************************
Components / Logo / Header
********************************/

.header-logo {
    padding: 11px 0 0 18px;
    float: left;
}

.header-logo > a {
    display: block;
    width: 167px;
    height: 31px;
    background: url(../img/common/logo-header-sp.png);
    background-size: 167px 31px;
    background-position: center;
    background-repeat: no-repeat;
}

@media only screen and (min-width: 768px) {

    .header-logo {
        padding: 22px 0 0 40px;
    }

    .header-logo > a {
        width: 270px;
        height: 50px;
        background: url(../img/common/logo-header-pc.png);
        background-size: 270px 50px;
    }

}

@media only screen and (min-width: 1024px) {

    .header-logo {
        padding: 32px 0 0 0;
    }

}

/********************************
Components / Logo / Footer
********************************/

.footer-logo {
    text-align: center;
    margin-bottom: 20px;
}

.footer-logo > a {
    display: inline-block;
    width: 226px;
    height: 42px;
    background: url(../img/common/logo-medium.png);
    background-size: 226px 42px;
    background-position: center;
    background-repeat: no-repeat;
}

@media only screen and (min-width: 768px) {

    .footer-logo {
        margin-bottom: 24px;
    }

    .footer-logo > a {
        width: 291px;
        height: 54px;
        background: url(../img/common/logo-large.png);
        background-size: 291px 54px;
    }

}

@media only screen and (min-width: 1024px) {

    .footer-logo {
        text-align: left;
    }

}

/********************************
Components / Logo / Error
********************************/

.error-logo {
    text-align: center;
    margin-bottom: 26px;
}

.error-logo > a {
    display: inline-block;
    width: 226px;
    height: 42px;
    background: url(../img/common/logo-medium.png);
    background-size: 226px 42px;
    background-position: center;
    background-repeat: no-repeat;
}

@media only screen and (min-width: 768px) {

    .error-logo {
        margin-bottom: 40px;
    }

    .error-logo > a {
        width: 291px;
        height: 54px;
        background: url(../img/common/logo-large.png);
        background-size: 291px 54px;
    }

}

/****************************************
Components / Section Title
****************************************/

/********************************
Components / Section Title / Main
********************************/

.section-title {
    font-size: 17px;
    font-size: 1.7rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    margin-bottom: 24px;
    text-align: center;
    letter-spacing: 2.2px;
}

.sub-page > .section-title {
    font-size: 16px;
    font-size: 1.6rem;
    margin: 0 -16px 24px;
    padding: 32px 16px;
    background: #ff5c69;
    color: #fff;
}

@media only screen and (min-width: 768px) {

    .section-title {
        font-size: 21px;
        font-size: 2.1rem;
        margin-bottom: 40px;
        letter-spacing: 3.5px;
    }

    .sub-page > .section-title {
        font-size: 21px;
        font-size: 2.1rem;
        margin: 0 -48px 48px;
        padding: 64px 48px;
    }

}

@media only screen and (min-width: 1024px) {

    .sub-page > .section-title {
        padding: 56px;
        background: #f7f7f7;
        margin: -64px -64px 64px;
        font-size: 23px;
        font-size: 2.3rem;
        padding-top: 0;
        color: #212121;
    }

    .item_list_page .sub-page > .section-title {
        font-size: 21px;
        font-size: 2.1rem;
        padding: 0;
        background: none;
        margin: 0 0 40px;
    }

}

/********************************
Components / Section Title / Side
********************************/

@media only screen and (max-width: 1023px) {

    .side-section-title {
        font-size: 13px;
        font-size: 1.3rem;
        font-weight: bold;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
        padding: 20px 16px;
        position: relative;
        transition: 0.5s ease;
        background: #f5f5f5;
        border-top: 1px solid #eee;
        border-bottom: 1px solid #eee;
    }

    .side-section-title:after {
        content: "\f489";
        display: inline-block;
        font-family: "Ionicons";
        speak: none;
        font-style: normal;
        font-weight: normal;
        font-variant: normal;
        text-transform: none;
        text-rendering: auto;
        line-height: 1;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
        position: absolute;
        top: 11px;
        right: 16px;
        font-size: 30px;
        font-size: 3rem;
    }

    .side-section-title.active {
        background: #ff5c69;
        color: #fff;
    }

    .side-section-title.active:after {
        content: "\f462";
    }

}

@media only screen and (min-width: 768px) {

    .side-section-title {
        font-size: 14px;
        font-size: 1.4rem;
        padding: 20px;
    }

    .side-section-title:after {
        font-size: 32px;
        font-size: 3.2rem;
    }

}

@media only screen and (min-width: 1024px) {

    .side-section-title {
        font-size: 16px;
        font-size: 1.6rem;
        font-weight: bold;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
        padding: 0 0 24px 18px;
        border-bottom: 1px solid #eee;
        letter-spacing: 1.2px;
    }

}

/****************************************
Components / Category Menu
****************************************/

/********************************
Components / Category Menu / Main
********************************/

#category {
    display: none;
}

#category .category-nav-item ul {
    display: block;
}

@media only screen and (min-width: 1024px) {

    #category {
        display: block;
        background: #f7f7f7;
    }

    #category .category-nav-list > .category-nav-item {
        float: left;
        position: relative;
        transition: 0.5s ease;
    }

    #category .category-nav-list > .side-nav-item {
        float: none;
    }

    #category .category-nav-list > .category-nav-item:hover {
        background: #fff;
    }

    #category .category-nav-list > .category-nav-item > a {
        height: 48px;
        line-height: 48px;
        font-size: 13px;
        font-size: 1.3rem;
        font-weight: bold;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
        padding: 0 20px;
        border-right: 1px solid #dcdcdc;
    }

    #category .category-nav-list > .side-nav-item > a {
        padding: 0 20px 0 60px;
        border-right: none;
    }

    #category .category-nav-list > .category-nav-item > ul {
        position: absolute;
        left: 0;
        top: 48px;
        width: 300%;
        background: #ffffff;
        padding: 32px 20px 6px;
        box-shadow: 0 40px 60px rgba(0,0,0,0.2);
        z-index: 10;
        font-size: 0;
        opacity: 0;
        display: block;
        visibility: hidden;
        opacity: 0;
        transition: 0.5s ease;
    }

    #category .category-nav-list > .category-nav-item:hover > ul {
        display: block;
        visibility: visible;
        opacity: 1;
    }

    #category .category-nav-list > .category-nav-item > ul > li {
        display: inline-block;
        margin: 0 12px 24px;
    }

    #category .category-nav-list > .side-nav-item > ul > li {
        display: block;
    }

    #category .category-nav-list > .category-nav-item > ul > li > a {
        display: block;
        font-size: 13px;
        font-size: 1.3rem;
        font-weight: bold;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
        color: #333;
    }

    #category .category-nav-list > .category-nav-item > ul > li > a:hover {
        color: #ff4654;
    }

}

/********************************
Components / Category Menu / Side & Drawer
********************************/

.side-categories .category-nav-item ul,
.drawer-categories .category-nav-item ul {
    display: none;
}

.side-categories .category-nav-list > .category-nav-item > ul,
.side-categories .category-nav-list > .category-nav-item > ul > .category-nav-item > ul {
    display: block;
}

.side-categories-wrapper {
    display: none;
}

.side-link,
.side-categories .category-nav-list > .category-nav-item,
.drawer-categories .category-nav-list > .category-nav-item {
    border-bottom: 1px solid #eee;
}

.side-link > a,
.side-categories .category-nav-list > .category-nav-item > a,
.drawer-categories .category-nav-list > .category-nav-item > a {
    display: block;
    font-size: 13px;
    font-size: 1.3rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    position: relative;
    padding: 18px 16px 18px 46px;
    background: #fff;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}

.side-link > a:before,
.side-categories .category-nav-list > .category-nav-item > a:before,
.drawer-categories .category-nav-list > .category-nav-item > a:before {
    content: "\f362";
    display: inline-block;
    font-family: "Ionicons";
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    text-rendering: auto;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 17px;
    color: #ff5c69;
    position: absolute;
    top: 15px;
    left: 16px;
}

.side-categories .category-nav-list > .category-nav-item > ul {
    margin: 5px 0 25px 46px;
}

.side-categories .category-nav-list > .category-nav-item > ul > li {
    margin-top: 16px;
}

.side-categories .category-nav-list > .category-nav-item > ul > li:first-child {
    margin-top: 0;
}

.side-categories .category-nav-list > .category-nav-item > ul > li > a {
    display: block;
    font-size: 13px;
    font-size: 1.3rem;
    font-weight: bold;
    color: #333;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}

.side-categories .category-nav-list > .category-nav-item > ul > .category-nav-item > ul > .category-nav-item {
    margin: 16px 0 0 10px;
}

.side-categories .category-nav-list > .category-nav-item > ul > .category-nav-item > ul > .category-nav-item > a {
    display: block;
    font-size: 13px;
    font-size: 1.3rem;
    font-weight: bold;
    color: #555;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}

@media only screen and (min-width: 768px) {

    .side-link > a,
    .side-categories .category-nav-list > .category-nav-item > a,
    .drawer-categories .category-nav-list > .category-nav-item > a {
        font-size: 14px;
        font-size: 1.4rem;
        padding: 18px 20px 18px 50px;
    }

    .side-link > a:before,
    .side-categories .category-nav-list > .category-nav-item > a:before,
    .drawer-categories .category-nav-list > .category-nav-item > a:before {
        top: 16px;
        left: 20px;
    }

}

@media only screen and (min-width: 768px) {

    .side-categories {
        width: 50%;
        display: inline-block;
        padding: 0 16px;
        vertical-align: top;
    }

    .side-categories .category-nav-list > .category-nav-item > ul {
        margin: 5px 0 25px 51px;
    }

    .side-search {
        width: 50%;
        display: inline-block;
        padding: 0 16px;
        vertical-align: top;
    }

}

@media only screen and (min-width: 1024px) {

    .side-categories {
        padding: 0;
        width: 100%;
        margin-bottom: 48px;
    }

    .side-search {
        padding: 0;
        width: 100%;
    }

    .side-categories-wrapper {
        display: block !important;
        height: 100% !important
    }

}

/****************************************
Components / Search
****************************************/

.search-inner {
    position: relative;
}

.search input[type="search"]::-webkit-input-placeholder {
  color: #777;
}

.search input[type="search"]::-moz-placeholder {
  color: #777;
}

.search input[type="search"]:-moz-placeholder {
  color: #777;
}

.search input[type="search"]:-ms-input-placeholder {
  color: #777;
}

.search input[type="search"] {
    border: none;
    padding: 0 50px 0 13px;
    font-size: 16px;
    font-size: 1.6rem;
    width: 100%;
    height: 42px;
    color: #000;
    border: 1px solid #f0f2f5;
    background: #f3f5f7;
    border-radius: 3px !important;
}

.search-submit {
    position: absolute;
    top: 0;
    right: 0;
    width: 42px;
    height: 42px;
    line-height: 42px;
    padding: 0;
    border: none;
    background: none;
    outline: none;
    font-size: 18px;
    font-size: 1.8rem;
    color: #3e3e3e;
}

.search input[type="search"]:focus {
    background: #fff;
}

@media only screen and (min-width: 1024px) {

    .search input[type="search"] {
        font-size: 13px;
        font-size: 1.3rem;
    }

}

/********************************
Components / Search / Header
********************************/

.drawer_block.search-wrapper {
    display: none;
}

@media only screen and (min-width: 1024px) {

    .drawer_block.search-wrapper {
        display: block;
    }

    .search-wrapper {
        position: absolute;
        top: 39px;
        right: 0;
    }

}

/********************************
Components / Search / Side
********************************/

.side-search-wrapper {
    display: none;
    padding: 16px;
    border-bottom: 1px solid #eee;
}

.side-search-wrapper .search input[type="search"] {
    padding: 0 54px 0 16px;
    height: 46px;
}

.side-search-wrapper .search-submit {
    width: 46px;
    height: 46px;
    line-height: 46px;
}

@media only screen and (min-width: 1024px) {

    .side-search-wrapper {
        display: block !important;
        padding: 24px 18px 0;
        border-bottom: none;
    }

}

/********************************
Components / Search / Drawer
********************************/

.drawer-search .search {
    padding: 16px;
    background: #fff;
    border: 1px solid #eee;
}

@media only screen and (min-width: 768px) {

    .drawer-search .search {
        padding: 20px;
    }

}

/****************************************
Components / Member Menu
****************************************/

/********************************
Components / Member Menu / Header
********************************/

.header-bottom .member-nav {
    display: none;
}

@media only screen and (min-width: 1024px) {

    .header-bottom .member-nav {
        display: block;
        float: right;
        margin: 56px 270px 0 0;
    }

    .header-bottom .member-nav-item {
        float: left;
        margin-left: 32px;
    }

    .header-bottom .nav-favorite {
        margin-left: 24px;
    }

    .header-bottom .member-nav-item > a {
        display: block;
        font-size: 12px;
        font-size: 1.2rem;
        font-weight: bold;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
        position: relative;
        padding-left: 32px;
    }

    .header-bottom .member-nav-item > a > i {
        position: absolute;
    }

    .header-bottom .nav-mypage > a > i {
        color: #ff8517;
        font-size: 25px;
        font-size: 2.5rem;
        top: -7px;
        left: 0;
    }

    .header-bottom .nav-login > a > i {
        color: #1ab37d;
        font-size: 26px;
        font-size: 2.6rem;
        top: -8px;
        left: 1px;
    }

    .header-bottom .nav-favorite > a > i {
        color: #ff6fac;
        font-size: 24px;
        font-size: 2.4rem;
        top: -6px;
        left: 1px;
    }

}

/********************************
Components / Member Menu / Drawer
********************************/

.drawer-member .member-nav-list {
    background: #fff;
    border-bottom: 1px solid #eee;
}

.drawer-member .member-nav-item {
    width: 33.333333%;
    float: left;
    border-left: 1px solid #eee;
}

.drawer-member .member-nav-item:first-child {
    border-left: none;
}

.drawer-member .member-nav-item > a {
    display: block;
    font-size: 11px;
    font-size: 1.1rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    position: relative;
    padding: 36px 0 16px;
    text-align: center;
}

.drawer-member .member-nav-item > a > i {
    position: absolute;
    left: 0;
    right: 0;
}

.drawer-member .nav-mypage > a > i {
    color: #ff8517;
    font-size: 21px;
    font-size: 2.1rem;
    top: 9px;
}

.drawer-member .nav-login > a > i {
    color: #1ab37d;
    font-size: 21px;
    font-size: 2.1rem;
    top: 8px;
}

.drawer-member .nav-favorite > a > i {
    color: #ff6fac;
    font-size: 20px;
    font-size: 2rem;
    top: 10px;
}

@media only screen and (min-width: 768px) {

    .drawer-member .member-nav-item > a {
        font-size: 12px;
        font-size: 1.2rem;
        padding: 40px 0 18px;
    }

    .drawer-member .nav-mypage > a > i {
        color: #ff8517;
        top: 11px;
    }

    .drawer-member .nav-login > a > i {
        top: 10px;
    }

    .drawer-member .nav-favorite > a > i {
        top: 12px;
    }

}

/****************************************
Components / Slider
****************************************/

.slick-slide img {
    width: 100%;
}

.slick-dots {
    bottom: -27px;
    font-size: 0;
}

.slick-dots li {
    width: 11px;
    height: 11px;
    margin: 0 8px;
}

.slick-dots li button {
    width: 100%;
    height: 100%;
    padding: 0;
}

.slick-dots li button:before {
    width: 100%;
    height: 100%;
    line-height: 1;
    opacity: 1;
    background: #dcdcdc;
}

.slick-dots li.slick-active button:before {
    opacity: 1;
    background: #ff5c69;
}

@media only screen and (min-width: 768px) {

    .slick-dots {
        bottom: -36px;
    }

    .slick-dots li {
        width: 12px;
        height: 12px;
        margin: 0 12px;
    }

    .slick-dots li button.thumbnail img {
        opacity: 0.65;
        transition: 0.5s ease;
    }

    .slick-dots li button.thumbnail:hover img,
    .slick-dots li.slick-active button.thumbnail img {
        opacity: 1;
    }

}

/********************************
Components / Slider / Main
********************************/

.slick-slider {
    margin-bottom: 0;
}

.slider-item > img {
    width: 100%;
}

@media only screen and (min-width: 768px) {

    .slider-items {
        padding: 0;
    }

    .slider-item-wrapper {
        max-width: 830px;
        margin: 0 auto;
    }

    .slider-items .slick-list {
        overflow: visible;
    }

}

/********************************
Components / Slider / Single
********************************/

@media only screen and (min-width: 768px) {

    .item-single-slider > .slick-list {
        margin-bottom: 32px;
    }

    .item-single-slider-image {
        background: #fff;
        text-align: center;
        border: 1px solid #eee;
    }

    .item-single-slider-image > img {
        display: inline;
        max-height: 100%;
    }

    .item-single-slider > .slick-dots {
        position: static;
        margin: 0 -15px;
        bottom: 0;
        width: auto;
    }

    .item-single-slider > .slick-dots > li {
        width: 33.333333%;
        height: auto;
        margin: 0;
        padding: 0 15px;
    }

    .slick-dots li button.thumbnail {
        text-align: center;
        border: 1px solid #eee;
    }

    .slick-dots li button.thumbnail > img {
        display: inline;
        width: auto;
        max-height: 100%;
    }

}

/****************************************
Components / Form
****************************************/

.extra-form {
    margin: 0;
}

span.required {
    font-weight: bold !important;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    margin-left: 8px;
    font-size: 10px;
    font-size: 1rem;
    padding: 5px;
    background: #ffdbde;
    color: #ff3d4c;
    position: relative;
    top: -1px;
}

span.required1 {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    margin-left: 5px;
    font-size: 10px;
    font-size: 0.8rem;
    padding: 3px;
    background: #ffdbde;
    color: #ff3d4c;
    position: relative;
    top: -1px;
}


.item-single-info-row-title > span.required {
    top: 3px;
}

.select-wrapper {
    position: relative;
    display: inline-block;
}

.select-wrapper:after {
    content: "\f104";
    font-size: 13px;
    font-size: 1.3rem;
    display: inline-block;
    font-family: "Ionicons";
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    text-rendering: auto;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    position: absolute;
    top: 15px;
    right: 11px;
    pointer-events: none;
}

#entry_birth .select-wrapper:after {
    right: 19px;
}

.content-wrapper .select-wrapper:after {
    display: none;
}

select.form-control {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    text-overflow: "";
    text-indent: .01px;
    background: #fff;
    border: 1px solid #e2e2e2;
    padding: 0 27px 0 11px;
    width: 100%;
    height: 40px;
    font-size: 16px;
    font-size: 1.6rem;
}

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

select:-moz-focusring {
    color: transparent;
    text-shadow: 0 0 0 #000;
}

input.form-control,
textarea.form-control {
    border-radius: 3px !important;
    font-size: 16px;
    font-size: 1.6rem;
    padding: 10px;
    background: none;
    border: 1px solid #e2e2e2;
    width: 100%;
    outline: none;
    transition: 0.5s ease;
}

input.form-control {
    height: 40px;
}

textarea.form-control {
    height: 160px !important;
}

.form-control:focus {
    border: 1px solid #a0a0a0 !important;
}

.has-error .form-control {
    border: 1px solid #ffb1b7;
    background: #ffdde0;
}

@media only screen and (min-width: 768px) {

    input.form-control {
        height: 46px;
        padding: 16px;
    }

    textarea.form-control {
        padding: 16px;
    }

    select.form-control {
        padding: 0 40px 0 16px;
        height: 44px;
    }

    input.form-control[type="number"] {
        height: 44px;
    }

    .select-wrapper:after {
        font-size: 14px;
        font-size: 1.4rem;
        top: 16px;
        right: 16px;
    }

}

@media only screen and (min-width: 1024px) {

    input.form-control,
    textarea.form-control {
        font-size: 14px;
        font-size: 1.4rem;
    }

    select.form-control {
        font-size: 14px;
        font-size: 1.4rem;
    }

}

/****************************************
Components / Table
****************************************/

/********************************
Components / Table / Default
********************************/

.table-default {
    width: 100%;
}

.table-default > tbody > tr {
    display: block;
    font-size: 13px;
    font-size: 1.3rem;
    margin-top: 24px;
}

.table-default > tbody > tr:first-child {
    margin-top: 0;
}

.table-default > tbody > tr > th {
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    padding: 14px 16px;
    text-align: left;
    display: block;
    background: #edeff1;
}

.table-default > tbody > tr > th > label {
    font-weight: bold;
}

.table-default > tbody > tr > td {
    padding: 16px 16px 0;
    text-align: left;
    display: block;
    line-height: 1.6;
}

@media only screen and (min-width: 768px) {

    .table-default > tbody > tr {
        font-size: 15px;
        font-size: 1.5rem;
        margin-top: 32px;
    }

    .table-default > tbody > tr > th {
        padding: 20px 24px;
    }

    .table-default > tbody > tr > td {
        padding: 24px 24px 0;
        line-height: 1.8;
    }

}

/********************************
Components / Table / Customer
********************************/

.table-customer {
    width: 100%;
    border-bottom: 1px solid #eee;
}

.entry-page .table-customer {
    margin-bottom: 24px;
}

.table-customer > tbody > tr > th {
    display: block;
    text-align: left;
    padding-left: 5px;
}

.table-customer > tbody > tr > th > label {
    font-size: 13px;
    font-size: 1.3rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.table-customer > tbody > tr > td {
    display: block;
    padding: 16px 0 24px;
    font-size: 0;
}

.form-name,
.form-zip,
.form-tel,
.form-fax {
    font-size: 0;
}

.form-name,
.form-zip1,
.form-zip2,
.form-tel1,
.form-tel2,
.form-tel3,
.form-fax1,
.form-fax2,
.form-fax3 {
    display: inline-block;
    position: relative;
}

.form-name {
    width: 50%;
}

.form-name:first-child {
    padding-right: 8px;
}

.content-wrapper .form-name,
.content-wrapper .form-tel {
    width: auto;
    font-size: 13px;
    font-size: 1.3rem;
}

.form-zip1,
.form-tel1,
.form-tel2,
.form-fax1,
.form-fax2 {
    margin-right: 17px;
}

.form-zip1:after,
.form-tel1:after,
.form-tel2:after,
.form-fax1:after,
.form-fax2:after {
    content: "-";
    position: absolute;
    top: 11px;
    right: -11px;
    font-size: 17px;
    font-size: 1.7rem;
}

.form-zip:before {
    content: "〒";
    font-size: 13px;
    font-size: 1.3rem;
    margin: 0 8px 0 2px;
}

.form-zip1 {
    width: 17%;
}

.form-zip2 {
    width: 20%;
}

.zip-search {
    display: inline-block;
    vertical-align: top;
}

.zip-search > button {
    font-size: 11px;
    font-size: 1.1rem;
    height: 40px;
    padding: 0 15px;
    border: none;
    background: #868686;
    color: #fff;
    margin-left: 8px;
    border-radius: 3px;
    transition: 0.5s ease;
}

.zip-search > button:hover {
    background: #676767;
}

.form-prefectures {
    margin: 16px 0 8px;
}

.form-address1 {
    margin-bottom: 8px;
}

.form-address input {
    width: 100%;
}

#entry_birth {
    margin-left: -8px;
}

#entry_birth {
    font-size: 13px;
    font-size: 1.3rem;
}

#entry_birth select,
#entry_birth select:first-child {
    margin: 0 8px;
}

#entry_sex {
    font-size: 13px;
    font-size: 1.3rem;
}

.form-tel1,
.form-tel2,
.form-tel3 {
    width: 19%;
}

.content-wrapper .form-tel1,
.content-wrapper .form-tel2,
.content-wrapper .form-tel3 {
    width: auto;
    margin-right: 0;
}

#nonmember_email_first,
#nonmember_email_second,
.form-email > input,
.form-password > input {
    width: 100%;
}

.form-email-first,
.form-email:first-child,
.form-password:first-child {
    margin-bottom: 8px;
}

#entry_sex .radio {
    margin-right: 16px;
}

#entry_sex .radio input[type="radio"] {
    margin-right: 8px;
    position: relative;
    top: 2px;
}

@media only screen and (min-width: 768px) {

    .entry-page .table-customer {
        margin-bottom: 48px;
    }

    .table-customer > tbody > tr {
        border-top: 1px solid #f1f1f1;
    }

    .table-customer > tbody > tr > th {
        display: table-cell;
        padding: 46px 32px 32px 0;
        vertical-align: top;
        width: 200px;
        text-align: right;
    }

    .table-customer > tbody > tr > th > label {
        font-size: 14px;
        font-size: 1.4rem;
    }

    .table-customer > tbody > tr > td {
        display: table-cell;
        padding: 32px 0;
    }

    .form-name:first-child {
        padding-right: 12px;
    }

    .form-zip1,
    .form-tel1,
    .form-tel2,
    .form-fax1,
    .form-fax2 {
        margin-right: 25px;
    }

    .form-zip1:after,
    .form-tel1:after,
    .form-tel2:after,
    .form-fax1:after,
    .form-fax2:after {
        top: 13px;
        right: -16px;
        font-size: 19px;
        font-size: 1.9rem;
    }

    .form-zip:before {
        font-size: 14px;
        font-size: 14px;
        margin: 0 16px 0 0;
        position: relative;
        top: 1px;
    }

    .zip-search > button {
        font-size: 12px;
        font-size: 1.2rem;
        height: 46px;
        padding: 0 16px;
        margin-left: 12px;
    }

    .form-prefectures {
        margin: 24px 0 12px;
    }

    .form-address1 {
        margin-bottom: 12px;
    }

    .form-email-first,
    .form-email:first-child,
    .form-password:first-child {
        margin-bottom: 12px;
    }

    .tr-sex > th {
        padding: 32px 32px 32px 0 !important;
    }

    #entry_sex {
        font-size: 14px;
        font-size: 1.4rem;
    }

    #entry_birth select,
    #entry_birth select:first-child {
        margin: 0 9px;
    }

}

@media only screen and (min-width: 1024px) {

    .table-customer > tbody > tr > th {
        width: 280px;
    }

    #entry_sex .radio {
        position: relative;
        top: 1px;
    }

    #entry_sex .radio input[type="radio"] {
        top: 0;
    }

}

/********************************
Components / Table / Cart
********************************/

.table-cart {
    width: 100%;
}

.table-cart > thead {
    display: none;
}

.table-cart > tbody > tr {
    display: block;
    margin-bottom: 24px;
}

.table-cart > tbody > tr > td {
    display: block;
    position: relative;
    text-align: right;
}

.table-cart > tbody > tr > td:before {
    position: absolute;
    top: 1px;
    left: 0;
    font-size: 13px;
    font-size: 1.3rem;
}

.cart-unit-price:before {
    content: "単価";
}

.cart-quantity:before {
    content: "数量";
}

.cart-subtotal:before {
    content: "小計";
    left: 0 !important;
}

.cart-item {
    margin-bottom: 16px;
    border-top: 1px solid #eee;
    border-bottom: 1px solid #eee;
}

.cart-item > a {
    display: table;
    table-layout: fixed;
    width: 100%;
}

.cart-item > a:hover {
    background: rgba(0,0,0,0.02);
    color: #2d2d2d;
}

.cart-item-thumb {
    display: table-cell;
    width: 122px;
    vertical-align: top;
    padding: 16px;
}

.cart-item-thumb > img {
    max-width: 100%;
    box-shadow: 0 7px 23px #e2e2e2;
}

.cart-item-text {
    display: table-cell;
    width: 100%;
    vertical-align: middle;
    text-align: left;
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    line-height: 1.5;
    padding: 16px 16px 16px 0;
}

.cart-unit-price {
    line-height: 15px;
    margin: 0 16px 16px;
    font-size: 15px;
    font-size: 1.5rem;
}

.cart-quantity {
    margin: 0 16px 16px;
}

.cart-quantity > p {
    display: inline-block;
    border: 1px solid #e0e0e0;
    vertical-align: top;
    min-width: 52px;
    height: 31px;
    line-height: 31px;
    text-align: center;
    font-size: 13px;
    font-size: 1.3rem;
    margin-bottom: 6px;
}

.cart-quantity-btn-list {
    font-size: 0;
    margin: 0 -3px;
}

.cart-quantity-btn-item {
    display: inline-block;
    width: 23px;
    height: 23px;
    margin: 0 3px;
    line-height: 23px;
}

.cart-quantity-btn-item > a,
.cart-quantity-btn-item > span {
    display: block;
    color: #fff;
    font-size: 18px;
    font-size: 1.8rem;
    text-align: center;
    background: #ff5c69;
    border-radius: 2px;
}

.cart-quantity-btn-item > a:hover {
    background: #ff2e3e;
}

.cart-quantity-btn-item.minus > a {
    background: #909090;
}

.cart-quantity-btn-item.minus > a:hover {
    background: #777;
}

.cart-quantity-btn-item.minus > span {
    background: #e2e2e2;
}

.cart-subtotal {
    font-size: 15px;
    font-size: 1.5rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    padding-bottom: 16px;
    margin: 0 16px 16px;
    border-bottom: 1px solid #bdbdbd;
}

.cart-remove-btn {
    margin: 0 16px;
}

.table-cart > tfoot > tr {
    display: block;
}

.cart-total-price-title,
.cart-empty {
    display: none;
}

.cart-total-price {
    display: block;
    position: relative;
    font-size: 17px;
    font-size: 1.7rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-align: right;
    padding: 24px 32px;
    background: #edeff1;
    margin: 0 -16px;
}

.cart-total-price:before {
    content: "合計";
    position: absolute;
    top: 26px;
    left: 32px;
    font-size: 14px;
    font-size: 1.4rem;
}

@media only screen and (min-width: 768px) {

    .table-cart > tbody > tr {
        margin-bottom: 32px;
    }

    .table-cart > tbody > tr > td:before {
        font-size: 15px;
        font-size: 1.5rem;
        top: 1px;
    }

    .cart-item {
        margin-bottom: 24px;
    }

    .cart-item-thumb {
        width: 168px;
        padding: 24px;
    }

    .cart-item-text {
        font-size: 16px;
        font-size: 1.6rem;
        padding: 24px 0;
    }

    .cart-unit-price {
        font-size: 17px;
        font-size: 1.7rem;
        margin: 0 24px 24px;
    }

    .cart-quantity {
        margin: 0 24px 24px;
    }

    .cart-quantity > p {
        min-width: 60px;
        height: 34px;
        line-height: 33px;
        font-size: 14px;
        font-size: 1.4rem;
        margin-bottom: 8px;
    }

    .cart-quantity-btn-list {
        margin: 0 -4px;
    }

    .cart-quantity-btn-item {
        width: 26px;
        height: 26px;
        margin: 0 4px;
    }

    .cart-quantity-btn-item > a,
    .cart-quantity-btn-item > span {
        font-size: 20px;
        font-size: 2rem;
        line-height: 26px;
    }

    .cart-subtotal {
        font-size: 17px;
        font-size: 1.7rem;
        padding-bottom: 24px;
        margin: 0 24px 24px;
    }

    .cart-total-price:before {
        top: 33px;
        left: 72px;
        font-size: 16px;
        font-size: 1.6rem;
    }

    .cart-total-price {
        font-size: 19px;
        font-size: 1.9rem;
        padding: 32px 72px;
        margin: 0 -48px;
    }

    .cart-remove-btn {
        margin: 0 24px;
    }

}

@media only screen and (min-width: 1024px) {

    .table-cart > thead {
        display: table-header-group;
    }

    .table-cart > thead > tr > th {
        background: #edeff1;
        padding: 20px 24px;
        font-size: 15px;
        font-size: 1.5rem;
        font-weight: bold;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
    }

    .table-cart > tbody > tr {
        display: table-row;
        margin-bottom: 0;
    }

    .table-cart > tbody > tr > td {
        display: table-cell;
        text-align: center;
        margin: 0 !important;
        padding: 24px !important;
        border-top: none;
        border-right: none;
        border-bottom: 1px solid #eee;
    }

    .table-cart > tbody > tr > td.cart-item {
        padding: 0 !important;
    }

    .table-cart > tbody > tr > td:before {
        display: none;
    }

    .cart-item-thumb {
        width: 148px;
        padding: 24px;
    }

    .cart-item-text {
        padding: 24px 24px 24px 0;
    }

    .cart-unit-price,
    .cart-subtotal {
        width: 140px;
    }

    .cart-subtotal {
        border-bottom: none;
    }

    .table-cart > tfoot > tr {
        display: table-row;
    }

    .table-cart > tfoot > tr > td {
        display: table-cell;
        border-top: none;
        border-right: none;
        border-left: 1px solid #eee;
        border-bottom: 1px solid #eee;
    }

    .table-cart > tfoot > tr > td:first-child {
        border-left: none;
    }

    .cart-total-price:before {
        display: none;
    }

    .cart-total-price-title {
        background: #f6f7f9;
        text-align: right;
        padding: 32px 36px 32px 26px;
        font-size: 16px;
        font-size: 1.6rem;
        font-weight: bold;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
    }

    .cart-total-price {
        text-align: center;
        padding: 24px;
        background: none;
    }

    .cart-empty-td {
        border-left: none !important;
    }

}

/****************************************
Components / Items
****************************************/

.item-wrapper {
    margin: -8px -8px 0;
}

.item {
    width: 33.333333%;
    float: left;
    position: relative;
}

.item > a {
    display: block;
    padding: 8px !important;
}

.item > a:hover {
    background: rgba(0,0,0,0.05);
}

.popular-items .item > a:hover {
    background: rgba(0,0,0,0.06);
}

.item-image {
    padding: 10px;
    margin-bottom: 11px;
    text-align: center;
    background: #fff;
    box-shadow: 0 7px 23px #e2e2e2;
    display: flex;
    justify-content: center;
    align-items: center;
}

.item-image::before {
    content:"";
    display: block;
    padding-top:100%;
}

.item-imageBox {
    width:100%;
    height:100%;
}

.popular-items .item-image {
    box-shadow: 0 7px 23px #e2d274;
}

.item-image > img {
    max-height: 100%;
    width:100%;
}

.item-name {
    font-size: 12px;
    font-size: 1.2rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    line-height: 1.4;
    color: #000;
    height: 48px;
    overflow: hidden;
    margin: 0 5px 12px;
    -webkit-box-flex:2;
        -ms-flex:2;
            flex:2;
}

.item-price {
    font-size: 15px;
    font-size: 1.5rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: #ff2d3e;
    margin: 0 5px;
    -webkit-box-flex:1px;
        -ms-flex:1px;
            flex:1px;
}

.no-item {
    border-bottom: 1px solid #eee;
}

@media only screen and (max-width: 768px) {
}

@media only screen and (min-width: 768px) {

    .item-wrapper {
        margin: -16px -16px 0;
    }

    .item > a {
        padding: 16px !important;
    }

    .item-image {
        padding: 16px;
        margin-bottom: 18px;
    }

    .item-name {
        font-size: 15px;
        font-size: 1.5rem;
        line-height: 1.5;
        height: 66px;
        margin-bottom: 15px;
    }

    .item-price {
        font-size: 19px;
        font-size: 1.9rem;
    }

}

@media only screen and (min-width: 1024px) {

    .item {
        width: 25%;
    }

    .popular-items .item,
    .feature-items .item {
        width: 16.6666666667%;
    }

    .item-name {
        font-size: 14px;
        font-size: 1.4rem;
        height: 63px;
    }

}



/****************************************
Components / News
****************************************/

.news-area {
    padding: 32px 16px;
}

.newslist {
    border-bottom: 1px solid #eee;
}

.newslist dl {
    border-top: 1px solid #eee;
}

.newslist dt {
    padding: 20px 16px 18px;
    transition: 0.5s ease;
}

.newslist dt:hover {
    background: rgba(0,0,0,0.05);
}

.newslist dt.active {
    background: #ff5c69;
}

.newslist dt .date {
    font-size: 11px;
    font-size: 1.1rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: #ff2d3e;
    margin-bottom: 7px;
    transition: 0.5s ease;
}

.newslist dt.active .date {
    color: #fff;
}

.newslist dt .news_title {
    font-size: 13px;
    font-size: 1.3rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    padding-right: 40px;
    line-height: 1.6;
    transition: 0.5s ease;
}

.newslist dt:hover .news_title {
    text-decoration: none;
}

.newslist dt.active .news_title {
    color: #fff;
}

.accordion-btn {
    position: absolute;
    top: 50%;
    right: 20px;
    width: 26px;
    height: 26px;
    line-height: 26px;
    margin-top: -13px;
    border: 1px solid #dedede;
    border-radius: 50%;
    text-align: center;
    font-size: 16px;
    font-size: 1.6rem;
    transition: 0.3s ease;
    transform: rotate(0);
}

.newslist dt.active .accordion-btn {
    background: #fff;
    color: #ff3c4b;
    border: 1px solid #ff5c69;
    transform: rotate(180deg);
}

.newslist dd {
    margin: 13px 16px 18px;
    font-size: 13px;
    font-size: 1.3rem;
    line-height: 1.8;
}

.newslist dd a {
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-decoration: underline;
    color: #1299c5;
}

.newslist dd a:hover {
    color: #ff404f;
}

@media only screen and (min-width: 768px) {

    .news-area {
        padding: 56px 48px;
    }

    .newslist dt {
        padding: 24px 24px 22px;
    }

    .newslist dt .date {
        float: none;
        width: auto;
        font-size: 12px;
        font-size: 1.2rem;
        margin-bottom: 10px;
    }

    .newslist dt .news_title {
        font-size: 14px;
        font-size: 1.4rem;
        padding-left: 0;
    }

    .newslist dd {
        font-size: 14px;
        font-size: 1.4rem;
        margin: 17px 24px 21px;
    }

}

@media only screen and (min-width: 1024px) {

    .news-area {
        padding: 0;
        width: 42%;
        float: left;
        padding: 0 24px 0 0;
    }

}

/****************************************
Components / Banners
****************************************/

.banners-item {
    margin-top: 8px;
}

.banners-item:first-child {
    margin-top: 0;
}

.banners-item > a {
    display: block;
}

@media only screen and (min-width: 768px) {

    .banners-list {
        margin: -16px -8px 0;
    }

    .banners-item {
        width: 50%;
        padding: 0 8px;
        float: left;
        margin-top: 16px;
    }

    .banners-item:first-child {
        width: 100%;
        margin-top: 16px;
    }

}

/****************************************
Components / Shop Guide
****************************************/

.guide-list {
    margin-bottom: 32px;
}

.guide-item {
    margin-top: 16px;
    background: #fff;
    padding: 32px 16px 28px;
}

.guide-item:first-child {
    margin-top: 0;
}

.guide-title {
    font-size: 15px;
    font-size: 1.5rem;
    font-weight: bold;
    margin-bottom: 15px;
    text-align: center;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    letter-spacing: 1.2px;
}

.guide-content {
    font-size: 12px;
    font-size: 1.2rem;
    line-height: 2;
}

.guide-note-title {
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    margin-bottom: 15px;
    text-align: center;
    letter-spacing: 2px;
}

.guide-note-content {
    font-size: 13px;
    font-size: 1.3rem;
    line-height: 2;
    margin: 0 16px;
}

@media only screen and (min-width: 768px) {

    .guide-list {
        margin-bottom: 48px;
    }

    .guide-item {
        padding: 48px;
        margin-top: 24px;
        display: table;
        table-layout: fixed;
        width: 100%;
    }

    .guide-title {
        display: table-cell;
        width: 130px;
        vertical-align: top;
        padding-top: 7px;
        text-align: center;
        margin-bottom: 0;
        font-size: 16px;
        font-size: 1.6rem;
        letter-spacing: 1.5px;
    }

    .guide-content {
        display: table-cell;
        width: 100%;
        vertical-align: top;
        font-size: 14px;
        font-size: 1.4rem;
        padding-left: 40px;
        line-height: 2.2;
    }

    .guide-note-title {
        font-size: 19px;
        font-size: 1.9rem;
        font-weight: bold;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
        margin-bottom: 24px;
        text-align: center;
        letter-spacing: 3px;
    }

    .guide-note-content {
        font-size: 14px;
        font-size: 1.4rem;
        line-height: 2.2;
        margin: 0 48px;
    }

}

/****************************************
Components / Pagination
****************************************/

.pagination-wrapper {
    margin-top: 8px;
}

.pagination-list {
    text-align: center;
    font-size: 0;
}

.pagination-item {
    display: inline-block;
    padding: 0 2.5px;
}

.pagination-item > a {
    display: block;
    min-width: 40px;
    height: 40px;
    line-height: 38px;
    background: #fff3f4;
    color: #3a3a3a;
    border-radius: 3px;
    font-size: 13px;
    font-size: 1.3rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.pagination-item.active > a {
    background: #ff5c69 !important;
    color: #fff;
}

.pagination-item > a:hover {
    background: #ffd7da;
}

.pagination-item-extend {
    font-size: 15px;
    font-size: 1.5rem;
    position: relative;
    top: -2px;
}

@media only screen and (min-width: 768px) {

    .pagination-wrapper {
        margin-top: 24px;
    }

    .pagination-item {
        padding: 0 4px;
    }

    .pagination-item > a {
        min-width: 45px;
        height: 45px;
        line-height: 45px;
        font-size: 13px;
        font-size: 1.3rem;
    }

}

/****************************************
Components / Message
****************************************/

.msg-default {
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-align: center;
    line-height: 1.6;
    margin-bottom: 16px;
}

.msg-large {
    font-size: 15px;
    font-size: 1.5rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-align: center;
    line-height: 1.6;
    margin-bottom: 16px;
}

.error-page .msg-large {
    margin-bottom: 10px;
}

.msg-border {
    border: 2px solid #5f6e7d;
    padding: 16px;
    color: #384552;
    border-radius: 5px;
}

.msg-small {
    font-size: 13px;
    font-size: 1.3rem;
    line-height: 1.6;
    text-align: center;
    margin-bottom: 16px;
}

.msg-default > a,
.msg-large > a,
.msg-small > a,
.msg-form-error > a {
    text-decoration: underline;
}

.msg-form-error {
    font-size: 12px;
    font-size: 1.2rem;
    line-height: 1.6;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-align: center;
    background: #ffedee;
    line-height: 1.5;
    padding: 10px 12px 10px;
    color: #ff1324;
    margin-bottom: 8px;
}

.msg-form-item {
    font-size: 12px;
    font-size: 1.2rem;
    line-height: 1.6;
    margin-top: 8px;
}

.msg-red {
    color: #ff4957;
}

.msg-left {
    text-align: left;
}

.msg-bold {
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

@media only screen and (min-width: 768px) {

     .msg-default {
         font-size: 16px;
         font-size: 1.6rem;
         margin-bottom: 45px;
     }

     .msg-large {
         font-size: 19px;
         font-size: 1.9rem;
         margin-bottom: 45px;
     }

     .error-page .msg-large {
         margin-bottom: 20px;
     }

     .msg-border {
         font-size: 17px;
         font-size: 1.7rem;
         padding: 21px 24px;
     }

     .msg-small {
         font-size: 15px;
         font-size: 1.5rem;
         line-height: 1.8;
         margin-bottom: 48px;
     }

     .msg-form-error {
         padding: 14px 16px;
     }

     .msg-form-item {
         font-size: 13px;
         font-size: 1.3rem;
         margin-top: 12px;
         line-height: 1.8;
     }

}

/****************************************
Components / Button
****************************************/

.btn-wrapper {
    margin-top: 24px;
}

.previous-btn {
    margin-top: 16px;
}

.btn-wrapper > p:first-child {
    margin-top: 0;
}

.login-form-btn {
    margin-top: 24px;
}

.mypage-customer-btn {
    font-size: 0;
}

.mypage-customer-edit-btn {
    margin-right: 5px;
    display: inline-block;
}

.mypage-customer-delete-btn {
    display: inline-block;
}

.edit-btn {
    text-align: right;
    margin-top: 16px;
}

.shippings-details > .edit-btn {
    text-align: left;
}

.shippings-delete-btn {
    margin-top: 16px;
}

.more-btn {
    width: 190px;
    margin: 16px auto 0;
}

.more-btn > a > i {
    position: absolute;
    top: 0;
    right: 27px;
    font-size: 18px;
    font-size: 1.8rem;
    transition: 0.5s ease;
}

.more-btn > a:hover > i {
    right: 22px;
}

.more-btn > a > i:before {
    font-weight: bold;
}

.btn-red {
    display: block;
    width: 100%;
    height: 50px;
    line-height: 50px;
    text-align: center;
    background: #ff5c69;
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: #fff;
    border: none;
    border-radius: 5px;
    outline: none;
    transition: 0.5s ease;
    position: relative;
    padding: 0;
}

.item-single-sold-out.btn-red {
    background: #ffc1c6 !important;
    color: #ff858f !important;
}

.more-btn > .btn-red {
    border-radius: 21px;
    height: 42px;
    line-height: 42px;
    font-size: 13px;
    font-size: 1.3rem;
}

.btn-red:hover {
    background: #ff2e3e;
    color: #fff;
}

.btn-border-red {
    display: block;
    width: 100%;
    height: 50px;
    line-height: 48px;
    text-align: center;
    background: none;
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: #ff4553;
    border: 1px solid #ff5c69;
    border-radius: 5px;
    outline: none;
    transition: 0.5s ease;
    position: relative;
    padding: 0;
}

.btn-border-red:hover {
    background: #ff5c69;
    color: #fff;
}

.btn-border-red[disabled] {
    background: #ff5c69;
    color: #ffadb3;
}

.btn-grey,
.btn-border-grey {
    display: inline-block;
    min-width: 53px;
    height: 34px;
    line-height: 32px;
    border: 1px solid #e0e0e0;
    color: #2d2d2d;
    font-size: 11px;
    font-size: 1.1rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-align: center;
    padding: 0 11px;
    background: none;
    outline: none;
    border-radius: 3px;
    transition: 0.5s ease;
    position: relative;
}

.btn-grey {
    background: #f1f1f1;
}

.btn-border-grey:hover {
    border: 1px solid #ff4654;
    color: #ff4654;
}

.btn-grey:hover {
    background: #e2e2e2;
    border: 1px solid #e2e2e2;
    color: #2d2d2d;
}

.edit-large-btn > .btn-border-grey {
    width: 100%;
    font-size: 12px;
    font-size: 1.2rem;
    height: 48px;
    line-height: 46px;
    background: #eaeaea;
    border-radius: 3px;
}

.btn-border-grey[disabled] {
    color: #d2d2d2;
    border: 1px solid #e8e8e8;
}

.add-btn .btn-border-grey {
    height: 36px;
    line-height: 34px;
}

.page-top-btn {
    position: fixed;
    bottom: -48px;
    right: 8px;
    display: block;
    width: 40px;
    height: 40px;
    line-height: 40px;
    background: #fff;
    text-align: center;
    border-radius: 50%;
    box-shadow: 0 10px 30px rgba(0,0,0,0.15);
    font-size: 20px;
    font-size: 2rem;
    transition: bottom 0.5s ease;
    cursor: pointer;
}

.page-top-btn.stikcy {
    bottom: 8px;
}

.page-top-btn:hover {
    color: #ff5c69;
}

.page-top-btn > i:before {
    position: relative;
    top: 0;
    transition: 0.5s ease;
}

.page-top-btn:hover > i:before {
    top: -3px;
}

@media only screen and (min-width: 768px) {

    .btn-wrapper {
        margin: 32px -8px 0;
        font-size: 0;
        text-align: center;
    }

    .edit-btn {
        margin-top: 24px;
    }

    .more-btn {
        width: 230px;
        margin: 24px auto 0;
    }

    .more-btn > a > i {
        font-size: 20px;
        font-size: 2rem;
    }

    .previous-btn {
        display: inline-block;
        width: 50%;
        padding: 0 8px;
        margin-top: 0;
    }

    .next-btn {
        display: inline-block;
        width: 50%;
        margin-bottom: 0;
        padding: 0 8px;
    }

    .order-sub .next-btn,
    .order-sub .previous-btn {
        width: 100%;
    }

    .order-sub .previous-btn {
        margin-top: 16px;
    }

    .login-form-btn {
        margin-top: 32px;
    }

    .mypage-customer-btn {
        top: 24px;
        right: 24px;
    }

    .mypage-customer-edit-btn {
        margin-right: 8px;
    }

    .btn-red {
        font-size: 15px;
        font-size: 1.5rem;
        height: 53px;
        line-height: 53px;
    }

    .more-btn > .btn-red {
        border-radius: 24px;
        height: 48px;
        line-height: 48px;
        font-size: 14px;
        font-size: 1.4rem;
    }

    .btn-border-red {
        font-size: 15px;
        font-size: 1.5rem;
        height: 53px;
        line-height: 51px;
    }

    .btn-border-grey {
        font-size: 12px;
        font-size: 1.2rem;
        min-width: 60px;
        height: 36px;
        line-height: 34px;
    }

    .add-btn .btn-border-grey {
        height: 38px;
        line-height: 36px;
    }

    .page-top-btn {
        bottom: -72px;
        right: 24px;
        width: 53px;
        height: 53px;
        line-height: 53px;
        font-size: 27px;
        font-size: 2.7rem;
    }

    .page-top-btn.stikcy {
        bottom: 24px;
    }

}

/****************************************
Components / Button
****************************************/

.favorite-delete-btn {
    position: absolute;
    top: -1px;
    right: -1px;
}

.favorite-delete-btn > a {
    display: block;
    width: 25px;
    height: 25px;
    line-height: 25px;
    text-align: center;
    background: #ffffff;
    border-radius: 50%;
    font-size: 20px;
    font-size: 2rem;
    box-shadow: 0 7px 20px rgba(0,0,0,0.2);
}

.favorite-delete-btn > a:hover {
    color: #fff;
    background: #ff5c69;
}

@media only screen and (min-width: 768px) {

    .favorite-delete-btn {
        top: 1px;
        right: 1px;
    }

    .favorite-delete-btn > a {
        width: 35px;
        height: 35px;
        line-height: 35px;
        font-size: 25px;
        font-size: 2.5rem;
    }

}

/****************************************
Components / Overlay
****************************************/

.overlay {
    background: rgba(0,0,0, 0.65);
}

.prevention-masked {
    opacity: 1;
    background: rgba(0,0,0,0.6);
}

/****************************************
Components / Copy
****************************************/

@media only screen and (min-width: 1024px) {

    .header .copy  {
        font-size: 11px;
        font-size: 1.1rem;
        color: #fff;
        padding: 0 0 0 20px;
    }

}

/****************************************
Components / Cart Button
****************************************/

.header-cart {
    position: absolute;
    top: 19px;
    right: 83px;
    z-index: 10;
}

.header-cart > a {
    display: block;
    position: relative;
}

.header-cart > a:before {
    content: "";
    background: url(../img/common/icon-cart.png);
    background-size: 20px;
    background-position: center;
    background-repeat: no-repeat;
    display: inline-block;
    width: 20px;
    height: 20px;
}

.header-cart-quantity {
    display: block;
    min-width: 20px;
    height: 20px;
    line-height: 16px;
    background: #ff5c69;
    color: #fff;
    font-size: 10px;
    font-size: 1rem;
    border-radius: 50%;
    text-align: center;
    position: absolute;
    top: -11px;
    left: 12px;
    border: 2px solid #fff;
}

.header-cart-icon {
    font-size: 26px;
    font-size: 2.6rem;
}

.header-cart-count {
    position: absolute;
    top: 8px;
    left: 14px;
    background: #f22727;
    width: 18px;
    height: 18px;
    line-height: 18px;
    display: block;
    font-size: 10px;
    font-size: 1rem;
    border-radius: 50%;
    color: #fff;
    text-align: center;
}

.header-cart-price {
    display: none;
}

@media only screen and (min-width: 768px) {

    .header-cart {
        top: 36px;
        right: 136px;
    }

    .header-cart > a:before {
        background-size: 24px;
        width: 24px;
        height: 24px;
        vertical-align: middle;
    }

    .header-cart-quantity {
        min-width: 22px;
        height: 22px;
        line-height: 18px;
        font-size: 11px;
        font-size: 1.1rem;
        top: -14px;
        left: 14px;
    }

    .header-cart-price {
        display: inline-block;
        font-size: 13px;
        font-size: 1.3rem;
        font-weight: bold;
        -webkit-font-smoothing: antialiased;
        position: relative;
        vertical-align: middle;
        color: #2d2d2d;
        margin-left: 24px;
        top: -2px;
    }

    .header-cart-price > span {
        font-size: 20px;
        font-size: 2rem;
        margin-left: 6px;
        position: relative;
        top: 1px;
    }

}

@media only screen and (min-width: 1024px) {

    .header-cart {
        top: 40px;
        right: 0;
    }

    .header-cart > a {
        padding: 12px 20px;
    }

    .header-cart > a:hover {
        background: #ececec;
    }

    .header-cart-quantity {
        top: 1px;
        left: 35px;
    }

}

/****************************************
Components / Cart Status
****************************************/

.cart-status {
    margin-bottom: 24px;
}

.cart-status-list {
    margin: 0 -4px;
}

.cart-status-item {
    width: 33.333333%;
    float: left;
    padding: 0 4px;
}

.cart-status-item > span {
    display: block;
    font-size: 12px;
    font-size: 1.2rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    padding: 16px;
    color: #929292;
    text-align: center;
}

.cart-status-item.active > span {
    background: #505050;
    color: #fff;
}

.cart-status-number {
    display: block;
    width: 40px;
    height: 40px;
    line-height: 40px;
    border-radius: 50%;
    font-size: 12px;
    font-size: 1.2rem;
    vertical-align: middle;
    margin: 0 auto 13px;
    background: #fff;
}

.cart-status-item.active > .cart-status-number {
    background: #ff5c69;
    color: #fff;
}

@media only screen and (min-width: 768px) {

    .cart-status {
        margin-bottom: 48px;
    }

    .cart-status-list {
        margin: 0 -16px;
    }

    .cart-status-item {
        padding: 0 16px;
    }

    .cart-status-item > span {
        font-size: 14px;
        font-size: 1.4rem;
        padding: 19px 24px;
    }

}

/****************************************
Components / Login
****************************************/

.login-item {
    margin-top: 24px;
}

.login-item:first-child {
    margin-top: 0;
    border-bottom: 1px solid #eee;
    padding-bottom: 24px;
}

.login-item-title {
    text-align: center;
    margin-bottom: 24px;
}

.login-item-title > span {
    display: inline-block;
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    padding-bottom: 16px;
    border-bottom: 2px solid #ff5c69;
    color: #ff4251;
}

.login-form-item {
    margin: 16px 0;
}

.login-form-item > input {
    width: 100%;
    line-height: 1;
    border: 1px solid #f0f2f5;
    background: #f3f5f7;
    height: 40px;
    padding: 0 13px;
}

.login-form-item > input:focus {
    background: #fff;
}

.login-form-item > label {
    font-size: 13px;
    font-size: 1.3rem;
    margin-bottom: 8px;
    display: block;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.login-form-item > span.required {
    display: none;
}

.login-form-item > .checkbox {
    font-size: 12px;
    font-size: 1.2rem;
    margin-top: 10px;
}

.login-form-item > .checkbox > label > input {
    position: relative;
    top: 2px;
    margin-right: 3px;
}

.login-form-menu-list {
    margin-top: 16px;
}

.login-form-menu-item {
    margin-top: 12px;
}

.login-form-menu-item > a {
    display: block;
    font-size: 12px;
    font-size: 1.2rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: #1299c5;
}

.login-form-menu-item > a:hover {
    color: #ff404f;
}

@media only screen and (min-width: 768px) {

    .login-item {
        margin-top: 40px;
    }

    .login-item:first-child {
        padding-bottom: 40px;
    }

    .login-item-title {
        margin-bottom: 40px;
    }

    .login-item-title > span {
        font-size: 16px;
        font-size: 1.6rem;
        padding-bottom: 20px;
    }

    .login-form-item {
        margin: 24px 0;
    }

    .login-form-item > input {
        height: 43px;
        padding: 0 16px;
    }

    .login-form-item > label {
        font-size: 14px;
        font-size: 1.4rem;
        margin-bottom: 16px;
    }

    .login-form-item > .checkbox {
        font-size: 13px;
        font-size: 1.3rem;
        margin-top: 16px;
    }

    .login-form-menu-list {
        margin-top: 24px;
    }

    .login-form-menu-item {
        margin-top: 16px;
    }

    .login-form-menu-item > a {
        font-size: 13px;
        font-size: 1.3rem;
    }

}

@media only screen and (min-width: 1024px) {

    .login-item {
        margin-top: 0;
        width: 50%;
        float: left;
        padding-left: 48px;
    }

    .forgot-page .login-item {
        width: 100%;
        float: none;
        padding-left: 0;
    }

    .login-item:first-child {
        border-right: 1px solid #eee;
        border-bottom: none;
        padding: 0 48px 0 0;
    }

    .forgot-page .login-item:first-child {
        border-right: none;
        padding: 0;
    }

    .login-form-item > .checkbox > label > input {
        top: 0px;
    }

}

/****************************************
Components / Drawer
****************************************/

.drawer-nav {
    width: 260px;
    z-index: 3;
    box-shadow: -2px 0 8px rgba(0,0,0,0.25);
    background: #f7f7f7;
}

.drawer--right .drawer-nav {
    right: -285px;
}

.drawer-hamburger {
    width: 24px;
    height: 56px;
    top: 0;
    padding: 0 16px;
    background: #ff5c69;
}

.drawer-hamburger:hover {
    background: #ff5c69;
}

.drawer--right.drawer-open .drawer-hamburger {
    right: 260px;
}

.drawer-hamburger-icon,
.drawer-hamburger-icon:after,
.drawer-hamburger-icon:before {
    background: #ffdcdf;
}

.drawer-hamburger-icon {
    margin-top: 0;
}

.drawer-hamburger-icon:after,
.drawer-hamburger-icon:before {
    top: -7px;
}

.drawer-hamburger-icon:after {
    top: 7px;
}

.drawer-title {
    padding: 16px;
    font-size: 12px;
    font-size: 1.2rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    border-bottom: 1px solid #eee;
    color: #505050;
}

.drawer-overlay {
    background-color: rgba(0,0,0,0.6);
    z-index: 2;
}

@media only screen and (min-width: 768px) {

    .drawer-nav {
        width: 300px;
        z-index: 3;
        box-shadow: -2px 0 8px rgba(0,0,0,0.25);
        background: #f7f7f7;
    }

    .drawer--right .drawer-nav {
        right: -325px;
    }

    .drawer--right.drawer-open .drawer-hamburger {
        right: 300px;
    }

    .drawer-hamburger {
        width: 32px;
        height: 96px;
        top: 0;
        padding: 0 32px;
    }

    .drawer-hamburger-icon:after,
    .drawer-hamburger-icon:before {
        top: -8px;
    }

    .drawer-hamburger-icon:after {
        top: 8px;
    }

    .drawer-title {
        padding: 17px 20px;
        font-size: 13px;
        font-size: 1.3rem;
    }

}

@media only screen and (min-width: 1024px) {

    .drawer-hamburger,
    .drawer-nav {
        display: none;
    }

}

/****************************************
Components / SNS
****************************************/

.footer-sns-list {
    font-size: 0;
    text-align: center;
    margin-bottom: 40px;
}

.footer-sns-item {
    display: inline-block;
    margin: 0 12px;
}

.footer-sns-item > a {
    display: inline-block;
    width: 46px;
    height: 46px;
    line-height: 46px;
    border-radius: 50%;
    color: #fff;
    vertical-align: top;
    text-align: center;
    overflow: hidden;
    position: relative;
    top: 0;
    transition: 0.3s ease;
}

.footer-sns-item > a:hover {
    top: -3px;
}

.btn-twitter {
    background: #55acee;
    font-size: 20px;
    font-size: 2rem;
}

.btn-facebook {
    background: #3B5998;
    font-size: 24px;
    font-size: 2.4rem;
}

.btn-facebook > i {
    position: relative;
    top: -1px;
}

.btn-line {
    background: #00b833;
}

.btn-line > img {
    width: 30px;
}

@media only screen and (min-width: 768px) {

    .footer-sns-list {
        margin-bottom: 48px;
    }

    .footer-sns-item > a {
        width: 48px;
        height: 48px;
        line-height: 48px;
    }

}

@media only screen and (min-width: 1024px) {

    .footer-sns-list {
        text-align: right;
    }

    .footer-sns-item {
        margin: 0 0 0 24px;
    }

}

/****************************************
Components / Mypage Menu
****************************************/

.mypage-menu {
    margin-bottom: 24px;
}

.mypage-menu-item {
    width: 20%;
    float: left;
}

.mypage-menu-item > a {
    font-size: 11px;
    font-size: 1.1rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    display: block;
    text-align: center;
    padding-bottom: 16px;
    color: #999;
}

.mypage-menu-item > a:hover {
    color: #ff4654;
}

.mypage-menu-item.active > a {
    color: #ff3030;
    border-bottom: 2px solid #ff5c69;
}

@media only screen and (min-width: 768px) {

    .mypage-menu {
        margin-bottom: 48px;
    }

    .mypage-menu-item > a {
        font-size: 14px;
        font-size: 1.4rem;
        padding-bottom: 24px;
    }

}

@media only screen and (min-width: 1024px) {

    .mypage-menu {
        margin-bottom: 64px;
    }

    .mypage-menu-item > a {
        padding-bottom: 30px;
    }

}

/****************************************
Components / Order
****************************************/

.order-wrapper {
    border-top: 1px solid #eee;
    margin-top: 32px;
}

.order-wrapper:first-child {
    margin-top: 0;
}

.order-main-row,
.order-sub-row {
    margin-top: 32px;
}

.order-main-row:first-child {
    margin-top: 0;
}

.order-main-row-title,
.order-sub-row-title {
    font-size: 13px;
    font-size: 1.3rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    background: #edeff1;
    padding: 14px 16px;
}

.order-main-row-contents {
    padding: 16px 16px 0;
    font-size: 13px;
    font-size: 1.3rem;
    line-height: 1.6;
}

.order-main-row-item {
    margin-top: 8px;
}

.order-main-row-item:first-child {
    margin-top: 0;
}

.order-main-row-item .radio {
    font-size: 13px;
    font-size: 1.3rem;
}

.order-main-row-item .radio input {
    margin-right: 8px;
    position: relative;
    top: 2px;
}

@media only screen and (min-width: 768px) {

    .order-wrapper {
        margin-top: 48px;
    }

    .order-main-row,
    .order-sub-row {
        margin-top: 40px;
    }

    .order-sub-row:first-child {
        margin-top: 0;
    }

    .order-main-row-title,
    .order-sub-row-title {
        font-size: 15px;
        font-size: 1.5rem;
        padding: 18px 24px;
    }

    .order-main-row-contents {
        padding: 24px 24px 0;
        font-size: 14px;
        font-size: 1.4rem;
        line-height: 1.8;
    }

    .order-main-row-item .radio {
        font-size: 14px;
        font-size: 1.4rem;
    }

}

@media only screen and (min-width: 1024px) {

    .order-wrapper {
        border-top: none;
    }

    .order-main-row-item .radio input {
        top: 0;
    }

}

/********************************
Components / Order / Items
********************************/

.order-item {
    border-bottom: 1px solid #eee;
}

.order-item > a {
    display: table;
    table-layout: fixed;
    width: 100%;
    padding: 16px;
}

.order-item > a:hover {
    background: rgba(0,0,0,0.02);
    color: #2d2d2d;
}

.order-item-thumb {
    display: table-cell;
    width: 106px;
    vertical-align: top;
    padding-right: 16px;
}

.order-item-thumb > img {
    box-shadow: 0 7px 23px #e2e2e2;
}

.order-item-text {
    vertical-align: middle;
    display: table-cell;
}

.order-item-name {
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    margin-bottom: 8px;
    line-height: 1.5;
}

.order-item-name > span {
    display: block;
    font-size: 12px;
    font-size: 1.2rem;
    color: #999;
    margin-top: 3px;
}

.order-item-price {
    font-size: 13px;
    font-size: 1.3rem;
}

@media only screen and (min-width: 768px) {

    .order-item > a {
        padding: 24px;
    }

    .order-item-thumb {
        width: 124px;
        padding-right: 24px;
    }

    .order-item-name {
        font-size: 16px;
        font-size: 1.6rem;
        margin-bottom: 13px;
    }

    .order-item-name > span {
        font-size: 13px;
        font-size: 1.3rem;
        margin-top: 8px;
    }

    .order-item-price {
        font-size: 15px;
        font-size: 1.5rem;
    }

}

/********************************
Components / Order / Customer
********************************/

.customer-details {
    font-size: 13px;
    font-size: 1.3rem;
    line-height: 1.3;
}

.shippings-radio-wrapper .customer-details {
    display: inline-block;
    vertical-align: middle;
}

.customer-details.edit .icon-hyphen {
    font-size: 17px;
    font-size: 1.7rem;
}

.customer-details.edit .customer-name01,
.customer-details.edit .customer-name02 {
    display: inline-block;
    width: 50%;
}

.customer-details.edit .customer-name01 {
    padding-right: 8px;
}

.customer-details.edit .customer-zip01 {
    width: 17%;
    display: inline-block;
    margin: 0 6px 0 8px;
}

.customer-details.edit .customer-zip02 {
    width: 20%;
    display: inline-block;
    margin-left: 6px;
}

.customer-details.edit .customer-tel01,
.customer-details.edit .customer-tel02,
.customer-details.edit .customer-tel03 {
    width: 19%;
    display: inline-block;
}

.customer-details.edit .customer-tel01 {
    margin-right: 6px;
}

.customer-details.edit .customer-tel02 {
    margin: 0 6px;
}

.customer-details.edit .customer-tel03 {
    margin-left: 6px;
}

.customer-address,
.customer-tel,
.customer-email {
    margin-top: 6px;
}

.customer-details.edit .customer-address,
.customer-details.edit .customer-tel,
.customer-details.edit .customer-email {
    margin-top: 16px;
}

.customer-details.edit .customer-pref,
.customer-details.edit .customer-addr01,
.customer-details.edit .customer-addr02 {
    display: block;
    margin-top: 8px;
}

.mod-button {
    font-size: 0;
    text-align: left;
    margin-top: 16px;
}

#customer-ok {
    display: inline-block;
    margin-right: 5px;
}

#customer-cancel {
    display: inline-block;
}

@media only screen and (min-width: 768px) {

    .customer-details {
        font-size: 14px;
        font-size: 1.4rem;
    }

    .page-delivery .customer-details {
        font-size: 15px;
        font-size: 1.5rem;
    }

    .customer-details.edit .icon-hyphen {
        font-size: 19px;
        font-size: 1.9rem;
    }

    .customer-details.edit .customer-name01 {
        padding-right: 12px;
    }

    .customer-details.edit .customer-zip01 {
        margin: 0 9px 0 16px;
    }

    .customer-details.edit .customer-zip02 {
        margin-left: 9px;
    }

    .customer-details.edit .customer-tel01 {
        margin-right: 9px;
    }

    .customer-details.edit .customer-tel02 {
        margin: 0 9px;
    }

    .customer-details.edit .customer-tel03 {
        margin-left: 9px;
    }

    .customer-details.edit .customer-address,
    .customer-details.edit .customer-tel,
    .customer-details.edit .customer-email {
        margin-top: 24px;
    }

    .customer-details.edit .customer-pref,
    .customer-details.edit .customer-addr01,
    .customer-details.edit .customer-addr02 {
        margin-top: 12px;
    }

    .mod-button {
        margin-top: 24px;
    }

    #customer-ok {
        margin-right: 5px;
    }

    .customer-address,
    .customer-tel,
    .customer-email {
        margin-top: 8px;
    }

}

/********************************
Components / Order / Shippings
********************************/

.mypage-wrapper .shippings-list {
    border-top: 1px solid #eee;
}

.shippings-item {
    border-bottom: 1px solid #eee;
    margin-top: 32px;
}

.shippings-item:first-child {
    margin-top: 16px;
}

.page-delivery .shippings-item {
    margin-top: 0;
}

.page-delivery .shippings-item:first-child {
    margin-top: 0;
}

.page-multiple .shippings-item {
    border-top: 1px solid #eee;
}

.shippings-item-title {
    font-size: 13px;
    font-size: 1.3rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    padding: 0 16px 16px;
    border-bottom: 1px solid #eee;
}

.shippings-details {
    padding: 16px;
}

.shipping_item {
    margin-top: 24px;
}

.shipping_item:first-child {
    margin-top: 0;
}

.shippings-radio {
    display: inline-block;
    vertical-align: middle;
    margin-right: 16px;
}

.shippings-delivery {
    margin-top: 20px;
}

.shippings-delivery-row {
    margin-top: 16px;
}

.page-multiple .shippings-delivery-row:first-child {
    margin-top: 0;
}

.shippings-delivery-row label,
.shippings-delivery-row-title {
    display: block;
    font-size: 12px;
    font-size: 1.2rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    margin-bottom: 8px;
}

.shippings-delivery-row-contents {
    font-size: 13px;
    font-size: 1.3rem;
}

@media only screen and (min-width: 768px) {

    .shippings-item {
        border-bottom: 1px solid #eee;
        margin-top: 40px;
    }

    .shippings-item:first-child {
        margin-top: 18px;
    }

    .shippings-item-title {
        font-size: 15px;
        font-size: 1.5rem;
        padding: 0 24px 18px;
    }

    .shippings-details {
        padding: 24px;
    }

    .shippings-radio {
        margin-right: 24px;
    }

    .shippings-delivery {
        margin-top: 24px;
    }

    .shippings-delivery-row label,
    .shippings-delivery-row-title {
        font-size: 13px;
        font-size: 1.3rem;
    }

    .shippings-delivery-row-contents {
        font-size: 14px;
        font-size: 1.4rem;
        margin-top: 10px;
    }

}

/********************************
Components / Order / Contact
********************************/

.order-contact-item {
    border-bottom: 1px solid #eee;
    transition: 0.5s ease;
}

.order-contact-header:hover,
.order-contact-header.active {
    background: rgba(0,0,0,0.02);
}

.order-contact-header {
    position: relative;
    padding: 20px 16px 18px;
    cursor: pointer;
    transition: 0.5s ease;
}

.order-contact-date {
    font-size: 12px;
    font-size: 1.2rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: #9a9a9a;
    margin-bottom: 7px;
}

.order-contact-title {
    font-size: 13px;
    font-size: 1.3rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    padding-right: 40px;
    line-height: 1.6;
}

.order-contact-btn {
    position: absolute;
    top: 50%;
    right: 16px;
    width: 26px;
    height: 26px;
    line-height: 26px;
    margin-top: -13px;
    border: 1px solid #dedede;
    border-radius: 50%;
    text-align: center;
    font-size: 16px;
    font-size: 1.6rem;
    transition: 0.3s ease;
    transform: rotate(0);
}

.order-contact-header.active > .order-contact-btn {
    transform: rotate(180deg);
}

.order-contact-contents {
    display: none;
    word-wrap: break-word;
    word-break: break-all;
    font-size: 13px;
    font-size: 1.3rem;
    line-height: 1.6;
    border-top: 1px solid #eee;
    padding: 20px 16px 18px;
}

@media only screen and (min-width: 768px) {

    .order-contact-header {
        padding: 24px 24px 22px;
    }

    .order-contact-date {
        font-size: 13px;
        font-size: 1.3rem;
        margin-bottom: 10px;
    }

    .order-contact-title {
        font-size: 14px;
        font-size: 1.4rem;
    }

    .order-contact-contents {
        padding: 24px 24px 22px;
        font-size: 14px;
        font-size: 1.4rem;
    }

}

/********************************
Components / Order / Table
********************************/

.order-table {
    display: table;
    table-layout: fixed;
    width: 100%;
}

.order-table-tr {
    display: table-row;
}

.table-total .order-table-tr:last-child {
    background: #f6f7f9;
}

.order-table-th,
.order-table-td {
    display: table-cell;
    padding: 20px;
}

.order-table-th {
    width: 40%;
    border-bottom: 1px solid #e6e6e6;
    font-size: 12px;
    font-size: 1.2rem;
}

.table-total .order-table-tr:last-child .order-table-th {
    font-size: 13px;
    font-size: 1.3rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.order-table-td {
    width: 60%;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    border-bottom: 1px solid #eee;
    text-align: right;
    font-size: 13px;
    font-size: 1.3rem;
}

.table-total .order-table-tr:last-child .order-table-td {
    font-size: 15px;
    font-size: 1.5rem;
}

@media only screen and (min-width: 768px) {

    .order-table-th,
    .order-table-td {
        padding: 24px;
    }

    .order-table-th {
        font-size: 13px;
        font-size: 1.3rem;
    }

    .order-table-td {
        font-size: 14px;
        font-size: 1.4rem;
    }

    .table-total .order-table-tr:last-child .order-table-th {
        font-size: 14px;
        font-size: 1.4rem;
    }

    .table-total .order-table-tr:last-child .order-table-td {
        font-size: 16px;
        font-size: 1.6rem;
    }

}

/****************************************
Components / Single
****************************************/

.item-single-detail-inner {
    background: #fff;
    padding: 24px 16px 32px;
}

.item-single-tag-list {
    margin-bottom: 18px;
}

.item-single-tag-item {
    float: left;
    margin-right: 7px;
    background: #fbd22a;
    padding: 9px 10px;
    font-size: 11px;
    font-size: 1.1rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: #312800;
    border-radius: 3px;
}

.item-single-name {
    font-size: 18px;
    font-size: 1.8rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    line-height: 1.5;
    margin-bottom: 14px;
}

.item-single-price {
    font-size: 17px;
    font-size: 1.7rem;
    font-weight: bold;
    color: #f22727;
    padding-bottom: 16px;
    border-bottom: 1px solid #eee;
    margin-bottom: 14px;
}

.item-single-description {
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.6;
    margin-bottom: 20px;
}

.item-single-info-row {
    display: table;
    table-layout: fixed;
    width: 100%;
    margin-bottom: 16px;
}

.item-single-info-row-title {
    display: table-cell;
    width: 120px;
    vertical-align: top;
    font-size: 12px;
    font-size: 1.2rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.item-single-info-row-title.select {
    padding-top: 5px;
}

.item-single-info-row-title > label {
    font-weight: bold;
    position: relative;
    top: 3px;
}

.item-single-info-row-contents {
    display: table-cell;
    width: 100%;
    vertical-align: top;
}

.item-single-product-code {
    font-size: 12px;
    font-size: 1.2rem;
}

.item-single-category-list {
    margin-top: 9px;
}

.item-single-category-list:first-child {
    margin-top: -3px;
}

.item-single-category-item {
    float: left;
}

.item-single-category-item > a {
    display: block;
    font-size: 12px;
    font-size: 1.2rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    position: relative;
    text-decoration: underline;
    line-height: 1.5;
    color: #1299c5;
}

.item-single-category-item > a:hover {
    color: #ff404f;
}

.item-single-category-item > a:after {
    content: "\f3d3";
    display: inline-block;
    font-family: "Ionicons";
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    text-rendering: auto;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    margin: 0 5px;
    position: relative;
    top: 1px;
}

.item-single-category-item:last-child > a:after {
    content: "";
}

.item-single-quantity.form-control {
    width: 80px;
}

.item-single-add-cart-btn,
.item-single-sold-out {
    margin: 24px 0 16px;
}

.item-single-freearea {
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.6;
    margin-top: 18px;
}

@media only screen and (min-width: 768px) {

    .item-single-detail-inner {
        padding: 0;
    }

    .item-single-tag-list {
        margin-bottom: 27px;
    }

    .item-single-tag-item {
        padding: 10px 11px;
        font-size: 12px;
        font-size: 1.2rem;
    }

    .item-single-name {
        font-size: 22px;
        font-size: 2.2rem;
        margin-bottom: 18px;
        line-height: 1.6;
    }

    .item-single-price {
        font-size: 21px;
        font-size: 2.1rem;
        padding-bottom: 24px;
        margin-bottom: 22px;
        margin-top: 15px;
    }

    .item-single-description {
        line-height: 1.8;
        margin-bottom: 35px;
    }

    .item-single-info-row {
        margin-bottom: 24px;
    }

    .item-single-info-row-title {
        font-size: 13px;
        font-size: 1.3rem;
    }

    .item-single-product-code {
        font-size: 13px;
        font-size: 1.3rem;
    }

    .item-single-category-list {
        margin-top: 11px;
    }

    .item-single-category-item > a {
        font-size: 13px;
        font-size: 1.3rem;
    }

    .item-single-freearea {
        line-height: 1.8;
        margin-top: 35px;
    }

    .item-single-add-cart-btn,
    .item-single-sold-out {
        margin: 40px 0 16px;
    }

}

/****************************************
Components / Help
****************************************/

.help-wrapper {
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.8;
}

.help-wrapper p {
    margin-bottom: 8px;
}

.sub-guide .help-wrapper p {
    margin: 0 16px 8px;
}

.help-wrapper *:last-child {
    margin-bottom: 0 !important;
}

.help-wrapper-title {
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    margin: 13px 0 7px;
}

.sub-guide-section {
    margin-top: 24px;
}

.sub-guide-section:first {
    margin-top: 0;
}

.sub-guide-section-title {
    font-size: 13px;
    font-size: 1.3rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    padding: 12px 16px;
    text-align: left;
    display: block;
    background: #eaeef3;
    background: #edeff1;
    margin-bottom: 16px;
}

@media only screen and (min-width: 768px) {

    .help-wrapper {
        font-size: 15px;
        font-size: 1.5rem;
    }

    .help-wrapper > p {
        margin-bottom: 16px;
    }

    .sub-guide .help-wrapper p {
        margin: 0 24px 16px;
    }

    .sub-guide-section {
        margin-top: 32px;
    }

    .help-wrapper-title {
        font-size: 18px;
        font-size: 1.8rem;
        margin: 24px 0 16px;
    }

    .sub-guide-section-title {
        font-size: 15px;
        font-size: 1.5rem;
        padding: 14px 24px;
        margin-bottom: 24px;
    }

}

/****************************************
Components / Item List Page
****************************************/

.result-and-settings {
    text-align: center;
    font-size: 0;
}

.result-settings-item > label {
    font-size: 11px;
    font-size: 1.1rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    margin-right: 5px;
}

.result-settings-list {
    background: #f7f7f7;
    padding: 16px 8px;
    margin: -24px -16px 24px;
}

.result-settings-item {
    display: inline-block;
    margin: 0 8px;
}

.result-count {
    font-size: 15px;
    font-size: 1.5rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    margin-bottom: 24px;
}

.result-count > span {
    font-size: 12px;
    font-size: 1.2rem;
    margin-left: 5px;
}

@media only screen and (min-width: 768px) {

    .result-and-settings {
        margin: -48px -48px 48px;
        padding: 24px 48px;
        background: #f7f7f7;
    }

    .result-settings-list {
        background: none;
        padding: 0;
        margin: 0;
        display: inline-block;
        vertical-align: middle;
    }

    .result-settings-item {
        margin: 0 12px;
    }

    .result-settings-item > label {
        font-size: 12px;
        font-size: 1.2rem;
        margin-right: 12px;
    }

    .result-count {
        display: inline-block;
        vertical-align: middle;
        margin-bottom: 0;
        margin: 0 20px;
        font-size: 20px;
        font-size: 2rem;
    }

    .result-count > span {
        font-size: 15px;
        font-size: 1.5rem;
    }

}

@media only screen and (min-width: 1024px) {

    .result-and-settings {
        margin: 0 0 40px 0;
        padding: 24px;
    }

}

/****************************************
Components / Copyright
****************************************/

.copyright {
    font-size: 11px;
    font-size: 1.1rem;
    text-align: center;
    color: #c1c1c1;
}

/****************************************
Components / Footer Menu
****************************************/

.footer-menu-list {
    font-size: 0;
    margin-bottom: 16px;
    text-align: center;
}

.footer-menu-item {
    margin: 0 9px 20px;
    display: inline-block;
}

.footer-menu-item > a {
    font-size: 12px;
    font-size: 1.2rem;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    display: block;
    color: #676767;
    position: relative;
}

.footer-menu-item > a:hover {
    color: #ff4654;
}

.footer-menu-item > a:before {
    content: "\f362";
    display: inline-block;
    font-family: "Ionicons";
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    text-rendering: auto;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 16px;
    font-size: 1.6rem;
    color: #cacaca;
    position: relative;
    top: 1px;
    margin-right: 7px;
    transition: 0.5s ease;
}

.footer-menu-item > a:hover:before {
    color: #ff4654;
}

@media only screen and (min-width: 768px) {

    .footer-menu-list {
        margin: 0 -12px 20px;
    }

}

@media only screen and (min-width: 1024px) {

    .footer-menu-list {
        text-align: left;
        margin: 0;
    }

    .footer-menu-item {
        margin: 0 24px 14px 0;
    }

}

/****************************************
Components / Footer Info
****************************************/

.footer-info {
    margin-bottom: 36px;
}

.footer-description {
    font-size: 12px;
    font-size: 1.2rem;
    line-height: 2;
}

@media only screen and (min-width: 768px) {

    .footer-info {
        margin-bottom: 40px;
    }

    .footer-description {
        font-size: 13px;
        font-size: 1.3rem;
        line-height: 2.2;
    }

}

@media only screen and (min-width: 1024px) {

    .footer-info {
        margin-bottom: 48px;
    }

}

/****************************************
Components / Error Page
****************************************/

.error-page-contents {
    padding: 32px;
    background: #fff;
    margin: 0 16px;
    position: relative;
    top: 50%;
    transform: translateY(-50%);
}

@media only screen and (min-width: 768px) {

    .error-page-contents {
        padding: 64px;
        margin: 0 48px;
    }

}

@media only screen and (min-width: 1024px) {

    .error-page-contents {
        width: 678px;
        margin: 0 auto;
    }

}

/************************************************
Helpers
************************************************/

.bb0 {
    border-bottom: 0;
}

.bt1 {
    border-top: 1px solid #eee;
}

@media only screen and (min-width: 768px) {

    .sp-hide {
        display: none;
    }

}

/************************************************
商品詳細カルーセル
************************************************/
button.slick-prev {
    transform: rotate(180deg);
    position: absolute;
    left: 0;
    top: 45%;
    border: none;
    color:#cccccc;
    background: none;
    margin: 0 0 0 10px;
    padding: 1px 1px 1px 0;
    font-size: 3.5rem;
    line-height:0;
    background: white;
    border-radius: 10%;
    opacity: 80%;
}

button.slick-next {
    position: absolute;
    right: 0;
    top: 45%;
    border: none;
    color:#cccccc;
    background: none;
    margin: 0 10px 0 0;
    padding: 1px 0 1px 1px;
    font-size: 3.5rem;
    line-height:0;
    background: white;
    border-radius: 10%;
    opacity: 80%;
}

button.slick-prev:focus, button.slick-next:focus {
    outline: 0;
}

@media only screen and (min-width: 768px) {
    button.slick-prev, button.slick-next {
        top: 35%;
    }
}
