@charset "UTF-8";
/*
Theme Name: libyane.com
Theme URI: https://libyane.com/
Description: pcbrain
Version: 1.0
Author: pcbrain.co.jp
*/

/* YUI fonts.css - font size設定
----------------------------------------------------------- */
@import url("css/cssfonts-min.css");
/* default style - リセット及びbody基本設定
----------------------------------------------------------- */
@import url("css/default.css");
/* all style
----------------------------------------------------------- */
@import url("css/style.css");

:root {
    --color-white: #fff;
    --color-font: #333;
    --color-main: #f18101;
    --color-green: #10A73B;
    --color-red: #db2a33;
    --color-yellow: #fff001;
    --color-blue: #083691;
    --color-gray: #ccc;
    --color-gray-white: #f9f9f9;

}

body {
    min-width: 1100px;
    /*コンテンツ横幅を指定する（スマホ閲覧時の背景欠けを防ぐ）*/
    overflow-x: hidden;
    font-size: 16px;
    font-family: 'Roboto', 'Noto Sans JP', sans-serif;
    font-weight: normal;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

.inner {
    width: 1100px;
    margin: 0 auto;
    position: relative;
    overflow: hidden;
    padding: 20px 0;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

.inner--bottomnone {
    width: 1100px;
    margin: 0 auto;
    position: relative;
    overflow: hidden;
    padding: 50px 0;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

.childMainv {
    max-width: 100%;
    height: auto;
}

/* article {
    padding: 20px 0;
} */

/*------------- tmp -------------*/
.tmp img {
    display: block;
    margin: 0 auto;
}

.bg01 {
    background: url(./img/bg_beige02.png) center center;
}

.bg02 {
    border-top: #77aae0 4px solid;
}

.bg03 {
    background: url(./img/bg_beige.png) center center;
}

.bg04 {
    position: relative;
    background: url(./img/bg_color01.png) no-repeat 10% top, url(./img/bg_color02.png) no-repeat 90% bottom;
}

.bg05 {
    background: url(./img/bg_beige02.png) center center;
}

.bg_green {
    background: url(./img/bg_new_green.png) center center;
}

.bg_blue {
    background: url(./img/bg_beige_blue.png) center center;
}

.btn {
    display: inline-block;
}

.btnC {
    text-align: center;
    display: block;
}

.btnC a {
    display: inline-block !important;
    text-align: center;
}

.btnR {
    display: block;
    float: right;
}

.btn a {
    display: block;
    border-radius: 50px;
    color: var(--color-white) !important;
    font-size: 16px;
    position: relative;
    padding: 10px 70px 10px 50px;
    text-decoration: none;
    text-align: center;
    background: var(--color-main);
    text-decoration: none !important;
}

.btn a:hover {
    box-shadow: 0px 0px 0px 2px var(--color-main) inset, 0px 0px 0px 3px var(--color-white) inset;
    transition: 0.4s;
}

.btn a:after {
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    font-family: "Font Awesome 5 Free";
    content: '\f138';
    font-weight: 900;
    font-size: 14px;
    right: 20px;
    height: 14px;
    line-height: 1;
}

.btnDetail {
    position: relative;
    text-align: center;
    margin: 10px 0 0;

    span {
        font-size: 16px;
        font-weight: bold;
        background: var(--color-main);
        padding: 3px 20px;
        transition: 0.7s;
        text-align: center;
        color: var(--color-white);
        display: inline-block;
        border-radius: 5px;
    }

    &:hover {
        opacity: 0.7;
        transition: 0.7s;
    }
}


.notice-r {
    color: var(--color-red);
}

.notice-o {
    color: var(--color-main);
}

.notice-b {
    color: var(--color-blue);
}

.notice-g {
    color: var(--color-green);
}

.tel {
    font-size: 13px;
}

.tel span {
    /*background: url(./img/common/ico_freedial03.png) no-repeat left bottom 10px;*/
    background: url(./img/ico_fdl.png) no-repeat left bottom 10px;
    background-size: 40px auto;
    font-size: 54px;
    line-height: 1;
    padding: 0 0 0 45px;
    margin: 0;
    display: block;
    font-family: 'Akshar', Gadget, sans-serif;
    font-weight: 700;
    letter-spacing: -0.1rem;
    color: var(--color-text);
}

.flex {
    display: flex;
    flex-wrap: wrap;
}

.spblock {
    display: none;
}

.spnone {
    display: block;
}

/* -----------------------------------------------------------
    header
----------------------------------------------------------- */
header {
    position: relative;

    .htxt {
        border-bottom: #ddd solid 1px;
        padding: 13px 0;
    }

    .htxt h1,
    .htxt p {
        font-size: 14px;
        font-weight: normal;
        display: block;
        width: 1100px;
        margin: 0 auto;
        padding-right: 390px;
        box-sizing: border-box;
        line-height: 1.2;
    }

    .htxt h1 span,
    .htxt p span {
        color: #23ac38;
        font-size: 16px;
    }

    .htxt p strong {
        font-weight: normal;
    }

    .inner {
        padding: 15px 0 10px 0;
        -webkit-box-sizing: border-box;
        -moz-box-sizing: border-box;
        box-sizing: border-box;
        width: 1100px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: -webkit-flex;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        -webkit-align-items: center;
        align-items: center;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        -webkit-justify-content: space-between;
        justify-content: space-between;
        overflow: visible;
    }

    .hdrLogo {
        overflow: hidden;
        margin: 0px 5px 0 0;


        a {
            margin: 6px 0 0;
            text-decoration: none;
            color: #222222;
            display: block;
            float: left;
        }

        a img {
            margin: 0 0 5px;
        }
    }

    .hdrMedal {
        max-height: 80px;
        margin-left: 10px;
    }

    .hdrContact {
        float: right;
        font-size: 14px;

        .tel {
            font-size: 15px;
            line-height: 1.4;
            text-align: right;
        }
    }

    .hdrContactBtn {
        position: absolute;
        bottom: 100%;
        right: 0;

        a {
            display: -webkit-box;
            display: -ms-flexbox;
            display: -webkit-flex;
            display: flex;
            -webkit-box-align: center;
            -ms-flex-align: center;
            -webkit-align-items: center;
            align-items: center;
            -webkit-box-pack: justify;
            -ms-flex-pack: justify;
            -webkit-justify-content: space-between;
            justify-content: space-between;
            color: #fff;
            text-decoration: none;
            background: #db2a33;
            font-size: 15px;
        }

        h3 {
            background: #10A73B;
            font-size: 15px;
            font-weight: normal;
            padding: 10px 15px;
        }

        p {
            padding: 10px 15px;
            display: -webkit-box;
            display: -ms-flexbox;
            display: -webkit-flex;
            display: flex;
            -webkit-box-align: center;
            -ms-flex-align: center;
            -webkit-align-items: center;
            align-items: center;

            img {
                margin-right: 10px;
            }
        }

    }

    .hdrBnr {
        position: relative;
        overflow: hidden;
        float: right;
        margin: -10px 0 0 5px;
        padding-top: 10px;

        li {
            -webkit-box-sizing: border-box;
            -moz-box-sizing: border-box;
            box-sizing: border-box;
            float: left;
            margin-left: 5px;
        }

        li.dgBtn {
            margin-top: -10px;
        }

        li a {
            text-decoration: none;
        }

        li span {
            border-radius: 3px;
            background: #0b3e9b;
            display: block;
            color: #ffffff;
            font-size: 16px;
            text-align: center;
            padding: 5px 0;
        }

        li:hover,
        li a:hover {
            opacity: 0.8;
            transition: 0.7s;
        }
    }

}



/* -----------------------------------------------------------
    footer
----------------------------------------------------------- */
footer {
    font-size: 13px;
    border-top: 5px solid var(--color-main);

    .ftrInfo {
        background: var(--color-main);
    }

    a,
    a:link,
    a:visited {
        color: var(--color-text);
        text-decoration: none;
    }

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

    .lead {
        font-size: 14px;
        font-weight: 700;
        line-height: 1.4;
        margin-bottom: 5px;

        &+p {
            margin-bottom: 15px;
        }
    }

    .floatL {
        margin-bottom: 30px;
    }

    nav {
        float: right;
        height: auto;
        background: none;
        margin-top: 0;
        margin-bottom: 60px;

        .ftrNav {
            position: relative;
            overflow: hidden;

            &>li {
                float: left;
                margin-left: 50px;
            }

            li ul>li {
                position: relative;
                padding-left: 13px;
            }

            li ul>li:before,
            li ul>li:after {
                display: block;
                content: '';
                position: absolute;
                top: 10px;
            }

            li ul>li:before {
                z-index: 2;
                top: 11px;
                left: 1px;
                width: 3px;
                height: 3px;
                border-right: 1px solid var(--color-white);
                border-bottom: 1px solid var(--color-white);
                -webkit-transform: rotate(-45deg);
                transform: rotate(-45deg);
            }

            li ul>li:after {
                left: 0px;
                width: 7px;
                height: 7px;
                background-color: var(--color-main);
            }

            li ul>li a {
                text-decoration: none;
            }
        }



        .ftrScroll {
            padding: 3px 0;
            background: rgba(0, 0, 0, 0.7);
            position: fixed;
            bottom: 0;
            width: 100%;
            display: none;
            z-index: 100;
            font-size: 12px;
            line-height: 1.2;

            .inner {
                margin: 10px auto;
                padding: 0;
                width: 1100px;
            }

            .ftrCont {
                background: var(--color-white);
                padding: 5px 10px;
                float: left;
                display: -webkit-box;
                display: -ms-flexbox;
                display: -webkit-flex;
                display: flex;
                -webkit-box-align: center;
                -ms-flex-align: center;
                -webkit-align-items: center;
                align-items: center;
                -webkit-box-pack: justify;
                -ms-flex-pack: justify;
                -webkit-justify-content: space-between;
                justify-content: space-between;
                margin-right: 15px;

                .btnList {
                    position: relative;
                    overflow: hidden;
                    display: -webkit-box;
                    display: -ms-flexbox;
                    display: -webkit-flex;
                    display: flex;
                    -webkit-box-align: center;
                    -ms-flex-align: center;
                    -webkit-align-items: stretch;
                    align-items: stretch;
                }

                .btnList li {
                    float: left;
                    margin-left: 12px;
                    width: 198px;
                    font-size: 20px;
                    font-weight: normal;
                    border-radius: 5px;
                    -webkit-box-sizing: border-box;
                    -moz-box-sizing: border-box;
                    box-sizing: border-box;
                    overflow: hidden;

                    a {
                        padding: 10px 0;
                        display: block;
                        color: var(--color-white);
                        text-decoration: none;
                        position: relative;
                        text-align: center;
                        display: -webkit-box;
                        display: -ms-flexbox;
                        display: -webkit-flex;
                        display: flex;
                        -webkit-box-align: center;
                        -ms-flex-align: center;
                        -webkit-align-items: center;
                        align-items: center;
                        -webkit-box-pack: center;
                        -ms-flex-pack: center;
                        -webkit-justify-content: center;
                        justify-content: center;
                    }


                    a:hover {
                        background: rgba(255, 255, 255, 0.3);
                        transition: 0.7s;
                    }

                    &.ftrDiagnosis a {
                        background-color: #ef8042;
                        border: #ef8042 1px solid;
                        box-shadow: 0 3px 0 rgb(255 255 255 / 50%) inset;
                    }

                    &.ftrShowroom a {
                        background-color: #db2a33;
                        border: #db2a33 1px solid;
                        box-shadow: 0 3px 0 rgb(255 255 255 / 50%) inset;
                    }


                    &.ftrContact a {
                        background-color: #4682b4;
                        border: #4682b4 1px solid;
                        box-shadow: 0 3px 0 rgb(255 255 255 / 50%) inset;
                    }

                    &.ftrTel {
                        display: none;
                    }

                    img {
                        margin-right: 10px;
                    }
                }




            }

            .catchTtl {
                margin: 0 10px 0 0 !important;
                background: none !important;

                li {
                    background: #db2a33;
                    color: #fff;
                    padding: 2px 10px;
                    width: auto;
                    margin: 0 0 1px;
                    border-radius: 3px;
                    font-size: 15px;
                    font-weight: normal;
                    float: none;
                }
            }


            .tel {
                display: inline-block;
                float: left;
                margin-right: 10px;
                color: var(--color-text);
                font-size: 11px;
                line-height: 1;

                span {
                    padding: 0 0 0 30px;
                    font-size: 44px;
                    line-height: 1;
                    display: block;
                    background-size: 25px;
                    background-position: left 0 bottom 8px;
                    padding-top: 10px
                }
            }

            .pageTop a {
                border: var(--color-white) solid 1px;
                width: 76px;
                height: 68px;
                text-align: center;
                display: table-cell;
                vertical-align: middle;
                box-sizing: border-box;
            }

            .pageTop a:hover img {
                filter: alpha(opacity=80);
                opacity: 0.8;
            }

            /* TOP右下 キャンペーンバナー */
            camBnrFix {
                position: absolute;
                content: "";
                right: 0;
                top: -100px;
                width: 240px;
                height: 90px;
            }

            .camBnrFix * {
                width: 100%;
                height: 100%;
            }

        }

    }

    .copyRight {
        clear: both;
        text-align: right;
    }
}


/* -----------------------------------------------------------
    nav
----------------------------------------------------------- */
header {
    nav {
        position: relative;
        height: 90px;

        /*デザインに調整*/
        ul#gNav {
            height: 64px;
            margin: 0 auto 0;
            width: 1100px;
            position: relative;
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding-top: 5px;

            &>li {
                border-right: #ddd solid 1px;
                display: block;
                min-width: 157px;
                position: relative;
                height: 100%;
                box-sizing: border-box;
                height: 64px;

                &:first-child {
                    border-left: #ddd solid 1px;
                }
            }

            &>li>a {
                padding: 0;
                height: 64px;
                display: block;
                position: relative;
                width: 100%;
                text-align: center;
                text-decoration: none;
                font-size: 14px;
                line-height: 1.2;
                vertical-align: middle;
                color: #222222;
                font-weight: bold;
            }

            &>li img {
                display: block;
                margin: 5px auto 5px;
                height: 40px;
                width: auto;
            }


            &>li>ul {
                position: absolute;
                top: 92px;
                left: 0;
                z-index: 1;
                min-width: 100%;
                height: 0;
                width: auto;
            }

            &>li>ul>li {
                visibility: hidden;
                overflow: hidden;
                width: auto;
                /*サブメニューの幅*/
                height: 0;
                background: rgba(45, 41, 32, 0.8);
                border-bottom: solid 1px;
                border-bottom-color: rgba(255, 255, 255, 0.8);
                font-size: 13px;
                transition: 0.7s;
                float: none;
                font-weight: normal;
                text-shadow: none;
            }

            li ul li a {
                height: auto;
                border-bottom: none;
                height: 39px;
                display: -webkit-box;
                display: -ms-flexbox;
                display: -webkit-flex;
                display: flex;
                -ms-align-items: center;
                align-items: center;
                justify-content: center;
            }

            li ul li a:before,
            li ul li a:after {
                display: none;
            }

            li ul li a:link,
            li ul li a:visited {
                color: #ffffff;
                text-decoration: none;
            }

            li ul li:hover,
            li ul>li a:hover {
                color: #f1d200 !important;
                transition: 0.7s;
            }

            li:hover ul li,
            li a:hover ul li {
                visibility: visible;
                overflow: visible;
                height: 39px;
                /*サブメニューの高さ*/
            }

            &>li.showroomNav:hover {
                opacity: 0.7;
                transition: 0.7s;
            }

            &>li.showroomNav a span {
                background: #e13131;
                color: #fff;
                display: block;

                position: absolute;
                height: 20px;
                bottom: 0;
                width: 100%;
            }

            &>li.showroomNav::before {
                content: url(./img/common/gnav_sr_bg.png);
                display: block;
                position: absolute;
                bottom: -6px;
                left: 0;
                margin: auto;
            }
        }


    }
}






/*-------------
#mainv
--------------*/
#mainv {
    margin-bottom: 0;
    z-index: 0;
    overflow: hidden;

    img {
        width: 100%;
        height: auto;
    }

    a:hover img {
        opacity: inherit;
    }
}

.contents {
    width: 1100px;
    margin: 50px auto;
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;

}

.main {
    width: 800px;

    img {
        max-width: 100%;
        height: auto;
    }
}

.sidebar {
    width: 270px;
    margin-top: 0 !important;
    order: -1;

    .sideCont {
        margin-bottom: 40px;

        &:last-ot-type {
            margin-bottom: 0;
        }
    }

    .sideTtl {
        color: var(--color-white);
        background: var(--color-main);
        font-size: 20px;
        padding: 10px;
        line-height: 1.2;
        font-weight: 700;
    }

    .sideList {
        border: 5px solid var(--color-gray);
        padding: 10px 5px;

        li {
            margin-bottom: 10px;
            padding-bottom: 10px;
            border-bottom: 1px solid var(--color-gray);

            &:last-of-type {
                border-bottom: none;
                padding-bottom: 0;
                margin-bottom: 0;
            }
        }

        li a {
            text-decoration: none;
            color: var(--color-font);
            display: flex;
            flex-flow: row nowrap;
        }

        .sideImg {
            width: 72px;
            height: 72px;
            background: var(--color-gray);
            overflow: hidden;
            margin-right: 10px;

            img {
                width: 100%;
                height: 100%;
                object-fit: cover;
            }
        }

        .txtWrap {
            width: calc(100% - 82px);

            p {
                font-size: 13px;
                font-weight: 700;
            }

            .title {
                text-decoration: underline;
                white-space: nowrap;
                text-overflow: ellipsis;
                overflow: hidden;
            }
        }
    }

    .sideCatList {
        border: 5px solid var(--color-gray);
        padding: 10px 5px;

        li {
            padding-left: 1.5em;
            margin-bottom: 0.5em;
            position: relative;

            &::before,
            &::after {
                position: absolute;
                content: "";
                top: 50%;
            }

            &::before {
                left: 0;
                width: 1em;
                height: 1em;
                background: var(--color-main);
                border-radius: 50%;
                transform: translateY(-50%);
            }

            &::after {
                left: 3px;
                width: 5px;
                height: 5px;
                border-top: 2px solid var(--color-white);
                border-right: 2px solid var(--color-white);
                transform: translateY(-50%) rotate(45deg);
            }

            &:last-of-type {
                margin-bottom: 0;
            }

            a {
                text-decoration: none;
                color: var(--color-text);
                font-weight: 700;
                transition: ease 0.3s;

                &:hover {
                    color: var(--color-main);
                }

            }
        }
    }

}

/*------------------------------------------
  TOP
--------------------------------------------*/
#top {
    section {
        margin-top: 60px;

        &:first-of-type {
            margin-top: 0;
        }
    }
}

.top_nayami {
    background: var(--color-gray-white);
    padding: 30px 30px 0 30px;

    h2 {
        font-size: 32px;
        font-weight: bold;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 10px;

        span {
            padding: 10px 25px;
            border-radius: 50vw;
            background: var(--color-blue);
            font-size: 20px;
            color: #fff;
        }
    }

    .flex {
        justify-content: space-between;
        margin-top: 25px;

        ul {
            width: 50%;
            margin-bottom: 30px;

            i {
                font-size: 18px;
                line-height: 1.4;
                position: relative;
                padding-left: 1.5em;
                margin-bottom: 10px;

                &:before {
                    position: absolute;
                    content: "";
                    background: url(./img/check_box.png) no-repeat;
                    width: 18px;
                    height: 16px;
                    background-size: contain;
                    top: 3px;
                    left: 0;
                }

                b {
                    color: var(--color-red);
                }
            }
        }

        figure {
            width: 45%;
            margin-bottom: 0;
        }
    }
}

.top_attention {
    padding: 30px;
    background: var(--color-yellow);

    h2 {
        img {
            width: min(650px, 100%);
        }
    }

    .flex {
        justify-content: space-between;
        margin-top: 30px;

        figure {
            width: 45%;
        }

        .txt_box {
            width: 50%;
        }
    }
}


.top_hikaku {
    h2 {
        img {
            width: min(650px, 100%);
            margin: auto;
            display: block;
        }
    }

    picture {
        display: block;
        margin-top: 15px;
    }
}

/*------------------------------------------
  footerCta.php
--------------------------------------------*/
.wpcf7-form {
    padding: 0;
}

input[type=button],
input[type=submit] {
    -webkit-box-sizing: border-box;
    -webkit-appearance: button;
    -moz-appearance: button;
    appearance: button
}

input[type=button]::-webkit-search-decoration,
input[type=submit]::-webkit-search-decoration {
    display: none
}

input[type=button]::focus,
input[type=submit]::focus {
    outline-offset: -2px
}

input[type=date],
input[type=email],
input[type=number],
input[type=password],
input[type=tel],
input[type=text],
input[type=url],
select,
textarea {
    font-size: 15px;
    box-sizing: border-box;
    border: 1px solid var(--color-gray);
    border-radius: 10px;
    padding: .8em 1em;
    margin: 0 0 5px;
    width: 100%
}

input[type=file] {
    margin: 5px 0
}

input[type=submit] {
    font-size: 20px;
    font-weight: 700;
    border: 1px solid var(--color-main);
    background-color: var(--color-main);
    color: #fff;
    padding: .5em 2em;
    border-radius: 10px;
}

input[type=submit]:hover {
    color: #fff;
    cursor: pointer;
    opacity: 0.7;
}

input[type=date],
input[type=email],
input[type=number],
input[type=password],
input[type=tel],
input[type=text],
input[type=url],
select,
textarea {
    font-size: 12px;
}

.wpcf7-form .must {
    color: #fff;
    font-weight: normal;
    background: var(--color-red);
    margin-left: 0;
    font-size: 12px;
    padding: 0px 10px;
    display: inline-block;
    line-height: 2;
    float: right;
}

.wpcf7-form .nini {
    background: #999;
}

/*チェックボックスズレ解消*/



/*同意ボタン調整*/
.agree_btn {
    margin: 30px 0;
}

.agree_btn div,
.agree_btn p {
    text-align: center;
}

.agree_btn div .wpcf7-list-item {
    margin: 0;
}

.agree_btn p,
.agree_btn p a {
    font-size: 90%;
}

/*送信ボタン調整*/
.SendBtn {
    text-align: center;
}

.SendBtn input[type="submit"],
.SendBtn input[type="reset"],
.SendBtn input[type="button"] {
    padding: 15px 100px;
    border-radius: 0vw;
    background-color: var(--color-main);
    border: 3px solid var(--color-main);
    transition: all ease .3s;
}

.SendBtn input[type="submit"]:hover,
.SendBtn input[type="reset"]:hover,
.SendBtn input[type="button"]:hover {
    color: var(--color-main);
    background: transparent;
    transition: all ease .3s;
}

.wpcf7-spinner {
    display: none;
}


.ftrCta {
    background-color: #ffe7cb;
    background-image: repeating-linear-gradient(-45deg, #fff3e5, #fff3e5 11px, transparent 0, transparent 22px);
    padding: 50px 0;

    .flex {
        width: min(1100px, 90%);
        justify-content: space-between;
        margin: 0 auto;

        figure {
            width: 60%;
            margin-bottom: 0;
            img {
                max-width: 100%;
                height: auto;
            }
        }

        .contactWrap {
            width: 38%;
            margin-left: 2%;
            background: #efefef;
            box-sizing: border-box;
            border: 1px solid #ddd;
            padding-bottom: 20px;

            h2 {
                font-size: 22px;
                font-weight: 900;
                color: #fff;
                text-align: center;
                background-color: #e60a11;
                padding: 8px 5px 10px;

                span {
                    color: #fff000;
                }
            }

            table {
                display: block;
                padding: 0 20px;
                box-sizing: border-box;
                margin-bottom: 20px;

                tr {
                    border-bottom: 1px solid var(--color-gray);
                    padding: 5px 0;
                    display: flex;
                    justify-content: space-between;
                    align-items: center;
                }

                th {
                    border: none;
                    text-align: left;
                    padding: 12px 0;
                    width: 40%;

                    p {
                        display: flex;
                        justify-content: space-between;
                        align-items: center;
                        font-weight: bold;
                    }
                }

                td {
                    border: none;
                    padding: 12px 0;
                    text-align: right;

                    p {
                        margin-left: auto;
                        width: 90%;

                        input {
                            margin-bottom: 0;
                        }
                    }
                }
            }

            .Send {
                p {
                    text-align: center;
                    padding: 0 20px;

                    input {
                        width: 100%;
                        padding: 8px 5px 8px;
                        text-align: center;
                        color: #FFF;
                        font-size: 20px;
                        font-weight: 900;
                        border-radius: 5px;
                        border: solid 3px var(--color-red);
                        background: -webkit-linear-gradient(bottom, var(--color-red), rgb(248, 17, 30));
                        background: linear-gradient(0deg, var(--color-red), rgb(248, 17, 30));
                    }
                }
            }
        }
    }
}

/*------------------------------------------
  child page - settings
--------------------------------------------*/
.pageTitle {
    background: var(--color-gray-white);
    padding: 30px 0;
    height: 250px;
    box-sizing: border-box;

    .inner {
        height: 100%;
        width: 100%;
        padding: 0;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .hone,
    h1 {
        font-size: 40px;
        font-weight: bold;
        display: flex;
        color: var(--color-white);
        flex-direction: column;
        align-items: center;
        line-height: 1.2;
        gap: 10px;

        span {
            font-size: 16px;
            display: block;
        }
    }
}

.pagePath {
    background: var(--color-gray-white);

    p {
        margin: 0 auto;
        padding: 3px 0;
        width: 1100px;

        a {
            text-decoration: none;
            color: var(--color-text);

            &:hover {
                color: var(--color-main);
            }
        }

    }
}

.common_h2 {
    color: #FFF;
    background: var(--color-blue);
    font-size: 28px;
    padding: 15px 20px;
    margin: 0 auto 25px;
    position: relative;
    border-radius: 5px;
    text-align: left;
    overflow: hidden;
    line-height: 1.2;
    z-index: 1;
}


/*------------------------------------------
  company - page
--------------------------------------------*/
.companyPage {
    section {
        margin-bottom: 60px;

        &:last-of-type {
            margin-bottom: 0;
        }
    }

    table {
        border: 5px solid #eee;
        width: 100%;

        th {
            padding: 15px;
            border: none;
            border-bottom: 1px solid var(--color-gray);
            text-align: center;
            width: 20%;
        }

        td {
            padding: 15px;
            border: none;
            border-bottom: 1px solid var(--color-gray);
        }
    }

    .grid {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        margin-bottom: 20px;
        gap: 4%;

        figure {
            aspect-ratio: 3/2;

            img {
                width: 100%;
                height: 100%;
                object-fit: cover;
            }
        }
    }

    iframe {
        width: 100%;
        height: auto;
        aspect-ratio: 3/2;
    }

    .companyMessage {
        h3 {
            margin-bottom: 1em;
        }
    }
}

.companyMessage {
    .flex {
        justify-content: space-between;

        .txt_box {
            width: 55%;

            .ttl {
                font-size: 20px;
                font-weight: bold;
                margin-bottom: 20px;
            }
        }

        .img_box {
            width: 40%;

            .name span {
                display: block;
                line-height: 1;
                text-align: right;
                margin-top: 10px;

                b {
                    font-size: 120%;
                    margin-left: 5px;
                    display: inline-block;
                }
            }
        }
    }
}

/*------------------------------------------
    reason - page
--------------------------------------------*/
.reasonPage {
    .reasonLead {
        margin-bottom: 60px;
    }

    .flex {
        justify-content: space-between;

        .txt_box {
            width: 48%;

            p.ttl {
                font-size: 20px;
                font-weight: bold;
                border-bottom: 2px solid var(--color-main);
                padding-bottom: 15px;
                margin-bottom: 15px;
            }
        }

        figure {
            width: 48%;
        }

        .row-reverse {
            flex-direction: row-reverse;
        }
    }

    ul.feature_ul {
        li {
            margin: 0;

            p.ttl_sub {
                padding: 10px 15px;
                border-left: 5px solid var(--color-blue);
                background: #f5f5f5;
                font-size: 20px;
                font-weight: bold;
                margin-bottom: 15px;
            }

            &:not(:first-child) {
                margin-top: 50px;
            }
        }
    }
}

/*------------------------------------------
    menu - page
--------------------------------------------*/
.menuPage {

    .menuCover,
    .menuPaint {
        margin-top: 60px;
    }

    .flex {
        justify-content: space-between;

        .txt_box {
            width: 48%;

            p.ttl {
                font-size: 20px;
                font-weight: bold;
                border-bottom: 2px solid var(--color-main);
                padding-bottom: 15px;
                margin-bottom: 15px;
            }
        }

        figure {
            width: 48%;
        }

        .row-reverse {
            flex-direction: row-reverse;
        }
    }
}

/*------------------------------------------
    contact - page
--------------------------------------------*/
.contactPage {

    table,
    table th,
    table td {
        border: none;
    }

    table {
        margin-bottom: 0;
        width: 100%;

        th,
        td {
            padding: 20px 25px;
            box-sizing: border-box;
            font-size: 16px;
        }

        th {
            width: 35%;
            vertical-align: middle;
            background: #f7f7f7;
            text-align: left;

            img {
                display: inline-block;
            }
        }

        td {
            width: 65%;
        }

    }

    table tr {
        border-bottom: 1px solid var(--color-gray);

        &:first-child {
            border-top: 1px solid var(--color-gray);
        }
    }
}

.wpcf7-form .must {
    color: #fff;
    font-weight: normal;
    background: var(--color-red);
    margin-left: 0;
    font-size: 12px;
    padding: 0px 10px;
    display: inline-block;
    line-height: 2;
    float: right;
}

.wpcf7-form .nini {
    background: #999;
}



@media screen and (max-width:800px) {

    .contactPage table tr {
        display: flex;
        flex-direction: column;
    }

    .contactPage table th,
    .contactPage table td {
        padding: 15px 20px;
        text-align: left;
        font-size: 14px;
        width: 100%;
    }
}

/*------------------------------------------
    policy - page
--------------------------------------------*/
.policyPage {
    h3 {
        font-size: 22px;
        font-weight: bold;
        margin: 40px 0 10px;
        line-height: 1.5;
    }

    h4 {
        margin: 30px 0 10px;
        font-size: 18px;
        font-weight: 500;
    }

    p {
        font-size: 16px;
        line-height: 1.6;
    }

    ul li {
        line-height: 1.6;
        position: relative;
        padding-left: 1em;
        font-size: 15px;

        &::before {
            position: absolute;
            content: "・";
            top: 0;
            left: 0;
        }
    }

}


/*------------------------------------------
    archive - common
--------------------------------------------*/
.archiveSec {
    margin-bottom: 60px;
}

.archiveList {}

.archiveListItem {
    width: 32%;
    margin: 0 2% 30px 0;

    &:nth-of-type(3n) {
        margin-right: 0;
    }

    a {
        text-decoration: none;
        color: var(--color-text);

        .imgWrap {
            width: 100%;
            height: 180px;

            img {
                width: 100%;
                height: 100%;
                object-fit: cover;
            }
        }

        .txtWrap {
            margin-top: 10px;
            line-height: 1.3;

            h3 {
                font-size: 18px;
            }

            .time {
                font-size: 12px;
                margin-top: 0.3em;
            }
            .price {
                font-weight: 700;
                span {
                    display: inline-block;
                    font-size: 13px;
                    margin-right: 0.5em;
                    border-radius: 3px;
                    color: var(--color-white);
                    background: var(--color-red);
                    padding: 0 5px;
                }
            }
        }
    }
}

.wp-pagenavi {
    text-align: center;

    a {
        border-radius: 5px;
        background: var(--color-main);
        padding: 0 5px;
        text-align: center;
        transition: 0.7s;
        border: none;
        display: inline-block;
        overflow: inherit;

        &:link,
        &:visited {
            color: var(--color-white);
            text-decoration: none;
        }

        &:hover {
            color: var(--color-white);
            opacity: 0.7;
        }
    }

    span {
        border-radius: 5px;
        padding: 0 5px;
        text-align: center;
        transition: 0.7s;
    }

    .pages,
    .last {
        display: inline-block;
    }


    a:hover,
    .current {
        border-color: var(--color-gray);
        display: inline-block;
    }

}




/*------------------------------------------
    single - common
--------------------------------------------*/
.pagenavi {
    border-bottom: dotted 1px var(--color-gray);
    padding: 20px 0;
    margin: 0 auto 40px;
    text-align: center;
    position: relative;

    ul {
        position: relative;
        overflow: hidden;
        height: 40px;
        margin: 0;
    }

    a {
        display: inline-block;
        border-radius: 5px;
        background: var(--color-main);
        /*border:solid 3px #338593;*/
        padding: 5px 5px;
        width: 130px;
        text-align: center;
        transition: 0.7s;
        position: relative;
        padding: 5px 25px 5px 5px;
        text-decoration: none;
        -webkit-box-sizing: border-box;
        -moz-box-sizing: border-box;
        box-sizing: border-box;

        &:link,
        &:hover,
        &:visited {
            color: var(--color-white);
            text-decoration: none;
        }

        &:hover {
            opacity: 0.75;
            transition: 0.7s;
        }

        &::before,
        &::after {
            position: absolute;
            top: 0;
            bottom: 0;
            right: 10px;
            margin: auto;
            content: "";
            vertical-align: middle;
        }

        &::before {
            width: 17px;
            height: 17px;
            -webkit-border-radius: 50%;
            border-radius: 50%;
            background: var(--color-white);
        }

        &::after {
            right: 16px;
            width: 5px;
            height: 5px;
            border-top: 3px solid var(--color-main);
            border-right: 3px solid var(--color-main);
            -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
        }
    }

    .next a {
        padding: 5px 5px 5px 25px;

        &::before,
        &::after {
            left: 10px;
            right: inherit;
        }

        &::after {
            left: 14px;
            right: inherit;
            -webkit-transform: rotate(-135deg);
            transform: rotate(-135deg);
        }
    }




    li {
        padding: 0;
        margin: 0;
        background: none;
        display: block;
        font-weight: bold;
        position: absolute;

        &::before,
        &::after {
            content: none;
        }
    }


    .prev {
        position: absolute;
        right: 0;
    }

    .list {
        position: absolute;
        left: 50%;
        margin-left: -70px;

        a {
            padding: 5px;

            &::before,
            &::after {
                content: none;
            }
        }

    }

    .next {
        position: absolute;
        left: 0;
    }
}

.singleDetails {
    .infoBox {
        text-align: right;
    }

    .singleMainv {
        text-align: center;
        margin: 20px 0;
    }

    .single_h2 {
        color: var(--color-white);
        background: var(--color-blue);
        font-size: 24px;
        padding: 10px 15px;
        margin: 40px auto 25px;
        position: relative;
        border-radius: 5px;
        text-align: left;
        overflow: hidden;
        line-height: 1.2;
        z-index: 1;
    }

    .single_h3 {
        font-size: 20px;
        font-weight: bold;
        color: var(--color-font);
        border-bottom: 3px solid var(--color-main);
        padding-bottom: 5px;
        margin: 20px 0 10px 0;

        &:first-child {
            margin-top: 0;
        }
    }

    table {
        margin: 0;
        width: 100%;
        border: 5px solid var(--color-gray);

        th {
            border: none;
            padding: 15px;
            width: 20%;
            text-align: left;
        }

        td {
            border: none;
            padding: 15px;
        }

        tr {
            border-bottom: 1px solid var(--color-gray);
        }
    }
}

/*------------------------------------------
single - works
--------------------------------------------*/
.singleWorks {
    .mainPhotoBox {
        margin-top: 20px;

        .beforeAfterPhoto {
            width: 45%;
            position: relative;

            .photoBox {
                height: 260px;
                width: 100%;
                background: var(--color-gray-white);
                text-align: center;
                display: block;
            }

            img {
                width: auto;
                height: 100%;
            }

            .photoTtl {
                position: absolute;
                top: 0;
                left: 0;
                width: 100px;
                font-size: 16px;
                line-height: 1.2;
                text-align: center;
                padding: 0.3em 0;
                color: #fff;

                &.before {
                    background: var(--color-blue);
                }

                &.after {
                    background: var(--color-red);
                }
            }
        }

        .afterPhoto {
            margin-left: 10%;
            position: relative;

            &::before {
                content: "";
                position: absolute;
                top: 50%;
                left: -50px;
                transform: translateY(-50%);
                border-left: 30px solid var(--color-main);
                border-top: 30px solid transparent;
                border-bottom: 30px solid transparent;
            }
        }
    }

    .worksOtherPhotos {}

    .worksOtherPhoto {
        width: 49%;
        margin: 0 2% 20px 0;
        position: relative;

        &:nth-of-type(2n) {
            margin-right: 0;
        }

        .beforeAfterPhoto {
            position: relative;
            background: var(--color-gray-white);

            img {
                width: 100%;
                height: 100%;
                object-fit: cover;
            }

            .photoTtl {
                display: block;
                color: var(--color-white);
                font-weight: 700;
                font-size: 13px;
                width: 80px;
                text-align: center;
                padding: 0.2em 0;
                position: absolute;
                top: 0;
                right: 0;

                &.before {
                    background: var(--color-blue);
                }

                &.after {
                    background: var(--color-red);
                }
            }
        }

        .beforePhoto {
            width: 120px;
            height: 120px;
            position: absolute;
            left: 0;
            top: 0;
            border: 3px solid var(--color-white);
            z-index: 1;

            img {
                width: 100%;
                height: 100%;
                object-fit: cover;
            }
        }

        .afterPhoto {
            height: 240px;
            z-index: 0;
        }
    }

    .worksReportsList {
        li {
            width: 32%;
            margin: 0 2% 20px 0;

            &:nth-of-type(3n) {
                margin-right: 0;
            }

            .imgWrap {
                width: 100%;
                height: 180px;

                img {
                    width: 100%;
                    height: 100%;
                    object-fit: cover;
                }
            }

            .txtWrap {
                line-height: 1.3;
                padding-top: 10px;

                h4 {
                    font-size: 18px;
                }

            }
        }
    }

    .worksFreeComments {
        margin: 60px 0;
    }
}

/*------------------------------------------
    single - voice
--------------------------------------------*/
.voiceSummary {
    position: relative;
    overflow: hidden;
    margin: 40px 0;

    h3 {
        margin-top: 0;
    }
}


.voicephotList {
    float: left;
    width: 316px;
    margin-right: 30px;

    li {
        background: none;
        padding: 0;
        position: relative;
        margin: 0 0 20px;
        border: var(--color-gray) solid 1px;
        -webkit-box-sizing: border-box;
        -moz-box-sizing: border-box;
        box-sizing: border-box;
        width: 316px;
        height: 206px;
        overflow: hidden;

        &::before,
        &::after {
            content: none;
        }

        img {
            position: absolute;
            top: 50%;
            left: 50%;
            -webkit-transform: translate(-50%, -50%);
            -ms-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
            width: 100%;
            height: auto;
        }

        .imgLayer {
            position: absolute;
            bottom: 5px;
            right: 5px;
            transform: none;
            top: inherit;
            left: inherit;
            width: auto;
            height: auto;
        }
    }

}

.voiceData {
    margin-bottom: 60px;

    table {
        width: 100%;
        margin-bottom: 30px;
    }

    .catWrap {
        .cat {
            display: inline-block;
            margin-right: 1em;
        }
    }

}

.voice_reviewBox {
    margin-bottom: 50px;
}

.voiceReports {}

.voiceReportsList {
    li {
        width: 32%;
        margin: 0 2% 30px 0;

        &:nth-of-type(3n) {
            margin-right: 0;
        }

        .imgWrap {
            width: 100%;
            height: 180px;

            img {
                width: 100%;
                height: 100%;
                object-fit: cover;
            }
        }

        .txtWrap {
            line-height: 1.3;
            padding-top: 10px;

        }
    }
}

/*------------------------------------------
    archive - common
--------------------------------------------*/

/*------------------------------------------
    WYSIWYG Editor Styles
--------------------------------------------*/
.wysiwyg {
    line-height: 1.6;
    padding: 20px 0 40px;

    /* 見出しタグ */
    h2 {
        color: var(--color-white);
        background: var(--color-blue);
        font-size: 28px;
        padding: 15px 20px;
        margin: 0 auto 25px;
        position: relative;
        border-radius: 5px;
        text-align: left;
        overflow: hidden;
        line-height: 1.2;
        z-index: 1;
    }

    h3 {
        font-size: 24px;
        font-weight: bold;
        color: var(--color-font);
        border-bottom: 3px solid var(--color-main);
        padding-bottom: 10px;
        margin: 30px 0 20px 0;

        &:first-child {
            margin-top: 0;
        }
    }

    h4 {
        font-size: 20px;
        font-weight: bold;
        color: var(--color-font);
        border-left: 5px solid var(--color-blue);
        background: var(--color-gray-white);
        padding: 10px 15px;
        margin: 25px 0 15px 0;

        &:first-child {
            margin-top: 0;
        }
    }

    h5 {
        font-size: 18px;
        font-weight: bold;
        color: var(--color-font);
        margin: 20px 0 10px 0;

        &:first-child {
            margin-top: 0;
        }
    }

    h6 {
        font-size: 16px;
        font-weight: bold;
        color: var(--color-font);
        margin: 15px 0 8px 0;

        &:first-child {
            margin-top: 0;
        }
    }


    /* 段落 */
    p {
        overflow: hidden;
        margin-bottom: 15px;

        &:last-child {
            margin-bottom: 0;
        }
    }

    /* リスト */
    ul,
    ol {
        margin: 15px 0;
        padding-left: 20px;

        li {
            margin-bottom: 5px;
            line-height: 1.6;

            &:last-child {
                margin-bottom: 0;
            }
        }
    }

    ul li {
        position: relative;
        padding-left: 1em;

        &::before {
            position: absolute;
            content: "・";
            top: 0;
            left: 0;
            color: var(--color-main);
            font-weight: bold;
        }
    }

    /* テーブル */
    table {
        border: 5px solid var(--color-gray);
        width: 100%;
        margin: 20px 0;
        border-collapse: collapse;

        th {
            padding: 15px;
            border: none;
            border-bottom: 1px solid var(--color-gray);
            text-align: center;
            background: var(--color-gray-white);
            font-weight: bold;
        }

        td {
            padding: 15px;
            border: none;
            border-bottom: 1px solid var(--color-gray);
        }

        tr:last-child th,
        tr:last-child td {
            border-bottom: none;
        }
    }

    /* 強調表示 */
    strong,
    b {
        font-weight: bold;
        color: var(--color-font);
    }

    em,
    i {
        font-style: italic;
    }

    /* リンク */
    a {
        color: var(--color-blue);
        text-decoration: underline;
        transition: color 0.3s ease;

        &:hover {
            color: var(--color-main);
        }
    }

    /* 引用 */
    blockquote {
        margin: 20px 0;
        padding: 15px 20px;
        background: #f9f9f9;
        border-left: 5px solid var(--color-main);
        font-style: italic;

        p {
            margin: 0;
        }
    }

    /* コード */
    code {
        background: var(--color-gray-white);
        padding: 2px 4px;
        border-radius: 3px;
        font-family: 'Courier New', monospace;
        font-size: 0.9em;
    }

    pre {
        background: var(--color-gray-white);
        padding: 15px;
        border-radius: 5px;
        overflow-x: auto;
        margin: 15px 0;

        code {
            background: none;
            padding: 0;
        }
    }

    /* 画像 */
    img {
        max-width: 100%;
        height: auto;
        margin: 10px 0;

        &.alignleft {
            float: left;
            margin-right: 15px;
        }

        &.alignright {
            float: right;
        }

        &.aligncenter {
            display: block;
            margin-left: auto;
            margin-right: auto;
        }

        /* 水平線 */
        hr {
            border: none;
            border-top: 2px solid var(--color-gray);
            margin: 30px 0;
        }
    }
}