:root {
    --colorblue: #007BC6;
    --colorgreen: #14A674;
}

html {
    scroll-behavior: smooth;
}
body{
    font-family: Arial, Helvetica, sans-serif;
}

header {
    display: flex;
    padding: 10px 20px;
    width: 100%;
    max-width: 2000px;
    margin: 0 auto;
    justify-content: space-around;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 100;
    background-color: #fff;
}

.header-flex {
    display: flex;
}

.logo {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.payment {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 204px;
    margin-left: 76px;
}

.tel {
    padding: 6px 20px;
}

.green {
    color: var(--colorgreen);
}

.bluec {
    color: var(--colorblue);
}

h2 {
    position: relative;
}
/* 
h2::after {
    position: absolute;
    width: 100%;
    height: 4px;
    content: "";
    bottom: -5px;
    left: 0;
    background: linear-gradient(to right, #14A674 0%, #14A674 50%, #007BC6 50%, #007BC6 100%);
} */

.tel p {
    font-size: 40px;
    text-align: center;
    font-weight: 900;
}
.tel span {
    font-size: 16px;
    line-height: 2;
    display: inline-block;
}
.header_btn{
    display: flex;
    align-items: center;
}
.header_button {
    background-color: #EB2948;
    padding: 9px 50px;
    color: #fff;
    display: flex;
    justify-content: space-evenly;
    align-items: center;
    border-radius: 50px;
    margin:8px 40px 18px 40px;
}


.header_button img {
    width: 35px;
    margin-right: 20px;
}

/* TOPIMAGE */
/* contents */
.wrap {
    max-width: 1200px;
    width: 100%;
    display: block;
    margin: 0 auto;
}

.topimg,
.pointimg {
    width: 100%;
}

.topimg img {
    width: 100%;
    display: block;
    margin: 90px auto 0 auto;
}

.content {
    padding: 80px 0;
    text-align: center;
}

.sp-non {
    display: block;
}

.sp-block {
    display: none;
}

.topimg img.sp-non {
    display: block;
}

.topimg img.sp-block {
    display: none;
}

.pad-b150 {
    padding-bottom: 150px;
}


h2 {
    font-size: 45px;
    font-weight: bold;
    display: inline-block;
}
.centerCont{
    display: block;
    margin: 30px auto;
}
.centerCont_all{
    display: block;
    margin: 0px auto;
}
.mt50{
    margin-top: 50px;
}
.mt100{
    margin-top: 100px;
}
.p-rel{
    position: relative;
}
.p-ab{
    position: absolute;
}

/* CTA */
#cta{
    background-image: url(../images/btn_area_bg.svg);
    background-size: cover;
    background-repeat: no-repeat;
    padding: 40px 0;
    margin-top: -5px;
    justify-content: center;
}

#cta a{
    display: block;
    margin: 0 20px;
}
/* 悩み */
.worrie_bg{
    bottom: 0;
    right: 0;
    z-index: -1;
}

/* 全て解決 */
.all_content{
    background-color: #66c3ff;
    padding-bottom: 50px;
}

/* サポート */
#support{
    background-color: #def2ff;
}
#support h2,#voice h2{
    background-color: #007BCB;
    color: #fff;
    text-align: center;
    font-size: 2rem;
    font-weight: bold;
    width: 100%;
    padding: 20px 0px;
}
.support_box h3{
    color: #007BC6;
    background: linear-gradient(transparent 50%, #FAE000 50%);
    font-size: 1.5rem;
    margin-top: 10px;
    display: inline-block;
    font-weight: bold;
    margin-bottom: 30px;
}
.support_box{
    padding: 50px 0;
    text-align: center;
}
.support_box img{
    margin: 0 auto;
    width: 50%;
}
#solution{
    padding-bottom: 50px;
}
.solution_img{
    margin: -20px auto 0 auto;
}

/* 選ばれている理由 */
#reason{
    background-image: url(../images/reason_bg.svg);
    background-size: cover;
    background-repeat: no-repeat;
}
.reason_box{
    width: 30%;
    border-radius: 20px;
    border: 1px solid #007BCB;
    background-color: #fff;
}
.reason_box h3{
    background-color:#007BCB;
    color:#FFEF65;
    text-align: center;
    font-weight: bold;
    padding: 20px;
    border-radius: 16px 16px 0 0;
    margin-bottom: 20px;
}
.reason_box img{
    transform: scale(0.9);
}
.reason_box p{
    color: #007BC6;
    margin: 10px 20px 20px 10px;
}

/* お問い合わせの流れ */
#flow {
    background-color: #f1faff;

}
#flow h2{
    background-color: #007BCB;
    text-align: center;
    color: #fff;
    border-radius: 50px;
    font-weight: bold;
    margin: 30px auto;
    padding: 25px;
}
.flow{
    text-align: left;
    width: 65%;
}
.flow dt{
    font-size: 2.2rem;
    line-height: 1.5;
    color: #007BCB;
}
.flow dd{
    margin-bottom: 30px;
}

/* お客様の声 */
#voice{
    background-image: url(../images/voice_bg.png);
    background-size: cover;
    background-repeat: no-repeat;
}
.f-wrap{
flex-wrap: wrap;
}
#voice img{
    width: 48%;
    box-shadow: 1px 0px 14px #bebebe;
    margin: 20px 0;
}
#voice h3{
    text-align: center;
    color: #007BC6;
    font-weight: bold;
    font-size: 2rem;
    margin-bottom: 20px;
}
.house_clean_text{
    text-align: left;
    display: flex;
    width: 56%;
    margin-left: 5%;
    line-height: 1.8;
    justify-content: center;
    align-items: center;
}

.container {
    max-width: 800px;
    margin: 20px auto;
    background-color: #fff;
    border: 1px solid #ddd;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
}
.header, .section-title {
    background-color: #0066cc;
    color: #ffffff;
    padding: 10px;
    font-size: 18px;
    text-align: center;
}
.row {
    display: flex;
    border-bottom: 1px solid #ddd;

}
.row:last-child {
    border-bottom: none;
}
.cell {
    padding: 10px;
    border-right: 1px solid #F4FBFF;
    width: 30%;
    padding: 20px ;
    line-height: 2;
}
.cell:last-child {
    border-right: none;
    width: 70%;
    text-align: left;
}
.label {
    background-color: #0066cc;
    color: #ffffff;
    font-weight: bold;
    text-align: center;
}
.value {
    background-color: #F4FBFF;
}
.flex-section{
    display: flex;
    justify-content: space-around;
}
.link {
    display: flex;
    align-items: center;
    flex-direction: column;
    justify-content: flex-end;
}
.link a {
    display: block;
    margin-bottom: 20px;
}
/* 会社概要 */


dt {
    font-size: 1.2rem;
    line-height: 1.5;
}

dd {
    font-size: 1.2rem;
    line-height: 1.5;
    text-align: left;
}

.under-company-wrapper dd {
    width: 75%;
}

#footer {
    padding: 30px 0;
    background-color: #A4d7f5;
    text-align: center;
}

#footer a:hover {
    text-decoration: underline;
}

#footer p {
    margin: 20px 0;
}

.detail-table {
    position: relative;
    width: 95%;
    display: table;
    margin: 0 auto;
    table-layout: fixed;
}

.detail-table::before {
    position: absolute;
    content: "施工情報";
    width: 200px;
    padding: 10px 20px;
    background-color: #000;
    color: #fff;
    top: -48px;
    left: 0;
    font-size: 24px;
    text-align: center;
    font-weight: bold;
}

.onepoint {
    font-size: 38px;
    text-align: left;
    margin-left: 21%;
    color: #379DE7;
    font-weight: bold;
}

.detail-table th {
    background-color: #379DE7;
    color: #fff;
    text-align: center;
    font-weight: bold;
    font-size: 24px;
    padding: 10px;
    border: 1px solid #fff;
}

.detail-table td {
    padding: 10px;
    background-color: #C7E8EF;
    color: #379DE7;
    text-align: center;
    font-weight: bold;
    font-size: 24px;
    border: 1px solid #fff;
}

.thanks-content {
    text-align: center;
    padding: 300px 0;
    font-size: 1.5rem;
}

.wpcf7-list-item.first {
    margin: 0;
}

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output .wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
    display: none;
}

.wpcf7-response-output {
    display: none;
}

.sp-non-flex {
    display: flex;
}
.contact-form{
    padding-top: 12px;
    margin-top: -12px;
}

.-flex{
    display: flex;
}
.js{
    justify-content: space-between;
}
.je{
    justify-content: space-evenly;
}
.warrie__box{
    margin-top: 30px;
}
.warrie__box p {
    background: linear-gradient(transparent 50%, #FAE000 50%);
    font-size: 1.5rem;
    margin-top: 10px;
    display: inline-block;
    font-weight: bold;
}
@media screen and (max-width:1400px) {
    .header_button {
        padding: 9px 10px;

    }

    .tel p {
        font-size: 24px;
        margin-top: 14px;
    }

    .tel span {
        font-size: 12px;
    }
}

@media screen and (max-width:1200px) {
    .tel {
        padding: 6px 7px;
    }

    .thanks-content {
        padding: 300px 10px;
        text-align: left;
    }

    .tel span {
        font-size: 10px;
    }

    .tel p {
        font-size: 14px;
        margin-top: 14px;
    }

    .wrap {
        padding: 0 10px;
    }

    .logo {
        width: 46%;
    }

    .logo img {
        width: 100%;
    }

    .center-pic img,.center-pic2 img,
    .center-cont img {
        width: 100%;
    }

    .payment {
        width: 37%;
    }

    .payment {
        margin-left: 40px;
    }

    .header_button img {
        width: 24px;
        margin-right: 20px;
    }

    .header_button {

        margin: 18px 10px;
    }
}

@media screen and (min-width:769px) and (max-width:820px) {
    .header_button {
        padding: 9px 77px;
    }

    .man1 {
        z-index: -1;
    }

}

@media screen and (max-width:820px) {
    .wrap {
        padding: 0 10px;
    }
    .electiric-point-explain {
        padding: 20px 20px 48px 20px;
        font-size: 18px;
        font-weight: bold;
        text-align: left;
        line-height: 1.8;
    }

    .topimg img {
        width: 100%;
        display: block;
    }

    .sp-non {
        display: none;
    }

    .sp-block {
        display: block;
    }

    .logo {
        width: 48%;
    }

    .payment {
        width: 31%;
    }
    .spwidth li span:first-child{
        width: initial;
        display: inline;
    }
    .second{
        width: initial;
        display: inline;
    
    }
    .center-pic img,.center-pic2 img,
    .center-cont img {
        width: 100%;
    }

    img {
        width: 100%;
    }

    h2 {
        font-size: 1.5rem;
    }

    .header_button {
        margin: 5px 0;
    }

    .header-flex {
        justify-content: space-evenly;
        margin-bottom: 15px;
    }

    .content {
        padding: 30px 18px;
        box-sizing: border-box;
    }

    .tel p {
        font-size: 23px;
        margin-top: 0;
    }

    .tel span {
        font-size: 10px;
    }

    .filter {
        padding-bottom: 0px;
    }

    .flex-section,
    header {
        display: block;
    }

    .filter .flex-section {
        width: 100%;
        margin: 30px auto 0px auto;
    }

    .center-cont {
        margin: -77px auto 50px auto;

    }

    .point,
    .voice-image,
    .filter .text-box,
    .works-item,
    .order-price,
    .step .flex-section,
    .steps ul {
        width: 100%;
    }

    .wpcf7-list-item {
        display: block !important;
        margin: 10px 0 !important;
    }

    .filter .text-box {
        margin-top: 30px;
        margin-left: 0;
    }

    .filter .text-box p {
        font-size: 18px;
    }

    .filter .text-box h3 {
        font-size: 1.5rem;
    }

    .onepoint {
        font-size: 17px;
        margin-left: 24%
    }

    .detail-table::before {
        width: 21%;
        padding: 10px 7px;
        top: -36px;
        font-size: 13px;
    }

    .p-accordion__head-inner {
        font-size: 13px;
    }

    .man1 {
        top: 0%;
        left: 5%;
        width: 23%;
    }

    .man2 {
        bottom: 7%;
        right: 4%;
        width: 12%;
    }

    .order-price,
    .plus {
        margin-top: 20px;
    }

    .filter h2 {
        font-size: 2rem;
    }

    .order-price_text {
        font-size: 36px;
    }

    .voice p,
    .p-accordion__main {
        font-size: 18px;
    }

    .steps h2 {
        font-size: 2.5rem;

    }

    .steps .electiric-point-point {
        font-size: 21px;
    }

    .electiric-point {
        font-size: 20px;
    }

    .p-accordion__head {
        font-size: 19px;
    }

    .steps .electiric-point-point {
        font-size: 16px;
    }

    .header_button img {
        width: 30px;
        margin-right: 20px;
    }

    .works-item {

        margin-bottom: 30px;
    }

    .polygon img {
        width: 20%;
    }

    .point-text {
        height: auto;
    }

    .point-text p:last-child {
        margin-top: 20px;
        text-align: left;
    }

    .link {
        margin-top: 20px;
    }

    .sp-non-flex {
        display: none;
    }

    .sp-header {
        display: flex;
        justify-content: space-between;
    }

    .sp-header-btn {
        width: 30%;
        padding: 20px 10px;
        color: #fff;
    }

    .sp-header-btn {
        width: 95%;
        padding: 0px 10px 4px 10px;
        color: #fff;
        font-size: 11px;
        text-align: center;
        letter-spacing: -1.2px;
        margin: 0 3px;
        transition: all 0.3s;
    }
    .sp-header a{
        width: 100%;
    }
    .color_red {
        background-color: #ff0000;
        box-shadow: 0px 3px 0px #af0101;
    }

    .color_blue {
        background-color: var(--colorblue);
        box-shadow: 0px 3px 0px #0b61a7;
        padding: 0 0 4.5px 0;
    }

    .color_green {
        background-color: #00B900;
        padding: 8.5px 0;
        box-shadow: 0px 3px 0px #028802;
    }
    .sp-header-btn:hover{
        transform: translateY(3px);
        box-shadow: none;
    }

    .sp-header-btn img {
        width: 30px;
        display: block;
        text-align: center;
        margin: 5px auto;

    }
    .column{
        flex-direction: column;
    }
    .topimg img.sp-non {
        display: none;
    }

    .topimg img.sp-block {
        display: block;
    }
}

@media screen and (max-width:740px) {
    .topimg img {

        margin: 200px auto 0 auto;
    }
}

@media screen and (max-width:739px) {
    .header-flex {
        justify-content: space-between;
        margin-bottom: 15px;
    }

    .topimg img {
        margin: 168px auto 0 auto;
    }

    h2 {
        font-size: 1.3rem;
    }



    .tel {
        padding: 6px 18px;
    }

    .tel p {
        font-size: 15px;
        margin-top: 0;
    }

    .header_button {
        padding: 16px 24px 16px 25px;
        font-size: 11px;
        margin: 5px 6px 5px 16px;
    }

    .header_button img {
        width: 19px;
        margin-right:
            5px;
    }

    header {
        padding: 10px 12px;
    }

    .payment {
        width: 39%;
    }

    .detail-table th {
        font-size: 20px;
    }

    .detail-table td {
        font-size: 18px;
        vertical-align: middle;
    }

    .electiric-point {
        background-color: aliceblue;
    }

    .warrie__box p{
        font-size: 1rem;
    }
    .reason_box{
        width: 100%;
        margin-bottom: 30px;
    }
    #flow img {
        width:100%;
    }
    .flow dt{
        font-size: 1.2rem;
    }
    .flow dd{
        font-size: 1rem;
    }
    #flow h2{
        padding: 10px 25px;
    }
    .support_box img {
        width: 90%;
    }
    #support h2, #voice h2{
        font-size: 1.2rem;
    }
    #cta{
        padding: 40px 10px;
        flex-direction: column;
    }
     #cta a{
        margin-bottom: 10px;
     }
    .house_clean_text{
        width: 100%;
        margin-left: 0;
    }
    #voice h3 {
        font-size: 1rem;
    }
    #voice img{
        width: 100%;
    }
    .cell {
        font-size: 13px;
    }

}

.contact p:nth-of-type(1) {
    margin-top: 30px;
    font-size: 18px;
}

.Form {
    margin-top: 80px;
    margin-left: auto;
    margin-right: auto;
    max-width: 720px;
}

@media screen and (max-width: 480px) {
    .Form {
        margin-top: 40px;
    }
}

.Form-Item {
    width: 100%;
    display: block;
    align-items: center;
    text-align: left;
}

@media screen and (max-width: 480px) {
    .Form-Item {
        padding-left: 14px;
        padding-right: 14px;
        padding-top: 0px;
        padding-bottom: 10px;

    }

    .under-company-wrapper dt {
        font-size: 1rem;
    }

    .under-company-wrapper {
        justify-content: space-between;
    }

    .under-company-wrapper dd {
        font-size: 1rem;
    }
}

.Form-Item-Label {
    width: 100%;
    max-width: 248px;
    letter-spacing: 0.05em;
    font-weight: bold;
    font-size: 18px;
    text-align: left;
    margin-bottom: 10px;
}

.contact .Form-Btn p {
    margin-top: 0;
}

@media screen and (max-width: 480px) {
    .Form-Item-Label {
        max-width: inherit;
        display: flex;
        align-items: center;
        font-size: 15px;
    }
}

@media screen and (max-width: 480px) {
    .Form-Item-Label.isMsg {
        margin-top: 0;
    }
}

.Form-Item-Label-Required {
    margin-right: 8px;
    padding-top: 5px;
    padding-bottom: 3px;
    width: 48px;
    display: inline-block;
    text-align: center;
    background: red;
    margin-left: 10px;
    color: #fff;
    font-size: 14px;
}

@media screen and (max-width: 480px) {
    .Form-Item-Label-Required {
        border-radius: 4px;
        padding-top: 4px;
        padding-bottom: 4px;
        width: 32px;
        font-size: 10px;
    }
}

.Form-Item-Input {
    border: 1px solid #ddd;
    border-radius: 6px;
    padding-left: 1em;
    padding-right: 1em;
    height: 48px;
    flex: 1;
    width: 100%;
    background: #eaedf2;
    font-size: 18px;
}

@media screen and (max-width: 480px) {
    .Form-Item-Input {
        margin-left: 0;
        margin-top: 18px;
        height: 40px;
        flex: inherit;
        font-size: 15px;
    }
}

.wpcf7-textarea {
    border: 1px solid #ddd;
    border-radius: 6px;
    padding-left: 1em;
    padding-right: 1em;
    height: 216px;
    flex: 1;
    width: 100%;
    background: #eaedf2;
    font-size: 18px;
}

@media screen and (max-width: 480px) {
    .wpcf7-textarea {
        margin-top: 18px;
        margin-left: 0;
        height: 200px;
        flex: inherit;
        font-size: 15px;
    }
}

.Form-Btn {
    border-radius: 6px;
    margin-top: 32px;
    margin-left: auto;
    margin-right: auto;
    padding-top: 20px;
    padding-bottom: 20px;
    width: 280px;
    display: block;
    letter-spacing: 0.05em;
    background: #5bc8ac;
    color: #fff;
    font-weight: bold;
    font-size: 20px;
}

@media screen and (max-width: 480px) {
    .Form-Btn {
        margin-top: 24px;
        padding-top: 28px;
        padding-bottom: 28px;
        width: 100%;
        font-size: 16px;
    }
}

input[type=checkbox],
input[type=radio] {
    appearance: auto;
    transform: scale(1.5);
    margin: 0 6px 0 0;
}

.wpcf7-checkbox {
    display: block;
    text-align: left;
}

.filter-coment img {
    width: 100%;
}

@media screen and (max-width:390px) {
    .tel {
        padding: 0px 18px;
    }

    .header_button {
        padding: 14px 11px;
        font-size: 11px;
        margin: 5px 16px;
    }

    .detail-table::before {
        width: 23%;
        padding: 10px 7px;
        top: -36px;
        font-size: 13px;
    }

    .onepoint {
        font-size: 17px;
        margin-left: 26%;
    }

    .topimg img {
        margin: 110px auto 0 auto;
    }
}

@media screen and (max-width:375px) {
    .tel {
        padding: 0px 18px;
    }

    .header_button {
        padding: 14px 11px;
        font-size: 11px;
        margin: 5px 16px;
    }

    .detail-table::before {
        width: 23%;
        padding: 10px 7px;
        top: -36px;
        font-size: 13px;
    }

    .onepoint {
        font-size: 17px;
        margin-left: 26%;
    }
    .color_red{
        letter-spacing: -1.9px;
    }
}

