/*
 Theme Name:   storefront custom
 Theme URI:    https://ss-complex.com/
 Description:  storefront custom
 Template:     storefront
 Version:      1.0.0
*/


/* common */

body, .secondary-navigation a {
    color: #333333;
}

b, strong {
    font-size: 1.8rem;
    font-size: 18px;
}
a {
    color: #0D47A1;
    text-decoration: underline;
}
a:hover {
    text-decoration: none;
}

h1, .alpha {
    font-size: 3.4rem;
    font-size: 34px;
    line-height: 1.8;
    position: relative;
}

h1:after, .alpha:after {
    content: '';
    background-color: #333;
    position: absolute;
    display: block;
    width: 40px;
    height: 4px;
    left: 0;
    bottom: -20px;
}
table td, table th {
    padding: 32px 16px 32px 0px;
}
table:not( .has-background ) th,
table:not( .has-background ) tbody td,
table:not( .has-background ) tbody tr:nth-child(2n) td, fieldset, fieldset legend {
    background: none;
}

.warkshopTable th,
.warkshopTable td {
    border-bottom: 0;
}
table.sysTable th,
table.sysTable td {
    border-bottom: 1px solid #CCCCCC;
}
table.sysTable a {
    color: #0D47A1;
    text-decoration: underline;
}
table.sysTable a:hover {
    text-decoration: none;
}
input[type=text], input[type=number], input[type=email], input[type=tel], input[type=url], input[type=password], input[type=search], textarea, .input-text {
    background-color: #ffffff;
    color: #333333;
    border: 1px solid #cccccc;
    -webkit-appearance: none;
    box-sizing: border-box;
    font-weight: 400;
}
button, input[type="file"],
button, input[type="submit"] {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    padding: 0;
    border: none;
    outline: none;
}
button, input[type="file"] {

}
input[type="file"] {
    width: 100%;
}

input[type=button], input[type=reset], input[type=submit], .button, .wc-block-grid__products .wc-block-grid__product .wp-block-button__link, .added_to_cart {
    text-decoration: none;
    color: #fff !important;
    font-size: 16px;
    box-shadow: 0px 8px 16px rgb(0 0 0 / 20%);
    background: #00acc1;
    background: linear-gradient(90deg, #00acc1 0%, #00897b 100%);
    border-radius: 4px;
    padding: 20px 24px;
}
button:hover, input[type=button]:hover, input[type=reset]:hover, input[type=submit]:hover, .button:hover, .wc-block-grid__products .wc-block-grid__product .wp-block-button__link:hover, .added_to_cart:hover {
    box-shadow: 0px 2px 4px rgb(0 0 0 / 20%);
}
.sysForm__radioList{
    display: inline-block;
    padding: 5px;
    cursor: pointer;
}
.sysForm__radioList>label:hover{
    color: #00acc1;
}
.sysForm__radioList>input{
    margin-right: 0px;
    cursor: pointer;
}
.sysForm__radioList input[type="radio"] {
   -webkit-transform: scale(1.5);
   transform: scale(1.5);
}
.amount {
    display: inline;
}
.sysTable__messageFrom {
    font-size: 12px;
    display: table;
    background-color: #eee;
    border-radius: 4px;
    font-weight: bold;
    color: #999;
    line-height: 1em;
    padding: 8px;
    margin-bottom: 8px !important;
}
.sysTable__messageDate {
    font-size: 13px;
    color: #999;
    margin-bottom: 8px !important;
}
/* parts */

.red {
    color: #FF0000;
}
.cmnTtl__type4 {
    font-size: 2.4rem;
}

/* header */
.storefront-breadcrumb {
    padding: 12px 0px;
    background-color: #E0E5EB;
}
.home.blog .site-header, .home.page:not(.page-template-template-homepage) .site-header, .home.post-type-archive-product .site-header {
    margin-bottom: 0;
}
.woocommerce-active .site-header .site-search {
    display: none;
}
/* footer */
.site-footer {
    background-color: #333333;
    color: #fff;
    padding:0;
}
.site-footer a {
    color: #fff !important;
}

/* contents */
.cmnTtl__type2:before {
    top: 0.1em;
}
a.bold.underLine {
    color: #333;
}


@media screen and (min-width:768px) {
    table td, table th {
        min-width: 145px;
    }
    .storefront-secondary-navigation.woocommerce-active .site-header .site-branding {
        width: 55%;
        float: left;
        margin-right: 0%;
    }
    .storefront-secondary-navigation.woocommerce-active .site-header .secondary-navigation {
    width: 45%;
    float: right;
    margin-right: 0%;
    }
    .storefront-primary-navigation {
        background-color: #FFFFFF;
    }
    .storefront-full-width-content .content-area {
        width: 800px;
        float: none;
        margin: 0 auto !important;
    }
    .storefront-full-width-content.single-product div.product .summary,
    .storefront-full-width-content .woocommerce-tabs .panel {
        width: 77.5%;
    }
    .storefront-full-width-content.single-product div.product .woocommerce-product-gallery,
    .storefront-full-width-content .woocommerce-tabs ul.tabs {
        width: 17.5%;
        margin-right: 5%;
        margin-bottom: 40px;
    }
    .storefront-full-width-content.single-product div.product .woocommerce-tabs {
        clear: both;
        width: 800px;
        position: relative;
        left: 0px;
    }
}

@media screen and (min-width:768px) {
.headerTop__brandName a {
    margin-top: 0 !important;
    margin-left: 0 !important
}
.headerTop__brandName {
    margin-bottom: 0 !important;
}
}

@media screen and (max-width:767px) {
.headerTop__brandName a {
    margin-top: 16px !important;
    margin-left: 0 !important;
    width: 200px;
    height: 15px;
}
.headerTop__brandName {
    margin-bottom: 0 !important;
}
}

.storefront-full-width-content.woocommerce-cart .entry-header, .storefront-full-width-content.woocommerce-checkout .entry-header, .storefront-full-width-content.woocommerce-account .entry-header, .storefront-full-width-content .woocommerce-products-header {
    text-align: left;
}

.courseFlow__item {
    list-style-type: none !important;
}
ul, ol {
    margin: 0;
}
.bottomLine.long {
    padding-right: 38px;
    text-decoration: none;
    color: #333;
}

.registration-form > h2 {
    display: none;
}
.sysForm__formItem {
    margin-bottom: 16px;
}
.userDashboardLink {
    margin-bottom: 32px;
}
.userDashboardLink li {
    list-style-type:  none;
}
.userDashboardLink a {
    display: block;
    border: 2px solid #333;
    border-radius: 4px;
    padding: 16px 0;
    text-align: center;
    text-decoration: none !important;
    font-weight: bold;
    font-size: 16px;
    background-color: #fff;
    box-shadow: 4px 4px 4px rgba(0,0,0,0.2);
    color: #333;
}
@media screen and (min-width:768px) {
.userDashboardLink {
    display: flex;
}
.userDashboardLink li {
    margin-right: 24px;
    width: calc((100% / 3) - 24px);
}

}
@media screen and (max-width:767px) {
.userDashboardLink {
    margin-top: 24px;
}
.userDashboardLink li {
    margin-top: 16px;
}
}

.faqArea {
    margin-top: 32px;
}
.faqArea__list {
    border-top: 1px solid #ccc;
}
.faqArea__question {
    width: 100%;
    border-bottom: 1px solid #ccc;
    font-size: 16px;
    padding: 16px 0;
    cursor: pointer;
}
.faqArea__question:hover {
    opacity: 0.7;
    transition: 0.3s;
}
.faqArea__question p {
    margin: 0 !important;
}
.faqArea__answer {
    display: none;
    padding: 16px;
    font-size: 14px;
    background-color: #f1f1f1;
    border-bottom: 1px silid #ccc;
}
@media screen and (min-width:768px) {
.faqArea__answer img {
    width: 400px;
    height: auto;
    margin: 0;
}
}

.order_comments:after {
    display: inline-block;
    font-size: 1.4rem;
    content :'※「榎本メソッド体験ワークショップ」をお申し込みの方は、実施日カレンダーから希望参加日と当日ご利用になる環境（PC・スマートフォン・タブレット）をご記入ください。';
}
/*注文ボタン下コメント*/
#payment::after {
    display: table;
    font-size: 1.4rem;
    content :'※「榎本メソッド体験ワークショップ」をお申し込みの方は、実施日カレンダーから希望参加日と当日ご利用になる環境（PC・スマートフォン・タブレット）をご記入ください。';
}

.valuer_top_form {
    margin-bottom: .618em;
}

.valuer_top_form select {
    min-height: 30px;
    margin-right: 0.5em;
}

input[type=submit].valuer_top_button {
    display: inline-block;
    text-decoration: none;
    font-size: 13px;
    line-height: 2.15384615;
    min-height: 30px;
    margin: 0;
    padding: 0 10px;
    cursor: pointer;
    border-width: 1px;
    border-style: solid;
    -webkit-appearance: none;
    border-radius: 3px;
    white-space: nowrap;
    box-sizing: border-box;

    color: #333 !important;
    border-color: #333;
    background: #f6f7f7;
    vertical-align: top;
    box-shadow: none;
}