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

html {
    scroll-behavior: smooth;
}

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 {
    border-right: 1px solid #333;
    border-left: 1px solid #333;
    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;
}

.header_button {
    background-color: var(--colorblue);
    padding: 9px 50px;
    color: #fff;
    display: flex;
    justify-content: space-evenly;
    align-items: center;
    border-radius: 6px;
    margin: 18px 40px;
}


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

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

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

.topimg img {
    width: 90%;
    display: block;
    margin: 126px 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;
}

h2 span .blue {
    color: var(--colorblue);
}

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

.steps h2 {
    display: block;
}

.steps h2::after {
    position: initial;

}

.flex-section {
    display: flex;
    justify-content: space-around;
}

li {
    list-style: none;
}

.point {
    margin-top: 50px;
    width: 300px;

}

.point-header {
    background-color: var(--colorblue);
    text-align: center;
    font-weight: bold;
    padding: 15px 0;
    color: #fff;
}

.point-text {
    background-color: #EFEFEF;
    padding: 20px 10px;
    height: 240px;
}

.point-text p:first-child {
    text-align: center;
    font-weight: bold;
    font-size: 20px;
    margin-bottom: 10px;
    height: 40px;
    display: flex;

    justify-content: center;
    flex-direction: column;
}

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

}

.point-text a {
    color: #0094ff;
}

.works {
    background-image: url(../images/bg0.jpg);
    background-size: cover;
    position: relative;
}

.man1 {
    position: absolute;
    top: 100px;
    left: 5%;
    width: 14%;
}

.man2 {
    position: absolute;
    bottom: 100px;
    right: 5%;
    width: 10%;
}

.promice {
    background-image: url(../images/bg1.png);
    background-size: cover;
}

.electric {
    background-image: url(../images/bg2.png);
    background-size: cover;
    background-color: #C1E5FF;
}

.voice {
    background-image: url(../images/bg3.png);
    background-size: cover;
    background-color: #E9F6FF;
}

.link {
    display: flex;
    align-items: center;
    flex-direction: column;
    justify-content: flex-end;
}

.link a {
    display: block;
    margin-bottom: 20px;
}

.qa {
    background-color: #d0e8f8;
}

.works-area {
    margin-top: 50px;
}

.works-item {
    width: 450px;
    padding: 20px;
    background-color: #fff;
    margin-top: 30px;
    box-shadow: 2px 2px 9px silver;
    margin-bottom: 80px;
}

.works-box {
    margin-top: 30px;
    border-radius: 20px;
    text-align: center;
    font-weight: bold;
    font-size: 22px;
    color: #fff;
    padding: 10px;
}

.blue {
    background-color: #379DE7;
}

.pink {
    background-color: #FF9595;
}

.polygon {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
}

.order-price {
    margin-top: 50px;
    width: 300px;
    border: var(--colorblue);
}

.order-price_header {
    background-color: var(--colorblue);
    color: #fff;
    border-radius: 6px 6px 0 6px;
    text-align: center;
    font-size: 22px;
    font-weight: bold;
    padding: 20px 0;
}

.order-price_text {
    text-align: center;
    font-size: 22px;
    padding: 30px 0;
    font-weight: bold;
    background-color: #fff;
}

.plus {
    font-weight: bold;
    font-size: 46px;
    margin-top: 50px;
    color: var(--colorblue);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
}

.p-accordion__main {
    font-size: 1.5rem;
}

.p-accordion__main img {
    margin-bottom: 20px;
}

.center-pic {
    text-align: center;
    margin-top: 30px;
}
.center-pic-2{
    text-align: center;
    margin: 30px auto 0px auto;
}
.center-pic-2 img{
    margin: 0 auto;
}


.promice .center-pic,.promice .center-pic2 {
    margin-bottom: 20px;
}

.promice .point-header {
    padding: 20px 10px;
    height: 70px;
    display: flex;
    justify-content: center;
    flex-direction: column;
}

.promice .point-text p:first-child {
    font-size: 18px;
    font-weight: 400;
    color: #fff;
    height: auto;

}

.promice .point-text p:nth-child(2) {
    font-size: 14px;
    color: #fff;
}

.promice .point-text {
    background-color: var(--colorblue);
    padding: 28px 16px;
}

.electric ul {
    width: 60%;
    display: block;
    margin: 0 auto;
    text-decoration: none;
    margin-top: 50px;
}

.electiric-point {
    border-left: 10px solid var(--colorblue);
    background-color: #fff;
    padding: 10px;
    font-size: 37px;
    font-weight: bold;
    color: #333;
    text-align: left;
}

.electiric-point span {
    margin-right: 30px;
}

.electiric-point-point {
    color: var(--colorblue);
    font-size: 24px;
}

.electiric-point-explain {
    padding: 20px;
    font-size: 18px;
    font-weight: bold;
    text-align: left;
    line-height: 1.8;
}

.center-cont {
    display: block;
    margin: -196px auto 50px auto;
    text-align: center;

}
.spwidth li span:first-child{
    width: 12%;
    display: inline-block;
}
.second{
    width: 80%;
    display: inline-block;

}
.filter {
    background-image: url(../images/sec2_bg.jpg);
    background-position: center;
    position: relative;
    padding-bottom: 0px;
}

.filter-coment {
    text-align: center;
    display: block;
    margin: 0 auto;
}

.filter .flex-section {
    width: 95%;
    margin: 30px auto 80px auto;
}

.filter .text-box {
    margin-left: 50px;
    width: 50%;
}

.filter .text-box h3 {
    font-weight: bold;
    font-size: 45px;
}

.filter .text-box p {
    margin-top: 30px;
    font-size: 23px;
    text-align: left;
}

.filter .point-header {
    background-color: var(--colorblue);
    padding: 10px;
}

.step .flex-section {
    width: 80%;
    margin: 0 auto;
    flex-wrap: wrap;
}

.step .point {
    box-shadow: 3px 5px 8px 2px #d1cccc;
}

.step .point-text {
    background-color: white;
    height: auto;
}

.step .point-text p:first-child {
    height: auto;
    color: var(--colorblue);
}

.voice p {
    text-align: center;
    font-weight: bold;
    font-size: 33px;
    margin: 30px 0;
}

.voice .flex-section {
    justify-content: space-around;
    flex-wrap: wrap;
}

.voice-image {
    width: 600px;
}

.steps h2 {
    background-color: var(--colorblue);
    color: #fff;
    font-size: 50px;
    padding: 50px 0;
}

.steps ul {
    width: 60%;
    display: block;
    margin: 50px auto;
}

.steps .electiric-point-point {
    font-size: 40px;
    font-weight: bold;
    color: #333;
}

/* よくある質問 */
.accordion {
    margin-top: 50px;
}

.p-accordion {
    max-width: 1000px;
    margin-inline: auto;
}

.p-accordion-desc {
    font-size: 15px;
    font-weight: 700;
}

.p-accordion__head {
    cursor: pointer;
    background-color: var(--colorblue);
    display: block;
    color: white;
    padding: 15px 20px;
    margin-top: 10px;
    font-weight: bold;
    font-size: 24px;
}

.p-accordion__head-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    text-align: left;
}

.p-accordion__icon {
    display: block;
    position: relative;
    width: 24px;
    transition: transform 0.25s;
}

.p-accordion__icon:before {
    content: "";
    position: absolute;
    display: block;
    width: 15px;
    height: 2px;
    background-color: #fff;
}

.p-accordion__icon:after {
    content: "";
    position: absolute;
    display: block;
    width: 15px;
    height: 2px;
    background-color: #fff;
}

.p-accordion__icon:before {
    left: 0;
    transform: rotate(45deg);
}

.p-accordion__icon:after {
    right: 0;
    transform: rotate(-45deg);
}

.p-accordion__input input[name=p-accordion__block] {
    display: none;
}

.p-accordion__input .p-accordion__block {
    cursor: pointer;
}

.p-accordion__input .p-accordion__content {
    height: 0;
    padding: 0 20px;
    overflow: hidden;
    opacity: 0.5;
    background-color: #fff;
    transition: padding 0.25s ease, opacity 0.3s ease 0s;
}

.p-accordion__input input[name=p-accordion__block]:checked+.p-accordion__head>.p-accordion__head-inner .p-accordion__icon {
    transform: rotate(-180deg);
}

.p-accordion__input input[name=p-accordion__block]:checked+.p-accordion__head+.p-accordion__content {
    /*開閉時*/
    height: auto;
    opacity: 1;
    padding: 20px;
    border: 2px solid #CCC;
    text-align: left;
}

/* よくある質問 */

/* 会社概要 */
.under-company-list {
    border-top: 1px solid #e0dfdf;
    margin-top: 3.259452412%;
}

.under-company-wrapper {
    padding: 4% 0 4% 4%;
    border-bottom: 1px solid #e0dfdf;
    display: flex;
    justify-content: left;
}

.under-company-wrapper dt {
    font-family: 'NotoSansJP-Bold', "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "游ゴシック体", "Yu Gothic", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-weight: 800;
    font-style: normal;
    width: 20%;
}

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;
}
@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: 90%;
        display: block;
        margin: 247px auto 0 auto;
    }

    .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 5px 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;
    }

    .color_green {
        background-color: #00B900;
        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;

    }
}

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

        margin: 200px auto 0 auto;
    }
}

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

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

    h2 {
        font-size: 1.3rem;
    }

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

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

    .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;
    }
}

.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: 160px 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;
    }
}

