.ec-pageHeader {
    padding-top: 50px;
}

.ec-contactRole {
    margin: 0 auto 10% auto;
    padding-left: 20px;
    padding-right: 20px;
    box-sizing: border-box;
    font-size: 16px;
    line-height: 1.4;
    color: #525263;
    -webkit-text-size-adjust: 100%;
    width: 100%;
    max-width: 1130px;
}

.ec-contactRole:after {
    content: " ";
    display: table;
}

.ec-contactRole:after {
    clear: both;
}

.ec-contactRole textarea {
    /* for chrome fontsize bug */
    font-family: sans-serif;
}

.ec-contactRole img {
    max-width: 100%;
}

.ec-contactRole html {
    box-sizing: border-box;
}

.ec-contactRole *,
.ec-contactRole *::before,
.ec-contactRole *::after {
    box-sizing: inherit;
}

.ec-contactRole img {
    width: 100%;
}

.ec-contactRole .ec-contactRole__actions {
    padding-top: 20px;
}

.ec-contactRole p {
    margin: 16px 0;
    font-size: 16px;
    text-align: center;
    color: #000;
}

.ec-contactConfirmRole {
    margin: 0 auto;
    padding-left: 20px;
    padding-right: 20px;
    box-sizing: border-box;
    font-size: 16px;
    line-height: 1.4;
    color: #525263;
    -webkit-text-size-adjust: 100%;
    width: 100%;
    max-width: 1130px;
}

.ec-contactConfirmRole:after {
    content: " ";
    display: table;
}

.ec-contactConfirmRole:after {
    clear: both;
}

.ec-contactConfirmRole textarea {
    /* for chrome fontsize bug */
    font-family: sans-serif;
}

.ec-contactConfirmRole img {
    max-width: 100%;
}

.ec-contactConfirmRole html {
    box-sizing: border-box;
}

.ec-contactConfirmRole *,
.ec-contactConfirmRole *::before,
.ec-contactConfirmRole *::after {
    box-sizing: inherit;
}

.ec-contactConfirmRole img {
    width: 100%;
}

.ec-contactConfirmRole .ec-contactConfirmRole__actions {
    padding-top: 20px;
}

.ec-contactConfirmRole .ec-blockBtn--action {
    margin-bottom: 16px;
}

.ec-contactCompleteRole {
    margin: 0 auto;
    padding-left: 20px;
    padding-right: 20px;
    box-sizing: border-box;
    font-size: 16px;
    line-height: 1.4;
    color: #525263;
    -webkit-text-size-adjust: 100%;
    width: 100%;
    max-width: 1130px;
}

.ec-contactCompleteRole:after {
    content: " ";
    display: table;
}

.ec-contactCompleteRole:after {
    clear: both;
}

.ec-contactCompleteRole textarea {
    /* for chrome fontsize bug */
    font-family: sans-serif;
}

.ec-contactCompleteRole img {
    max-width: 100%;
}

.ec-contactCompleteRole html {
    box-sizing: border-box;
}

.ec-contactCompleteRole *,
.ec-contactCompleteRole *::before,
.ec-contactCompleteRole *::after {
    box-sizing: inherit;
}

.ec-contactCompleteRole img {
    width: 100%;
}

.no-product h2 {
    font-size: 21px;
    color: #E43433;
    font-weight: bold;
    margin: 0;
    padding-bottom: 20px;
}

.no-product p {
    font-size: 14px;
    color: #666;
    font-weight: 500;
    margin-bottom: 0;
    text-align: left;
}

.no-product h3 {
    font-size: 21px;
    color: #666;
    font-weight: bold;
    margin: 0;
    padding-bottom: 20px;
}

.contact_bg .no-product-main {
    background: #f7f7f7;
}

.no-product.contact_bg .ec-borderedDefs {}

.ec-borderedDeff .no-product-main dt {
    font-size: 14px;
    padding-top: 9px;
    font-weight: 500;
}

.contact_bg .ec-borderedDefs dt {
    padding-top: 10px;
}

.ec-borderedDeff .no-product-main dt .ec-label {
    font-weight: 400;
}

.contact_bg .ec-borderedDefs dt .ec-label {
    font-weight: 500;
}

.ec-borderedDeff .no-product-main dl {
    border-bottom: none;
}

.contact_bg .ec-borderedDefs dl {
    border-bottom: none;
}

.no-product-main input {
    background: #eeeeee;
    border: none;
    border-radius: 0;
}

.contact_bg .no-product-main input {
    background: #fff;
}

#contact_address_pref {
    background: #fff;
    background-image: url('../image/contact_menu.svg');
    background-size: 40px;
    border: none;
    -webkit-appearance: none;
    appearance: none;
    background-repeat: no-repeat;
    width: 40%;
    background-position: right center;
    background-color: #fff;
    height: 40px;
    margin-bottom: 16px;
    margin-top: 16px;
}

.ec-zipInputHelp span {
    font-size: 14px;
}

.no-product-main textarea {
    background: #eeeeee;
    border: none;
    border-radius: 0;
}

.contact_bg .no-product-main textarea {
    background: #fff;
    width: 100%;
    text-indent: 12px;
    font-family: "Noto Sans JP", sans-serif;
}

.ec-blockBtn--action {
    background: #E43433;
    border-color: #E43433;
}

.contact_bg .no-product-top {
    background: #f7f7f7;
}

.ec-contactConfirmRole {
    margin-top: 76px;
}


.ec-pageHeader h1 {
    border: none;
    color: #000;
    font-size: 34px;
    text-align: center;
    margin-bottom: 0;
}

.ec-required {
    display: inline-block;
    margin-left: .8em;
    vertical-align: 2px;
    color: #E43433;
    font-size: 12px;
    font-weight: normal;
}

.ec-borderedDeff {
    width: 100%;
    margin-bottom: 16px;
}

.ec-borderedDeff dl {
    display: flex;
    border-bottom: 1px dotted #ccc;
    margin: 0;
    padding: 10px 0 0;
    flex-wrap: wrap;
}

.ec-borderedDeff dt,
.ec-borderedDeff dd {
    padding: 0;
}

.ec-borderedDeff dt {
    font-weight: normal;
    width: 100%;
    padding-top: 0;
}

.ec-borderedDeff dd {
    padding: 0;
    width: 100%;
    line-height: 2.5;
}

.ec-borderedDeff p {
    line-height: 1.4;
}

.ec-borderedDefs {
    width: 100%;
    border-bottom: 1px solid #eee;
    margin-bottom: 16px;
}

.ec-borderedDefs dl {
    display: flex;
    border-bottom: 1px dotted #ccc;
    margin: 0;
    padding: 10px 0 0;
    flex-wrap: wrap;
}

.ec-borderedDefs dt,
.ec-borderedDefs dd {
    padding: 0;
}

.ec-borderedDefs dt {
    font-weight: normal;
    width: 100%;
    padding-top: 0;
}

.ec-borderedDefs dd {
    padding: 0;
    width: 100%;
    line-height: 2.5;
}

.ec-borderedDefs p {
    line-height: 1.4;
    font-weight: 400;
    font-size: 15px;
}

.ec-borderedDefss {
    width: 100%;
    border-top: 1px dotted #ccc;
}

.ec-borderedDefss dl {
    display: flex;

    margin: 0;
    padding: 10px 0 0;
    flex-wrap: wrap;
}

.ec-borderedDefss dt,
.ec-borderedDefss dd {
    padding: 0;
}

.ec-borderedDefss dt {
    font-weight: normal;
    width: 100%;
    padding-top: 0;
}

.ec-borderedDefss dd {
    padding: 0;
    width: 100%;
    line-height: 2.5;
}

.ec-borderedDefss p {
    line-height: 1.4;
}

.ec-borderedDefsss {
    width: 100%;
}

.ec-borderedDefsss dl {
    display: flex;
    margin: 0;
    padding: 10px 0 0;
    flex-wrap: wrap;
}

.ec-borderedDefsss dt,
.ec-borderedDefsss dd {
    padding: 0;
}

.ec-borderedDefsss dt {
    font-weight: normal;
    width: 100%;
    padding-top: 0;
}

.ec-borderedDefsss dd {
    padding: 0;
    width: 100%;
    line-height: 2.5;
}

.ec-borderedDefsss p {
    line-height: 1.4;
}

.ec-list-chilled {
    display: table-row;
    border: 0 none;
    padding: 8px 0;
}

.ec-list-chilled dt,
.ec-list-chilled dd {
    display: table-cell;
    border-bottom: 1px dotted #ccc;
    padding: 0;
}

.ec-list-chilled dt {
    width: 30%;
}

.ec-list-chilled dd {
    padding: 0;
}

.no-product-main {
    padding: 20px 28px;
    background: #fff;
    margin-bottom: 20px;
}

.ec-input input,
.ec-halfInput input,
.ec-numberInput input,
.ec-zipInput input,
.ec-telInput input,
.ec-select input,
.ec-birth input {
    display: block;
    width: 100%;
    height: 40px;
    padding: 6px 12px;
    font-size: 14px;
    line-height: 1.42857;
    color: #555555;
    background-color: #fff;
    background-image: none;
    border: 1px solid #ccc;
    border-radius: 4px;
    -webkit-appearance: none;
    box-shadow: none;
    transition: border-color ease-in-out 0.15s, box-shadow ease-in-out 0.15s;
    border-radius: 3px;
}

.ec-halfInput input[type='text'] {
    display: inline-block;
    width: 47%;
    margin-left: 2%;
}

.ec-halfInput input[type='text']:first-child {
    margin-left: 0;
}

.no-product-main input {
    background: #eeeeee;
    border: none;
    border-radius: 0;
}

.contact_bg .no-product-main input {
    background: #fff;
}

:focus-visible {
    outline: none;
}

.ec-zipInput {
    display: inline-block;
}

.ec-zipInput input {
    display: inline-block;
    text-align: left;
    width: auto;
    max-width: 8em;
    font-size: 14px;
}

.ec-zipInput span {
    display: inline-block;
    padding: 0 5px 0 3px;
    margin-left: 5px;
}

.ec-zipInputHelp {
    display: inline-block;
    margin-left: 10px;
    margin-bottom: 16px;
    vertical-align: baseline;
    line-height: 0;
}

.ec-zipInputHelp .ec-zipInputHelp__icon {
    display: inline-block;
    margin-top: -10px;
    width: 20px;
    height: 20px;
    background: #525263;
    border-radius: 50%;
    font-size: 13px;
    position: relative;
    top: -6px;
}

.ec-zipInputHelp .ec-zipInputHelp__icon .ec-icon img {
    width: 1em;
    height: 1em;
    position: relative;
    left: 3px;
    top: 3px;
}

.ec-zipInputHelp span {
    margin-left: 8px;
    display: inline-block;
    color: #0092C4;
    vertical-align: 3px;
}

.ec-zipAuto {
    margin-bottom: 16px;
}

.ec-zipAuto .ec-inlineBtn {
    font-weight: normal;
}

.ec-input input::-moz-placeholder,
.ec-halfInput input::-moz-placeholder,
.ec-numberInput input::-moz-placeholder,
.ec-zipInput input::-moz-placeholder,
.ec-telInput input::-moz-placeholder,
.ec-select input::-moz-placeholder,
.ec-birth input::-moz-placeholder {
    color: #999;
    opacity: 1;
}

.ec-input input:-ms-input-placeholder,
.ec-halfInput input:-ms-input-placeholder,
.ec-numberInput input:-ms-input-placeholder,
.ec-zipInput input:-ms-input-placeholder,
.ec-telInput input:-ms-input-placeholder,
.ec-select input:-ms-input-placeholder,
.ec-birth input:-ms-input-placeholder {
    color: #999;
}

.ec-input input::-webkit-input-placeholder,
.ec-halfInput input::-webkit-input-placeholder,
.ec-numberInput input::-webkit-input-placeholder,
.ec-zipInput input::-webkit-input-placeholder,
.ec-telInput input::-webkit-input-placeholder,
.ec-select input::-webkit-input-placeholder,
.ec-birth input::-webkit-input-placeholder {
    color: #999;
}

.ec-blockBtn--action {
    display: inline-block;
    margin-bottom: 0;
    font-weight: bold;
    text-align: center;
    vertical-align: middle;
    touch-action: manipulation;
    cursor: pointer;
    background-image: none;
    border: 1px solid transparent;
    white-space: nowrap;
    padding: 6px 12px;
    font-size: 14px;
    line-height: 1.42857;
    border-radius: 0px;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    padding: 10px 16px;
    text-decoration: none;
    color: #fff;
    background-color: #E43433;
    border-color: #E43433;
    display: block;
    width: 100%;
    height: 56px;
    line-height: 56px;
    padding-top: 0;
    padding-bottom: 0;
}

.ec-blockBtn--action {
    padding: 10px;
    width: 200px;
    height: initial;
    line-height: 1.6em;
    margin: 3% auto 0 auto;
}

.ec-blockBtn--action:hover {
	opacity: .8;
	filter: opacity(80%);
}

@media only screen and (min-width: 768px) {
    .ec-pageHeader h1 {
        border-top: none;
        margin: 10px 16px 16px;
        padding: 8px;
        font-size: 32px;
        font-weight: bold;
    }

    .ec-heading-bold {
        font-size: 18px;
    }

    .ec-reportHeading {
        border-top: 0;
        font-size: 32px;
    }

    .ec-reportHeading h1,
    .ec-reportHeading h2,
    .ec-reportHeading h3,
    .ec-reportHeading h4,
    .ec-reportHeading h5,
    .ec-reportHeading h6,
    .ec-reportHeading p {
        font-size: 32px;
    }

    .ec-price .ec-price__unit {
        font-size: 1em;
    }

    .ec-price .ec-price__price {
        font-size: 1em;
    }

    .ec-price .ec-price__tax {
        font-size: 0.57em;
    }

    .ec-borderedDefs dl {
        flex-wrap: nowrap;
        padding: 15px 0 4px;
    }

    .ec-borderedDefs dt {
        padding-top: 14px;
        width: 30%;
    }

    .ec-borderedDefs dd {
        width: 70%;
        line-height: 3;
    }

    .ec-borderedDeff dl {
        flex-wrap: nowrap;
        padding: 15px 0 4px;
    }

    .ec-borderedDeff dt {
        padding-top: 14px;
        width: 30%;
    }

    .ec-borderedDeff dd {
        width: 70%;
        line-height: 3;
    }

    .ec-borderedDefss dl {
        flex-wrap: nowrap;
        padding: 15px 0 4px;
    }

    .ec-borderedDefss dt {
        padding-top: 14px;
        width: 30%;
    }

    .ec-borderedDefss dd {
        width: 70%;
        line-height: 3;
    }

    .ec-borderedDefsss dl {
        flex-wrap: nowrap;
        padding: 15px 0 4px;
    }

    .ec-borderedDefsss dt {
        padding-top: 14px;
        width: 30%;
    }

    .ec-borderedDefsss dd {
        width: 70%;
        line-height: 3;
    }

    .ec-list-chilled dt,
    .ec-list-chilled dd {
        padding: 16px 0;
    }

    .ec-list-chilled dd {
        padding: 16px;
    }

    .ec-borderedList {
        border-top: 1px dotted #ccc;
    }

    .ec-blockTopBtn {
        right: 30px;
        bottom: 30px;
    }

    .ec-input input,
    .ec-halfInput input,
    .ec-numberInput input,
    .ec-zipInput input,
    .ec-telInput input,
    .ec-select input,
    .ec-birth input {
        font-size: 14px;
    }

    .ec-input select,
    .ec-halfInput select,
    .ec-numberInput select,
    .ec-zipInput select,
    .ec-telInput select,
    .ec-select select,
    .ec-birth select {
        font-size: 14px;
    }

    .ec-input textarea,
    .ec-halfInput textarea,
    .ec-numberInput textarea,
    .ec-zipInput textarea,
    .ec-telInput textarea,
    .ec-select textarea,
    .ec-birth textarea {
        font-size: 14px;
    }

    .ec-input input,
    .ec-halfInput input,
    .ec-numberInput input,
    .ec-zipInput input,
    .ec-telInput input,
    .ec-select input,
    .ec-birth input {
        margin-bottom: 16px;
    }

    .ec-halfInput input[type='text'] {
        margin-left: 15px;
        width: 45%;
    }

    .ec-input input,
    .ec-halfInput input,
    .ec-numberInput input,
    .ec-zipInput input,
    .ec-telInput input,
    .ec-select input,
    .ec-birth input {
        font-size: 14px;
    }

    .ec-input select,
    .ec-halfInput select,
    .ec-numberInput select,
    .ec-zipInput select,
    .ec-telInput select,
    .ec-select select,
    .ec-birth select {
        font-size: 14px;
    }

    .ec-input textarea,
    .ec-halfInput textarea,
    .ec-numberInput textarea,
    .ec-zipInput textarea,
    .ec-telInput textarea,
    .ec-select textarea,
    .ec-birth textarea {
        font-size: 14px;
    }

    .ec-input input,
    .ec-halfInput input,
    .ec-numberInput input,
    .ec-zipInput input,
    .ec-telInput input,
    .ec-select input,
    .ec-birth input {
        margin-bottom: 16px;
    }

    .ec-halfInput input[type='text'] {
        margin-left: 15px;
        width: 45%;
    }

    .ec-select__delivery {
        display: inline-block;
    }

    .ec-select__time {
        display: inline-block;
    }

    .ec-birth select {
        margin: 0 8px 10px;
    }

    .ec-required {
        margin-left: 1em;
    }

    .ec-borderedDefs dl {
        flex-wrap: nowrap;
        padding: 15px 0 4px;
    }

    .ec-borderedDefs dt {
        padding-top: 14px;
        width: 30%;
    }

    .ec-borderedDefs dd {
        width: 70%;
        line-height: 3;
    }

    .ec-borderedDeff dl {
        flex-wrap: nowrap;
        padding: 15px 0 4px;
    }

    .ec-borderedDeff dt {
        padding-top: 14px;
        width: 30%;
    }

    .ec-borderedDeff dd {
        width: 70%;
        line-height: 3;
    }

    .ec-borderedDefss dl {
        flex-wrap: nowrap;
        padding: 15px 0 4px;
    }

    .ec-borderedDefss dt {
        padding-top: 14px;
        width: 30%;
    }

    .ec-borderedDefss dd {
        width: 70%;
        line-height: 3;
    }

    .ec-borderedDefsss dl {
        flex-wrap: nowrap;
        padding: 15px 0 4px;
    }

    .ec-borderedDefsss dt {
        padding-top: 14px;
        width: 30%;
    }

    .ec-borderedDefsss dd {
        width: 70%;
        line-height: 3;
    }

    .ec-list-chilled dt,
    .ec-list-chilled dd {
        padding: 16px 0;
    }

    .ec-list-chilled dd {
        padding: 16px;
    }
}