@charset "utf-8";
/* service_mv */
.service_mv_ttl,
.service_mv_txt {
    text-align: center;
}
.service_mv_ttl {
    font-weight: 700;
}
.service_mv_txt {
    font-weight: 400;
    color: var(--color-dark-gray);
}
@media (min-width: 769px) {
    .service_mv {
        padding-top: 260px;
    }
    .service_mv_ttl {
        font-size: 56px;
        line-height: 1;
    }
    .service_mv_txt {
        margin-top: 50px;
        line-height: 2;
    }
}
@media (max-width: 768px) {
    .service_mv {
        padding-top: 134px;
    }
    .service_mv_ttl {
        font-size: 42px;
        line-height: 1.4;
    }
    .service_mv_txt {
        margin-top: 40px;
        font-size: 16px;
        line-height: 1.9;
    }
}

/* タイトルアニメーション */
.anim_char_up_cover_wrap {
    overflow: hidden;
    line-height: 1;
    opacity: 0;
}
.is_animated.anim_char_up_cover_wrap {
    opacity: 1;
    transition: opacity 0s;
}
.anim_char_up_cover,
.anim_char_up_inner {
    line-height: 1;
}
.anim_char_up_cover {
    display: inline-block;
}
.anim_char_up_inner {
    display: inline-block;
    transform: translateY(100%);
    transition: transform 0s;
}
.is_animated > .anim_char_up_cover .anim_char_up_inner {
    transform: translateY(0);
    transition: transform 1.5s cubic-bezier(0.22, 1, 0.36, 1);
}
.anim_char_up_cover:nth-child(1) .anim_char_up_inner {
    transition-delay: 0.3s;
}
.anim_char_up_cover:nth-child(2) .anim_char_up_inner {
    transition-delay: 0.35s;
}
.anim_char_up_cover:nth-child(3) .anim_char_up_inner {
    transition-delay: 0.4s;
}
.anim_char_up_cover:nth-child(4) .anim_char_up_inner {
    transition-delay: 0.45s;
}
.anim_char_up_cover:nth-child(5) .anim_char_up_inner {
    transition-delay: 0.5s;
}
.anim_char_up_cover:nth-child(6) .anim_char_up_inner {
    transition-delay: 0.55s;
}
.anim_char_up_cover:nth-child(7) .anim_char_up_inner {
    transition-delay: 0.6s;
}
.anim_char_up_cover:nth-child(8) .anim_char_up_inner {
    transition-delay: 0.65s;
}
.anim_char_up_cover:nth-child(9) .anim_char_up_inner {
    transition-delay: 0.7s;
}
.anim_char_up_cover:nth-child(10) .anim_char_up_inner {
    transition-delay: 0.75s;
}
.anim_char_up_cover:nth-child(11) .anim_char_up_inner {
    transition-delay: 0.8s;
}
.anim_char_up_cover:nth-child(12) .anim_char_up_inner {
    transition-delay: 0.85s;
}
.anim_char_up_cover:nth-child(13) .anim_char_up_inner {
    transition-delay: 0.9s;
}
.anim_char_up_cover:nth-child(14) .anim_char_up_inner {
    transition-delay: 0.95s;
}
.anim_char_up_cover:nth-child(15) .anim_char_up_inner {
    transition-delay: 1s;
}
.anim_char_up_cover:nth-child(16) .anim_char_up_inner {
    transition-delay: 1.05s;
}
.anim_char_up_cover:nth-child(17) .anim_char_up_inner {
    transition-delay: 1.1s;
}
.anim_char_up_cover:nth-child(18) .anim_char_up_inner {
    transition-delay: 1.15s;
}

/* request_btn_area */
.request_btn_area {
    text-align: center;
}
.request_btn_area .btn {
    height: 80px;
    border-radius: 40px;
    padding-inline: 35px 75px;
}
.request_btn_area .btn_bg {
    width: 12px;
    height: 12px;
}
.request_btn_area .btn_icon {
    width: 25px;
    height: 20px;
}
@media (min-width: 769px) {
    .request_btn_area {
        padding-top: 120px;
    }
    .request_btn_area .btn {
        font-size: 24px;
    }
}
@media (max-width: 768px) {
    .request_btn_area {
        padding-top: 80px;
    }
    .request_btn_area .btn {
        font-size: 22px;
    }
}

/* local */
.local {
    background-color: var(--color-light-gray);
}
.local_ttl {
    line-height: 1;
    text-align: center;
    position: relative;
}
.local_ttl_icon {
    width: 100%;
    height: 9px;
    display: flex;
    justify-content: center;
    gap: 6px;
    position: absolute;
    top: 0;
    left: 0;
}
.local_ttl_icon::before,
.local_ttl_icon::after {
    content: '';
}
.local_ttl_icon::before,
.local_ttl_icon_box,
.local_ttl_icon::after {
    width: 9px;
    height: 9px;
    background-color: var(--color-black);
    display: block;
}
.local_ttl {
    padding-top: 22px;
    font-size: 16px;
}
.local_list {
    display: flex;
    flex-wrap: wrap;
}
.btn_local {
    display: grid;
    place-content: center;
    border: solid 1px var(--color-black);
    border-radius: 16px;
    font-weight: 700;
}
.btn_local_blank {
    position: relative;
}
.btn_local_blank::after {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    background: url(../img/common/icon_tab_gray.svg) no-repeat center center / contain;
    z-index: 1;
    width: 16px;
    height: 16px;
}
.btn_local_top_wrap {
    text-align: center;
}
.btn_local_top {
    display: inline-flex;
    align-items: center;
    background-color: var(--color-gray);
    color: var(--color-white);
    border-radius: 32px;
}
@media (min-width: 769px) {
    .local {
        margin-top: 120px;
        padding-block: 120px;
    }
    .local_list {
        gap: 32px 39px;
        margin-top: 67px;
    }
    .local_list > li {
        width: calc(50% - 20px);
        font-size: 32px;
    }
    .btn_local {
        height: 120px;
    }
    .btn_local_blank {
        transition: background-color 0.55s;
    }
    .btn_local_blank::after {
        right: 26px;
        transition: background 0.55s;
    }
    .local_btn_other {
        margin-top: 32px;
    }
    .local_btn_other .btn_local {
        font-size: 32px;
    }
    .btn_local_top_wrap {
        margin-top: 64px;
    }
    .btn_local_top {
        padding-inline: 28px 32px;
        height: 62px;
        transition:
            background-color 0.55s,
            color 0.55s;
    }
    @media (hover: hover) {
        .btn_local .btn_bg {
            transition: transform 0.95s;
        }
        .btn_local:hover .btn_bg {
            transform: scale(150);
        }
        .btn_local_blank:hover {
            background-color: var(--color-green);
        }
        .btn_local_blank:hover::after {
            background: url(../img/common/icon_tab.svg) no-repeat center center / contain;
        }
        .local_btn_other .btn_local:hover .btn_bg {
            transform: scale(240);
        }
        .btn_local_top:hover {
            background-color: var(--color-white);
            color: var(--color-gray);
        }
    }
}
@media (max-width: 768px) {
    .local {
        margin-top: 80px;
        padding-block: 80px;
    }
    .local_list {
        flex-direction: column;
        margin-top: 60px;
        row-gap: 8px;
    }
    .local_list > li {
        font-size: 24px;
    }
    .btn_local {
        height: 80px;
    }
    .btn_local_blank::after {
        right: 17px;
    }
    .local_btn_other {
        margin-top: 8px;
    }
    .local_btn_other .btn_local {
        font-size: 24px;
    }
    .btn_local_top_wrap {
        margin-top: 44px;
    }
    .btn_local_top {
        padding-inline: 23px 25px;
        height: 60px;
        font-size: 16px;
    }
}

/* service */
.service_txt {
    color: var(--color-dark-gray);
}
.service_list {
    padding-left: 1.2em;
    text-indent: -1.2em;
}
@media (min-width: 769px) {
    .service_ttl {
        font-size: 24px;
        line-height: calc(40 / 16);
    }
    .service_txt {
        font-size: 16px;
        line-height: calc(26 / 16);
    }
}
@media (max-width: 768px) {
    .service_ttl {
        font-size: 20px;
        line-height: calc(64 / 40);
    }
    .service_txt {
        font-size: 16px;
        line-height: calc(52 / 32);
    }
}

/* service_item */
.service_item {
    background-color: var(--color-light-gray);
}
.service_item_img_cover {
    overflow: hidden;
}
.service_item_img_cover > img {
    width: 100%;
}
.service_item_txt {
    color: var(--color-dark-gray);
}
@media (min-width: 769px) {
    .service_item {
        padding: 48px;
        border-radius: 16px;
        display: flex;
        align-items: flex-start;
        gap: 48px;
    }
    .service_item + .service_item {
        margin-top: 16px;
    }
    .service_item_img_cover {
        width: 256px;
        min-width: 256px;
        border-radius: 16px;
    }
    .service_item_ttl {
        font-size: 24px;
    }
    .service_item_txt {
        margin-top: 36px;
        font-size: 16px;
        line-height: calc(26 / 16);
    }
}
@media (max-width: 768px) {
    .service_item {
        padding: 19px;
        border-radius: 16px;
    }
    .service_item + .service_item {
        margin-top: 16px;
    }
    .service_item_img_cover {
        border-radius: 8px;
    }
    .service_item_ttl {
        margin-top: 24px;
        font-size: 20px;
        line-height: calc(64 / 40);
    }
    .service_item_txt {
        margin-top: 19px;
        font-size: 16px;
        line-height: calc(52 / 32);
    }
}

/* service_content */
.service_content {
    background-color: var(--color-light-gray);
}
.service_content_ttl,
.service_content_txt {
    text-align: center;
}
.service_content_txt,
.service_content_item_txt {
    color: var(--color-dark-gray);
}
.service_content_item_txt {
    text-align: center;
    position: relative;
}
.service_content_item_img {
    display: block;
    margin-inline: auto;
}
.service_content_item_ttl {
    text-align: center;
    font-weight: 700;
}
.service_content_item_img_wrap {
    display: flex;
    justify-content: space-between;
}
.service_content_item_img_cover {
    overflow: hidden;
}
.service_content_item_list {
    padding-left: 1.2em;
    text-indent: -1.2em;
}
.service_content_box_wrap {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 18px 0;
}
.service_content_box {
    background-color: var(--color-white);
    display: flex;
    align-items: center;
    overflow: hidden;
}
.service_content_box_txt {
    text-align: center;
}
@media (min-width: 769px) {
    .service_content {
        margin-top: 106px;
        padding-block: 120px;
    }
    .service_content_ttl {
        padding-top: 90px;
        font-size: 38px;
        line-height: calc(52 / 38);
    }
    .service_content_txt {
        margin-top: 48px;
        font-size: 16px;
        line-height: calc(32 / 16);
    }
    .service_content_item:has(.service_content_item_img_wrap) {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        flex-direction: row-reverse;
    }
    .solar .service_content_item:has(.service_content_item_img_wrap) {
        gap: 60px;
    }
    .solar .service_content_item_img_wrap {
        width: 45%;
        min-width: 45%;
    }
    .service_content_item_img_cover {
        border-radius: 16px;
    }
    .service_content_item_img {
        width: 56px;
        height: 51px;
    }
    .service_content_item_ttl {
        font-size: 24px;
        line-height: calc(40 / 16);
    }
    .service_content_item_txt {
        font-size: 16px;
        line-height: calc(26 / 16);
        margin-top: 40px;
    }
    .service_content_item_ttl {
        font-size: 32px;
        line-height: calc(52 / 32);
        margin-top: 20px;
    }
    .service_content_box_wrap {
        margin-top: 60px;
    }
    .service_content_box {
        width: 48%;
        border-radius: 16px;
    }
    .service_content_box > img {
        width: 52%;
    }
    .service_content_box_txt {
        width: 280px;
        font-size: 16px;
        line-height: calc(26 / 16);
    }
}
@media (max-width: 768px) {
    .service_content {
        margin-top: 75px;
        padding-block: 78px;
    }
    .service_content_ttl {
        padding-top: 58px;
        font-size: 28px;
        line-height: calc(80 / 56);
    }
    .service_content_txt {
        margin-top: 35px;
        font-size: 16px;
        line-height: calc(56 / 32);
    }
    .service_content_item_img_wrap {
        gap: 12px;
    }
    .service_content_item_img_cover {
        border-radius: 8px;
    }
    .service_content_item_img_cover,
    .service_content_item_img_cover > img {
        width: 100%;
    }
    .service_content_item_img {
        width: 42px;
        height: auto;
    }
    .service_content_item_ttl {
        margin-top: 24px;
        font-size: 28px;
        line-height: calc(56 / 52);
    }
    .service_content_item_txt {
        margin-top: 40px;
        font-size: 16px;
        line-height: calc(56 / 32);
    }
    .service_content_box_wrap {
        margin-top: 60px;
    }
    .service_content_box {
        width: 100%;
        border-radius: 8px;
    }
    .service_content_box > img {
        width: 55%;
    }
    .service_content_box_txt {
        width: 45%;
        font-size: 16px;
        line-height: calc(52 / 32);
    }
}

/* service_area */
.service_area_ttl {
    color: var(--color-white);
    background-color: var(--color-black);
}
.service_area_item_img_cover {
    overflow: hidden;
}
.service_area_item_txt {
    color: var(--color-dark-gray);
}
.service_area_item_pdf {
    padding-block: 20px;
    padding-left: 74px;
    font-size: 16px;
    display: inline-block;
    position: relative;
}
.service_area_item_pdf::before {
    content: '';
    width: 52px;
    height: 64px;
    margin: auto;
    background: url(../img/common/icon_pdf.svg) no-repeat 50% / contain;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
}
.service_area_item_list > li,
.service_item_list > li {
    padding-left: 1.2em;
    text-indent: -1.2em;
}
.service_area_item_img_box {
    background-color: var(--color-light-gray);
    overflow: hidden;
}
@media (min-width: 769px) {
    .service_area {
        margin-top: 110px;
    }
    .service_area + .service_area {
        margin-top: 80px;
    }
    .service_area_ttl {
        padding: 3px 24px 7px;
        font-size: 32px;
    }
    .environment .service_area_ttl {
        display: flex;
        align-items: center;
        gap: 20px;
    }
    .service_area_ttl_s {
        padding-top: 3px;
        font-size: 20px;
    }
    .service_area_item {
        padding-block: 64px 48px;
    }
    .service_area_item:has(.service_area_item_img_cover) {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        flex-direction: row-reverse;
        gap: 80px;
    }
    .service_area_item_img_cover {
        width: 45%;
        min-width: 45%;
    }
    .service_area_item_txt {
        font-size: 16px;
        line-height: calc(26 / 16);
    }
    .service_area_item_txt + .service_area_item_pdf {
        margin-top: 44px;
    }
    .service_area_item:has(.service_area_item_img_box) {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 70px;
    }
    .service_area_item_img_box_wrap {
        width: 45%;
        min-width: 45%;
    }
    .service_area_item_img_box {
        border-radius: 16px;
        display: flex;
        align-items: center;
    }
    .service_area_item_img_box + .service_area_item_img_box {
        margin-top: 18px;
    }
    .service_area_item_img_box > img {
        width: 55%;
    }
    .service_area_item_img_box_txt {
        padding-inline: 26px;
        font-size: 16px;
        line-height: calc(26 / 16);
    }
}
@media (max-width: 768px) {
    .service_area {
        margin-top: 72px;
    }
    .service_area + .service_area {
        margin-top: 60px;
    }
    .service_area_ttl {
        padding: 8px 17px 11px;
        font-size: 28px;
    }
    .service_area_ttl_s {
        font-size: 20px;
    }
    .service_area_item {
        margin-top: 44px;
    }
    .service_area_item_img_cover > img {
        width: 100%;
    }
    .service_area_item_txt {
        margin-top: 30px;
        font-size: 16px;
        line-height: calc(52 / 32);
    }
    .service_area_item_txt + .service_area_item_pdf {
        margin-top: 38px;
    }
    .service_area_item_img_box_wrap {
        margin-top: 27px;
    }
    .service_area_item_img_box {
        border-radius: 8px;
        display: flex;
        align-items: center;
        gap: 16px;
    }
    .service_area_item_img_box + .service_area_item_img_box {
        margin-top: 16px;
    }
    .service_area_item_img_box > img {
        width: 55%;
    }
    .service_area_item_img_box_txt {
        font-size: 16px;
        line-height: calc(52 / 32);
    }
}
@media (min-width: 769px) {
    @media (hover: hover) {
        .service_area_item_pdf {
            transition: opacity 0.3s;
        }
        .service_area_item_pdf:hover {
            opacity: 0.7;
        }
    }
}

/* service_area_csc */
.service_area_csc {
    text-align: center;
    border: solid var(--color-silver-gray);
    background-color: var(--color-white);
}
.service_area_csc_tel {
    display: inline-block;
    position: relative;
}
.service_area_csc_tel::before {
    content: '';
    width: 18px;
    height: 26px;
    margin: auto;
    background: url(../img/common/icon_sp.svg) no-repeat 50% / contain;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
}
.service_area_csc_time {
    color: var(--color-dark-gray);
}
.service_area_csc_btn::after {
    content: '';
    width: 16px;
    height: 16px;
    margin: auto;
    background: url(../img/common/icon_tab.svg) no-repeat 50% / contain;
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
}
@media (min-width: 769px) {
    .service_area_csc {
        max-width: 400px;
        padding-block: 42px 48px;
        border-width: 2px;
        border-radius: 16px;
    }
    .environment .service_area_csc {
        margin-top: 48px;
        margin-inline: auto;
    }
    .solar .service_area_csc {
        margin-top: 115px;
    }
    .service_area_csc_ttl {
        font-size: 24px;
    }
    .service_area_csc_img {
        margin-top: 24px;
    }
    .service_area_csc_txt {
        margin-top: 20px;
        font-size: 16px;
        line-height: calc(26 / 16);
    }
    .service_area_csc_tel {
        margin-top: 13px;
        padding-left: 25px;
        font-size: 36px;
    }
    .service_area_csc_time {
        margin-top: 4px;
        font-size: 16px;
    }
    .service_area_csc_btn {
        margin-top: 25px;
    }
    .service_area_csc_btn::after {
        right: 34px;
    }
}
@media (max-width: 768px) {
    .service_area_csc {
        margin-block: 44px 40px;
        padding-block: 28px 30px;
        border-width: 1px;
        border-radius: 8px;
    }
    .service_area_csc_ttl {
        font-size: 19px;
    }
    .service_area_csc_img {
        width: 188px;
        margin-top: 19px;
    }
    .service_area_csc_txt {
        margin-top: 20px;
        font-size: 16px;
        line-height: calc(26 / 16);
    }
    .service_area_csc_txt {
        margin-top: 20px;
        font-size: 16px;
        line-height: calc(52 / 32);
    }
    .service_area_csc_tel {
        margin-top: 13px;
        padding-left: 25px;
        font-size: 36px;
    }
    .service_area_csc_time {
        margin-top: 4px;
        font-size: 16px;
    }
    .service_area_csc_btn {
        height: 60px;
        margin-top: 25px;
        padding-inline: 25px 51px;
    }
    .service_area_csc_btn::after {
        right: 24px;
    }
}
@media (min-width: 769px) {
    @media (hover: hover) {
        .service_area_csc_btn {
            transition: background-color 0.3s;
        }
        .service_area_csc_btn:hover {
            background-color: #4e95d9;
        }
    }
}

/* auto_fuel_table */
.auto_fuel_table_wrap {
    overflow: auto;
}
.auto_fuel_table {
    max-width: 870px;
    margin-inline: auto;
    line-height: 1;
    text-align: center;
    border-collapse: collapse;
    display: block;
}
.auto_fuel_table th,
.auto_fuel_table td {
    height: 48px;
    padding-inline: 6px;
    font-size: 16px;
    border: solid 1px var(--color-black);
}
.auto_fuel_table th {
    width: 152px;
    font-weight: 500;
    background-color: var(--color-light-gray);
}
.auto_fuel_table td {
    width: 179px;
}
.auto_fuel_table tr:last-child th {
    font-weight: 700;
    color: var(--color-white);
    background-color: var(--color-dark-gray);
}
.auto_fuel_table tr:last-child th:first-child {
    border: none;
    visibility: hidden;
}
.auto_fuel_table_s {
    font-size: 12px;
}
@media (min-width: 769px) {
    .auto_fuel_table {
        margin-top: 40px;
    }
}
@media (max-width: 768px) {
    .auto_fuel_table_wrap {
        margin-inline: -16px;
        padding-bottom: 32px;
    }
    .auto_fuel_table {
        width: 870px;
        margin-top: 28px;
    }
    .simplebar-track {
        background-color: var(--color-light-gray);
        border-radius: 10px;
    }
    .simplebar-track.simplebar-horizontal {
        height: 8px;
    }
    .simplebar-track .simplebar-scrollbar.simplebar-visible::before {
        opacity: 1;
    }
    .simplebar-track .simplebar-scrollbar::before {
        background-color: var(--color-dark-gray);
        inset: 0;
    }
}
