.koko-section {
    padding-block: 63px 80px;
}
.koko-section--bg {
    background: #f9f7f3;
}
.koko-section__text {
    line-height: 1.8;
    margin-top: 3.5rem;
}
.koko-section__ft {
    text-align: center;
    margin-top: 4.5rem;
}


/*リフォームコンシェルジュ®とは？*/

.about-reform__slider {
    margin-inline: 25px;
    margin-top: 3rem;
}

.about-reform__sliderTitle {
    font-size: 1.6rem;
    font-weight: normal;
    line-height: 1.7;
    margin-top: 2rem;
}

.about-reform__sliderItem {
    position: relative;
}

.about-reform__sliderLink {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1;
}

.about-reform__slider .slick-arrow {
    position: absolute;
    text-indent: -9999em;
    display: block;
    margin: 0;
    top: calc(50% - 10px);
    bottom: 0;
    transform: translateY(-50%);
    background: none;
    border: none;
    -webkit-appearance: none;
        -moz-appearance: none;
            appearance: none;
    width: 20px;
    height: 20px;
    z-index: 1;
    cursor: pointer;
}
.about-reform__slider .slick-arrow::before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    filter: drop-shadow(0 0 3px rgba(0, 0, 0, 0.3));
}
.about-reform__slider .slick-prev {
    right: 100%;
}
.about-reform__slider .slick-prev::before {
    content: "";
    display: inline-block;
    border-color: #EF6D22;
    border-style: solid;
    border-width: 0 2px 2px 0;
    width: 14px;
    height: 14px;
    vertical-align: middle;
    transform: rotate(135deg);
    left: 65%;
    translate: -50% -50%;
}
.about-reform__slider .slick-next {
    left: 100%;
}
.about-reform__slider .slick-next::before {
    content: "";
    display: inline-block;
    border-color: #EF6D22;
    border-style: solid;
    border-width: 0 2px 2px 0;
    width: 14px;
    height: 14px;
    vertical-align: middle;
    transform: rotate(-45deg);
    right: 65%;
    translate: 50% -50%;
}


/*リフォームコンシェルジュが選ばれる理由*/

.chosen-card-wrap {
    display: grid;
    gap: 40px;
    margin-top: 4.5rem;
}

.chosen-card {
    background: rgba(255, 255, 190, .2);
    border: 2px solid rgba(239, 109, 34, .5);
    border-radius: 11px;
    padding: 2.7rem 2.2rem;
}
.chosen-card__head {
    display: grid;
    grid-template-columns: 1fr 80px;
    gap: 1.7rem;
    align-items: center;
    border-bottom: 1px solid #ef6d22;
    padding-bottom: 10px;
}
.chosen-card__label {
    font-size: 2rem;
    font-weight: bold;
    color: #ef6d22;
}
.chosen-card__label .num {
    font-size: 3.2rem;
}
.chosen-card__title {
    font-size: 1.8rem;
    font-weight: bold;
    text-align: center;
    color: #ef6d22;
    line-height: 1.7;
    margin-top: 1.5rem;
}
.chosen-card__text {
    font-size: 1.4rem;
    line-height: 1.8;
    margin-top: 5px;
}
.chosen-card__link {
    font-size: 1.4rem;
    text-decoration: underline !important;
}

.chosen-img {
    display: grid;
    gap: 37px;
    justify-items: center;
    margin-top: 60px;
}



/*エグゼクティブリフォームコンシェルジュのご紹介*/

.ex-con-article {
    margin-top: 5.8rem;
}

.ex-con-article + .ex-con-articl {
    margin-top: 100px;
}

.ex-con-article__title {
    font-size: 1.6rem;
    font-weight: bold;
    color: #ef6d22;
    border-bottom: 1px solid #ef6d22;
    padding-bottom: 5px;
    margin-bottom: 2.7rem;
}

.ex-con-prof {
    display: grid;
    gap: 27px;
}
.ex-con-prof img {
    max-width: 210px;
    margin: auto;
}

.ex-con-faq-wrap {
    display: grid;
    gap: 3.5rem;
    margin-top: 3.7rem;
}

.ex-con-prof__content {
    line-height: 1.8;
}

.ex-con-prof__loc,
.ex-con-prof__company,
.ex-con-prof__post,
.ex-con-prof__name {
    font-size: 1.6rem;
    display: block;
}
.ex-con-prof__post {
    font-size: 1.4rem;
    margin-top: 5px;
}

.ex-con-prof__company {
    text-decoration: underline !important;
    font-weight: bold;
    margin-top: 5px;
}

.ex-con-faq-wrap {
    position: relative;
    counter-reset: faq;
}
.ex-con-faq {
    display: grid;
    grid-template-rows: subgrid;
    grid-row: span 2;
    gap: 0;
}
.ex-con-faq__q {
    counter-increment: faq;
    font-size: 1.6rem;
    font-weight: bold;
    color: #ef6d22;
    line-height: 1.7;
}
.ex-con-faq__q::before {
    content: "Q." counter(faq);
    font-size: 2.4rem;
    color: #ef6d22;
}
.ex-con-faq__a {
    font-size: 1.4rem;
    line-height: 1.8;
    margin-top: 1.5rem;
}
.ex-con-faq__a::before {
    content: "A.";
    font-weight: bold;
}


.value-link-list--flex-center {
    display: grid;
    gap: 3rem;
    margin-top: 5rem;
}

@media screen and (max-width: 768px) {
    .chosen-card__label {
        display: flex;
        flex-wrap: wrap;
        align-items: baseline;
        gap: 7px;
    }

    .ex-con-faq-wrap {
        max-height: 230px;
        overflow: hidden;
    }
    .ex-con-faq-wrap.is-open {
        max-height: max-content;
    }
    .is-open.ex-con-faq-wrap::after {
        content: none;
    }

    .ex-con-faq-wrap::after {
        content: "";
        background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, #F9F7F3 90%, #F9F7F3 100%);
        width: 100%;
        height: 200px;
        position: absolute;
        left: 0;
        bottom: -1px;
        z-index: 1;
    }

    .ex-con-faq-more {
        display: flex;
        justify-content: center;
        margin-top: 3rem;
    }

    .ex-con-faq-more__btn {
        appearance: none;
        margin: 0;
        border: none;
        background: none;
        color: #EF6D22;
        font-size: 1.6rem;
        font-weight: 700;
        line-height: 2;
        text-align: center;
        display: inline-grid;
        justify-content: center;
        row-gap: 1rem;
        cursor: pointer;
        transition: opacity 0.2s ease-out;
    }
    .ex-con-faq-more__btn::after {
        content: "";
        width: 24px;
        aspect-ratio: 1;
        background: url(/images/2025/common/ico_plusCircle.svg) center center / contain no-repeat;
        display: block;
        margin-inline: auto;
    }
}

@media screen and (min-width: 769px) { 
    .koko-section {
        padding-block: 110px 130px;
    }
    .koko-section__text {
        max-width: 600px;
        text-align: center;
        margin: 7.4rem auto 0;
    }
    .koko-section__ft {
        margin-top: 7.4rem;
    }


    
/*リフォームコンシェルジュ®とは？*/

    .about-reform__slider {
        margin-inline: 35px;
        margin-top: 5rem;
    }

    .about-reform__sliderItem {
        margin-inline: 22px;
        transition: .2s ease-out;
    }

    .about-reform__sliderItem:hover {
        opacity: .7;
    }

    .about-reform__slider .slick-arrow {
        position: absolute;
        text-indent: -9999em;
        display: block;
        margin: 0;
        top: calc(50% - 10px);
        bottom: 0;
        transform: translateY(-50%);
        background: none;
        border: none;
        -webkit-appearance: none;
            -moz-appearance: none;
                appearance: none;
        width: 20px;
        height: 20px;
        translate: 0 -50%;
        z-index: 1;
        cursor: pointer;
    }
    .about-reform__slider .slick-arrow::before {
        content: "";
        display: block;
        position: absolute;
        top: 50%;
        filter: drop-shadow(0 0 3px rgba(0, 0, 0, 0.3));
    }
    .about-reform__slider .slick-prev {
        right: 100%;
    }
    .about-reform__slider .slick-prev::before {
        content: "";
        display: inline-block;
        border-color: #EF6D22;
        border-style: solid;
        border-width: 0 2px 2px 0;
        width: 14px;
        height: 14px;
        vertical-align: middle;
        transform: rotate(135deg);
        left: 65%;
        translate: -50% -50%;
    }
    .about-reform__slider .slick-next {
        left: 100%;
    }
    .about-reform__slider .slick-next::before {
        content: "";
        display: inline-block;
        border-color: #EF6D22;
        border-style: solid;
        border-width: 0 2px 2px 0;
        width: 14px;
        height: 14px;
        vertical-align: middle;
        transform: rotate(-45deg);
        right: 65%;
        translate: 50% -50%;
    }


    /*リフォームコンシェルジュが選ばれる理由*/

    .chosen-card-wrap {
        display: flex;
        flex-wrap: wrap;
        gap: 52px 40px;
        justify-content: center;
        margin-top: 11rem;
    }

    .chosen-card {
        width: calc(100% / 3);
        max-width: 320px;
        padding: 2.7rem 3.7rem;
    }
    .chosen-card__head {
        margin-top: 2rem;
    }
    .chosen-card__label {
        font-size: 2.4rem;
        text-align: center;
    }
    .chosen-card__label .num {
        display: block;
    }
    .chosen-card__title {
        font-size: 2rem;
    }
    .chosen-card__text {
        font-size: 1.6rem;
        margin-top: 1.5rem;
    }
    .chosen-img {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 96px;
        align-items: end;
        max-width: 680px;
        margin: 110px auto 0;
    }


    
    /*エグゼクティブリフォームコンシェルジュのご紹介*/

    .ex-con-article {
        margin-top: 100px;
    }
    .ex-con-article + .ex-con-articl {
        margin-top: 126px;
    }
    .ex-con-article__title {
        font-size: 2rem;
        padding-bottom: 14px;
        margin-bottom: 5.3rem;
    }
    .ex-con-prof {
        grid-template-columns: 265px 1fr;
        gap: 60px;
    }
    .ex-con-prof img {
        max-width: 265px;
        height: auto;
    }
    .ex-con-faq-wrap {
        grid-template-columns: repeat(2,1fr);
        gap: 110px;
        margin-top: 6.7rem;
    }

    .ex-con-prof__loc,
    .ex-con-prof__company,
    .ex-con-prof__post,
    .ex-con-prof__name {
        font-size: 1.8rem;
    }
    .ex-con-prof__post {
        font-size: 1.6rem;
    }

    .ex-con-faq__q {
        display: flex;
        align-items: center;
        gap: 22px;
        font-size: 1.8rem;
    }
    .ex-con-faq__q::before {
        font-size: 3.6rem;
    }
    .ex-con-faq__a {
        font-size: 1.6rem;
        margin-top: 2.8rem;
    }

    .ex-con-faq-more {
        display: none;
    }

    .value-link-list--flex-center {
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
        gap: 43px;
        margin-top: 89px;
    }
    .value-link-list--flex-center .value-link-list__item {
        flex: 0 0 calc(100% / 2 - 43px);
    }
}