@charset "utf-8";

.font_w6 {
    font-family: "Hiragino Kaku Gothic W6 JIS2004";
}

.bg-sky {
    background-color: #e8f1fA;
}

.pic_full img {
    width: 100%;
    max-width: inherit;
    vertical-align: middle;
}

#main_visual {
    position: relative;
    text-align: center;
    color: #2644d7;
}

#main_visual .section_inner {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}

#main_visual .pg_heading {
    margin-top: 10%;
    font-size: 2.6vw;
    font-family: var(--font-bold);
    letter-spacing: 3px;
}

#main_visual .pg_heading span {
    letter-spacing: -2px;
}

.visual_copy {
    margin-top: 4%;
    font-size: 1.25vw;
    font-family: var(--font-bold);
    line-height: 1.9;
}

.ev_slider {
    display: none;
}


@media screen and (max-width: 768px) {
    #main_visual {
        padding-top: 14.8vw;
        background-color: #f5f9fc;
    }

    #main_visual .section_inner {
        position: relative;
    }

    #main_visual .pg_heading {
        margin-top: 30px;
        font-size: calc(1.4vw + 16.5px);
    }

    .visual_copy {
        margin-top: 20px;
        font-size: calc(1.4vw + 11px);
        line-height: 1.5;
    }

    .ev_slider {
        display: block;
        margin-top: 30px;
    }

    .ev_slider .slide_item img{
        width: 100%;

    }
}

.ev_inner {
    margin: 0 auto;
    padding: 0 20px;
    max-width: 1080px;
}

.section {
    padding: 70px 0 50px;
    color: #595757;
}

@media screen and (max-width: 768px) {
    .ev_inner {
        padding: 0 10px;
        max-width: 100%;
    }

    .section {
        padding: 10px 0;
    }
}

.bg_box {
    margin-bottom: 50px;
    padding: 0 0 50px;
    border-radius: 15px;
    box-sizing: border-box;
    background-color: #fff;
}

.section .title {
    padding: 17px 0;
    border-bottom: 8px solid #e8f1fa;
    text-align: center;
    color: #2644d7;
    font-size: 30px;
    font-family: var(--font-bold);
}

.box_in {
    padding: 0 30px;
}

@media screen and (max-width: 768px) {
    .section .title {
        margin-bottom: 0;
        padding: 11px 0;
        border-width: 4px;
        font-size: calc(1.4vw + 14px);
    }
    .bg_box {
        margin-bottom: 10px;
        padding: 0 0 18px;
    }
    .box_in {
        padding: 0 10px;
    }
}

.img_ev {
    margin-top: 60px;
    text-align: center;
}

.img_ev img {
    max-width: 885px;
}
@media screen and (max-width: 768px) {
    .img_ev {
        margin-top: 15px;
        padding: 0 10px;
    }
    .img_ev img {
        max-width: 100%;
    }
}


.tbl_box {
    margin-top: 80px;
    border: 1px solid #595757;
    border-radius: 13px;
    box-shadow: 0px 0px 6px rgba(0,0,0,.16);
    background-color: #f5f9fc;
}

.tbl_box .tbl {
    width: 100%;
}

.tbl_box .tbl th, .tbl_box .tbl td{
    padding: 19px 46px;
    font-size: 1rem;
    vertical-align: middle;
}

.tbl_box .tbl td {
    border-left: 1px solid #595757;
}

.tbl_box .tbl tr > td:last-child {
    padding-left: 75px;
}

.tbl_box .tbl tr:not(:last-child) td {
    border-bottom: 1px solid #595757;
}

@media screen and (max-width: 768px) {
    .tbl_box {
        margin-top: 20px;
        border-radius: 6.5px;
    }

    .tbl_box .tbl th, .tbl_box .tbl td {
        padding: 10px 5px;
        font-size: calc(1.3vw + 6px);
        line-height: 1.6;
    }

    .tbl_box .tbl tr > th {
        width: 10%;
        text-align: center;
    }

    .tbl_box .tbl tr > td:last-child {
        padding-left: 5px;
    }
}

.desc {
    margin-top: 35px;
    font-size: 18px;
    line-height: 1.65;
}

.bd_box {
    margin-top: 50px;
    padding: 70px 40px 60px;
    border: 1px solid #595757;
    border-radius: 12px;
    background-color: #e8f1fa
}

.bd_box--size-s {
    margin-top: 40px;
}

.bd_box h4 {
    text-align: center;
    font-size: 24px;
    font-family: var(--font-bold)
}

.battery .desc {
    text-align: center;
}

@media screen and (max-width: 768px) {
    .desc {
        margin-top: 18px;
        font-size: calc(1.4vw + 9px);
    }
    .bd_box {
        margin-top: 18px;
        padding: 30px 15px;
        border-radius: 6px;
    }
    .bd_box--size-s {
        padding-bottom: 8px;
    }
    .bd_box h4 {
        font-size: calc(1.4vw + 11px);
    }
    .battery .desc {
        text-align: left;
    }
}

.box-grid {
    display: flex;
    flex-wrap: wrap;
}

.box-grid .box_col {
    margin-top: 35px;
    box-sizing: border-box;
}

.box-grid .box_col > .img > img {
    width: 100%;
}

.box-grid--col-2 {
    margin: 0 -10px;
}
.box-grid--col-2 > * {
    width: 50%;
    padding: 0 10px;
}

.box-grid--col-3 > * {
    width: 33.33%;
}


.service_box {
    padding-bottom: 0;
    margin-bottom: 0;
}

.service_box .title {
    margin-bottom: 0;
}

.service_box .box_col {
    margin-top: 0;
    padding: 37px 26px 40px;
    border-left: 8px solid #e8f1fA;
}


.service_box .box_col:nth-child(3n+1) {
    border-left: 0;
}

.service_box .box_col.col_1 {
    padding-left: 41px;
    padding-right: 35px;
}

.service_box .box_col.col_3 {
    padding-left: 30px;
    padding-right: 30px;
}

.service_box .box_col .desc {
    letter-spacing: .9px;
}

@media screen and (max-width: 768px) {
    .box-grid--col-sp-1 {
        margin: 0;
    }

    .box-grid--col-sp-1 > * {
        width: 100%;
        padding: 0;
    }

    .box-grid .box_col {
        margin-top: 20px;
    }

    .service_box .box_col  {
        margin-top: 0;
        padding: 25px 28px !important;
        border-left: 0;
        border-bottom: 4px solid #e8f1fA;
    }

    .service_box .box_col .img {
        text-align: center;
    }

    .service_box .box_col > .img > img {
        max-width: 95%;
    }

    .service_box .box_col .desc {
        font-size: calc(1.4vw + 13px);
        letter-spacing: inherit;
    }


}

.mt_0 {
    margin-top: 0 !important;
}

.mb_0 {
    margin-bottom: 0 !important;
}

@media screen and (max-width: 768px) {
    .mt_sp_0 {
        margin-top: 0 !important;
    }
}

.img_ev_caution {
    font-family: var(--font-light);
}