﻿@charset "UTF-8";

/* -------------------- cart -------------------- */
.block-cart{
    margin: 50px 0 110px;
}
.block-login {
    position: relative;
    margin: 0 auto 130px;
    width: 100%;
}
.block-login h2 {
    margin: 0 0 20px;
}
.block-login--body {
    width: 900px;
    margin: 0 auto;
}
.block-order-flow--step-current {
    background: #141414;
}
.block-order-flow--step-current:after {
    border-left: 25px solid #141414;
}
.block-cart--infomation {
    border: 1px solid #e7e7e7;
}
.block-order-flow--step {
    padding: 0 0 20px;
    margin-bottom: 52px;
}
.block-cart--procedure {
    border: none;
}
.block-cart--procedure-container {
    background: #f4f4f4;
}
.block-promotion-message--content {
    margin: 0 0 42px 0;
}
.block-cart--goods-list-item-price.price {
    color: #141414;
    font-family: Avenir Next;
    font-weight: 600;
}
.block-cart--goods-list-item-price.price:after {
    content: '円（税込）';
    font-size: 10px;
}
.block-cart--subtotal-price.price {
    color: #141414;
    font-family: Avenir Next;
    font-weight: 600;
}
.block-cart--subtotal-price.price:after {
    content: '円（税込）';
    font-size: 14px;
}
.block-cart--goods-list-item-note {
    display: block;
    padding-left: 5px;
    font-size: 12px;
}
.block-cart--goods-list-item-note em {
    font-weight: bold;
    font-style: normal;
}
.block-order-estimate,
.block-order-method,
.block-order-complete {
    margin: 50px 0 110px;
}
.block-order-estimate--pay-header {
    background: #141414;
}
.pane-order-contents .block-order-estimate--confirmation, .pane-order-contents .block-order-estimate--date-spec-confirmation, .pane-order-contents .block-order-estimate--novelty, .pane-order-contents .block-order-estimate--goods-content, .pane-order-contents .block-order-estimate--sales-append, .pane-order-contents .block-order-estimate--regular-cycle-confirmation, .pane-order-contents .block-order-estimate--comment-content, .pane-order-contents .block-order-estimate--amazonpay-login {
    border: 1px solid #e7e7e7;
}
.pane-order-contents .table, .pane-order-contents .table td, .pane-order-contents .table th {
    border: 1px solid #e7e7e7;
}
.block-cart--continue-shopping-link:hover,
.block-cart--goods-list-item-delete:hover {
    text-decoration: none;
}
.block-order-method--payment-content, .block-order-method--regular-content, .block-order-method--spec-content, .block-order-method--goods-content, .block-order-method--dest-content, .block-order-method--host-content, .block-order-method--host-confirmation {
    border: 1px solid #e7e7e7;
}
.fieldset .form-group,
.fieldset .form-group:last-child {
    border: 1px solid #e7e7e7;
}
.block-order-complete--orderinfo, .block-order-complete--customerentry-wrapper {
    border: solid 1px #e7e7e7;
}
.block-cart-recent-item {
    position: relative;
}
.block-cart-recent-item--header {
    position: relative;
    font-size: 30px;
    font-weight: 600;
    text-align: center;
    line-height: 1;
    letter-spacing: 0.21em;
    margin: 0 0 70px;
    border-top: #141414 1px solid;
    padding: 79px 0 0;
}
.block-cart-recent-item::before,
.block-cart-recent-item::after,
.block-cart-recent-item--header::before,
.block-cart-recent-item--header:after {
    position: absolute;
    right: 0;
    left: 0;
    margin: 0 auto;
    content: '';
    display: block;
    background: #000;
    border-radius: 50%;
    width: 8px;
    height: 8px;
}
.block-cart-recent-item::before {
    top: 129px;
    transform: translateX(-7px);
}
.block-cart-recent-item::after {
    top: 129px;
    transform: translateX(7px);
}
.block-cart-recent-item--header::before {
    bottom: -27px;
    transform: translateX(-21px);
}
.block-cart-recent-item--header::after {
    bottom: -27px;
    transform: translateX(21px);
}
.block-order-estimate--procedure-container,
.block-order-method--procedure-container {
    background: #f4f4f4;
}
.block-order-complete--home {
    margin: 48px auto 0;
}
.block-order-complete--community {
    margin-top: 48px;
}
.block-order-complete--community-inner {
    width: 495px;
    margin: 0 auto;
}
.block-order-complete--community-item:not(:first-child) {
    margin-top: 20px;
}
.block-order-complete--community-link {
display: block;
}
.block-order-complete--community-link img {
width: 100%;
}
.block-login--member-body {
    margin: 0 0 80px;
}
.pane-order-contents {
    min-height: auto;
}
.page-logout .pane-contents {
    margin-top: 60px;
}
.page-contact .action {
    margin: 0 auto;
}
.page-entrycomplete .pane-contents,
.page-salescancelcomplete .pane-contents,
.page-everyform .pane-contents,
.page-everyformcomplete .pane-contents,
.page-askpass .pane-contents,
.page-askpasscomplete .pane-contents,
.page-askpasschange .pane-contents,
.page-reviewwrite .pane-contents,
.page-reviewposted .pane-contents {
    margin: 60px 0 150px;
}
.page-contactthanks .pane-contents,
.page-contact .pane-contents,
.page-topicdetaillist .pane-contents,
.page-entry .pane-contents,
.page-agree .pane-contents,
.page-mag .pane-contents,
.page-topic .pane-contents,
.page-top .pane-contents,
.page-pagecategory .pane-contents,
.page-page .pane-contents,
.page-contactlist .pane-contents {
    margin: 0 0 150px;
}
.page-contactdetail .pane-contents {
    margin: 0 0 140px;
}
.page-menu .pane-contents,
.page-customer .pane-contents,
.page-history .pane-contents,
.page-historydetail .pane-contents,
.page-passchange .pane-contents,
.page-mailchange .pane-contents,
.page-couponlist .pane-contents,
.page-cardedit .pane-contents,
.page-logout .pane-contents,
.page-salescancel .pane-contents {
    padding-bottom: 200px;
}
.page-withdrawal .pane-contents,
.page-custdest .pane-contents {
    padding-bottom: 190px;
}
.block-mypage--customer-status {
    background: #141414;
}
.block-mypage--sign {
    border-right: #141414 1px solid;
}
.block-mypage--shopping-info, .block-mypage--member-info, .block-mypage--inquiry-info, .block-mypage--snssync-info {
    background: rgba(20,20,20,0.05);
}
.block-mypage--shopping-info-items li, .block-mypage--member-info-items li, .block-mypage--inquiry-info-items li, .block-mypage--snssync-info-items li {
    border: #e7e7e7 1px solid;
}
.block-mypage--shopping-info-items li dt, .block-mypage--member-info-items li dt, .block-mypage--inquiry-info-items li dt, .block-mypage--snssync-info-items li dt {
    border-bottom: #e7e7e7 3px solid;
}
.page-history .table, .page-history .table td, .page-history .table th,
.page-historydetail .table, .page-historydetail .table td, .page-historydetail .table th {
    border: 1px solid #e7e7e7;
}
.legend {
    margin: 40px 0 20px;
    padding: 0 0 5px 2px;
    font-size: 26px;
    font-weight: normal;
    border-bottom: #e7e7e7 1px solid;
}
.block-logout,
.block-withdrawal,
.block-order-cancellation-completed,
.block-questionnaire,
.block-questionnaire-completed,
.block-member-terms--message,
.block-member-terms form,
.block-inquiry--message,
.block-inquiry--form,
.block-inquiry--confirmation-form,
.block-inquiry-completed--message,
.block-inquiry--customer-name,
.block-inquiry-completed--customer-name,
.block-inquiry-history-detail,
.block-reset-password-completed,
.block-update-new-password,
.block-user-review-completed {
    width: 900px;
    margin: 0 auto;
}
.block-inquiry-completed,
.block-member-terms,
.block-inquiry,
.page-pagecategory .pane-contents .pane-main,
.page-pagecategory .pane-contents .container,
.page-page .pane-contents .pane-main,
.page-page .pane-contents .container {
    width: 100%;
}
.block-logout .action-buttons,
.page-contact .action-buttons,
.page-couponlist .action-buttons,
.page-cardedit .action-buttons,
.page-salescancelcomplete .action-buttons,
.page-mag .action-buttons,
.page-sales_landingpage .block-landingpage--wrapper > form .action-buttons,
.page-askpasscomplete .action-buttons,
.page-askpasschange .action-buttons,
.block-user-review--form .action-buttons {
    margin-top: 48px;
}
.page-contactthanks .action-buttons {
    margin: 48px 0;
}
.page-withdrawal .action-buttons,
.page-entry .action-buttons,
.page-login .action-buttons,
.page-customer .action-buttons,
.page-history .action-buttons,
.block-purchase-history-detail--requests-for-order,
.page-passchange .action-buttons,
.page-mailchange .action-buttons,
.page-entrycomplete .action-buttons,
.page-salescancel .action-buttons,
.page-everyform .action-buttons,
.page-everyformcomplete .action-buttons,
.page-custdest .action-buttons,
.page-everyformcomplete .action-buttons,
.page-askpass .action-buttons {
    margin-top: 38px;
}
.page-agree .action-buttons {
    margin-top: 20px;
}
.block-purchase-history-detail--requests-for-order .action-buttons {
    display: flex;
    justify-content: center;
    align-items: center;
}
.block-topic-details--header {
    display: none;
}
.block-topic-details--pager-top.pager,
.block-topic-details--pager-bottom.pager {
    display: none;
}
.block-topic-details--items {
    width: 900px;
    margin: 0 auto;
}
.block-topic-details--items {
    border-top: 1px solid #e7e7e7;
}
.block-topic-details--items li {
    position: relative;
    border-bottom: 1px solid #e7e7e7;
    padding: 0;
}
.block-topic-details--items li a {
    position: relative;
    display: block;
}
.block-topic-details--items li a::before,
.block-topic-details--items li a::after {
    content: '';
    display: block;
    width: 0;
    height: 100%;
    pointer-events: none;
    position: absolute;
    z-index: 1;
    top: 0;
    background: #f7f7f7;
}
.block-topic-details--items li a::before {
    left: 0;
    transition: all 0.1s cubic-bezier(.25,.46,.45,.94);
}
.block-topic-details--items li a::after {
    right: 0;
    transition: all 0.4s cubic-bezier(.25,.46,.45,.94) 0.1s;
}
.block-topic-details--items li a:hover::before,
.block-topic-details--items li a:hover::after {
    width: 100%;
}
.block-topic-details--items li a:hover::before {
    transition: all 0.4s cubic-bezier(.25,.46,.45,.94);
}
.block-topic-details--items li a:hover::after {
    transition: all 0.1s cubic-bezier(.25,.46,.45,.94) 0.4s;
}
.block-topic-details--items li a dl {
    position: relative;
    display: flex;
    justify-content: flex-end;
    align-items: center;
}
.block-topic-details--items li a dl::before {
    content: '';
    display: block;
    background: #141414;
    width: 16px;
    height: 1px;
    order: 2;
}
.block-topic-details--items li a dl::after {
    content: '';
    display: block;
    background: #141414;
    width: 9px;
    height: 9px;
    border-radius: 50%;
    order: 3;
    margin-right: 25px;
}
.block-topic-details--items dl {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    padding: 29px 0;
    order: 1;
    width: 875px;
    position: relative;
    z-index: 2;
}
.block-topic-details--items dt {
    font-family: Avenir Next;
    font-weight: 600;
    font-size: 14px;
    color: rgba(44,44,44,0.5);
    display: block;
    width: 120px;
    margin-right: 0;
}
.block-topic-details--items dd {
    font-size: 16px;
    font-weight: 600;
    color: #141414;
    line-height: 1.63;
    display: block;
    width: 705px;
    padding-top: 32px;
}
.page-topicdetaillist .pane-right-menu,
.page-topic .pane-right-menu {
    margin: 0;
}
.block-topic-page--body {
    width: 700px;
    margin: 0 auto;
}
.block-topic-page--article-header {
    margin: 0 0 40px;
    font-size: 30px;
    font-weight: 600;
    position: relative;
    padding-top: 30px;
}
.block-topic-page--article-body {
    font-size: 16px;
    line-height: 1.63;
    margin: 32px 0 0;
}
.block-questionnaire--freespace-top {
    margin-bottom: 48px;
}
.block-questionnaire--freespace-bottom {
    margin-top: 48px;
}
.block-questionnaire--header,
.block-questionnaire-completed--header {
    margin: 0 0 40px;
    font-weight: 600;
    font-size: 38px;
}
.pane-landingpage-contents {
    background: none;
    border: none;
    margin: 60px 0 180px;
}
.block-landingpage-form {
    border: solid 3px #e7e7e7;
}
.block-landingpage-form--payment-content,
.block-landingpage-form--spec-content,
.block-landingpage-form--goods,
.block-landingpage-form--sales-append-content {
    border: solid 1px #e7e7e7;
}
.block-order-method--dest-item {
    border-bottom: solid 1px #e7e7e7;
}
.block-order-method--dest-item:first-child {
    border-top: solid 1px #e7e7e7;
}
.block-landingpage--body-bottom {
    margin-top: 48px;
}
.block-mail-news,
.block-member-info,
.block-member-info-confirmation {
    width: 100%;
}
.block-mail-news--terms-of-service,
.block-mail-news--register-form,
.block-mail-news---release-form,
.block-mail-news--completed-message,
.block-member-info .alert,
.block-member-info--form,
.block-member-info-confirmation--promotion-freespace,
.block-member-info-confirmation--form,
.block-member-info--customer-name,
.block-member-info-confirmation--customer-name {
    width: 900px;
    margin: 0 auto;
}
.block-pagecategory--pager.pager {
    display: none;
}
.block-pagecategory-page-list--date {
    display: none;
}
.block-member-password--login-link a {
    text-decoration: underline;
}
.block-member-password--login-link a:hover {
    text-decoration: none;
}
.block-topic-page--article-body strong {
    font-weight: bold;
}
.block-topic-page--article-body table {
    border-top: 1px solid #e7e7e7;
    border-left: 1px solid #e7e7e7;
}
.block-topic-page--article-body table tr {
    border-bottom: 1px solid #e7e7e7;
}
.block-topic-page--article-body table th {
    font-weight: 600;
    text-align: center;
    border-right: 1px solid #e7e7e7;
    padding: 8px;
    font-size: 14px;
}
.block-topic-page--article-body table td {
    border-right: 1px solid #e7e7e7;
    padding: 8px;
    font-size: 14px;
}

/* バージョンアップ対応 */
.block-order-estimate h3 {
    margin: 0 0 12px 0;
}