/* common */
.subpage { overflow: hidden; position:relative; text-align: left; }
.subpage > section {padding: 90px 0; position: relative; }
.subpage > section:nth-of-type(even) {background: #f7f7f7;}
.sub_inner { padding: 0 50px; margin: 0 auto; max-width: 1400px; width: 100%; }

.line_tit {text-align: left; position: relative;  padding-left: 15px;  }
.line_tit::before {content: ''; display: block; width: 4px; height: 60%; background-color: #1b1b7f; position: absolute; left: 0; top:20%; }

/* font size */
.fs_55 {font-size: 55px; font-weight :600; line-height: 1.2; color:#000; }
.fs_37 {font-size: 37px; font-weight :700; line-height: 1.2; color:#000; }
.fs_34 {font-size: 34px; font-weight:500; line-height: 1.32;  color:#000;  }
.fs_32 {font-size: 32px; font-weight:700; line-height: 1.57;  color:#000;  }
.fs_30 {font-size: 30px; font-weight:700; line-height: 1.57;  color:#000;  }
.fs_26 {font-size: 26px; font-weight:700; line-height: 1.57;  color:#000;  }
.fs_23 {font-size: 23px; font-weight:700; line-height: 1.61; color:#000; letter-spacing: -.46px;}
.fs_22 {font-size: 22px; font-weight:600; line-height: 1.4; color:#000;  }
.fs_21 {font-size: 21px; font-weight:700; line-height: 1.4; color:#000;  }
.fs_20 {font-size: 20px; font-weight:300; line-height: 1.67; color:#000;  }
.fs_19 {font-size: 19px; font-weight: 400; color: #333; line-height: 1.67; letter-spacing: -.36px; }
.fs_18 {font-size: 18px; font-weight: 400; color: #333; line-height: 1.83; letter-spacing: -.36px; }
.fs_17 {font-size: 17px; font-weight: 400; color: #333; line-height: 1.72; letter-spacing: -.36px; }
.fs_16 {font-size: 16px; font-weight: 400; color: #444; line-height: 1.72; letter-spacing: -.36px; }
.fs_15 {font-size: 15px; font-weight: 400; color: #666; line-height: 1.72; letter-spacing: -.36px; }

/*Content CSS*/
.line_tit {margin-bottom:25px;}
.cont + .cont {margin-top: 80px;}
.img_wrap {display: flex ;align-items: center; justify-content: center; flex-direction: column; border: 1px solid #ddd; width: 100%; padding: 50px; margin-bottom: 80px;}

.img_list {display: flex; justify-content: space-between; width: 100%;}
.img_list + .img_list {margin-top: 15px;}
.img_list > li {margin-right: 15px; }
.img_list > li:last-child {margin-right: 0; }

.txt_list {display: flex; flex-wrap: wrap; justify-content: space-between; text-align: left; }
.txt_list > li {width: calc(50% - 10px); padding: 25px; border:1px solid #ddd;}
.txt_list > li:nth-child(n+3) {margin-top: 20px; }
.txt_list p {position: relative;  padding-left: 11px; font-weight: 400; color:#333; }
.txt_list p::before {content: ''; display: block; width: 5px; height: 5px; background-color: #999; position: absolute; left: 0; top:12px; border-radius:50%;}


.txt_box {background-color: #f7f7f7; padding:35px 40px; text-align: center; margin-top: 25px;}
.txt_box p {font-weight: 400; color:#000; letter-spacing: -.36px; display: inline;}
.txt_box .icon {margin-right: 10px; position: relative; top:-2px;}


@media screen and (max-width:1400px) {
    /* common */
    .subpage br:not(.space) {display: none;}

    /* content */
    .img_box {height: auto; padding: 60px;}

}


@media screen and (max-width: 1024px) {
    /* common */
    .subpage {text-align: center;}
    .subpage > section {padding: 70px 0; }
    .sub_inner {padding:0 30px;}

    /* font size */
    .fs_55 {font-size:40px; }
    .fs_37 {font-size:30px; }
    .fs_34 {font-size: 27px;}
    .fs_32 {font-size: 26px;}
    .fs_30 {font-size: 25px;}
    .fs_26 {font-size: 21px;}
    .fs_23 {font-size: 19px;}
    .fs_22 {font-size: 19px;}
    .fs_21 {font-size: 18px; line-height: 1.4;}
    .fs_20 {font-size: 17px; line-height: 1.65;}
    .fs_19 {font-size: 17px; line-height: 1.65;}
    .fs_18 {font-size: 16px; line-height: 1.65;}
    .fs_17 {font-size: 15px; line-height: 1.65;}
    .fs_16 {font-size: 14px; line-height: 1.65;}
    .fs_15 {font-size: 13px; line-height: 1.65;}

    /* content */
    .img_wrap {padding: 20px; }
    .img_list > li {margin-right: 7px;}
    .img_list + .img_list {margin-top: 7px;}

    .txt_box { padding: 30px;}

    .txt_list > li {padding: 15px 20px; width: 100%;}
    .txt_list > li:nth-child(n+2) {margin-top: 10px;}
    .txt_list p::before {top:8px;}

}

@media screen and (max-width: 768px) {
    .img_wrap {padding: 10px;}
    .img_list {flex-wrap: wrap; }
    .img_list > li {width: 50%;margin: 0 ; display: flex; align-items: center;justify-content: center; padding: 10px;}
    .img_list.list3 > li,
    .img_list.list4 > li {width: 100%;}

}

@media screen and (max-width: 640px) {
    /* common */
    .subpage > section {padding: 50px 0;}
    .sub_inner {padding:0 20px;}
    .sub_tit {margin-bottom: 20px; }

    /* font size */
    .fs_55 {font-size:32px; }
    .fs_37 {font-size:22px; }
    .fs_34 {font-size: 21px;}
    .fs_32 {font-size: 20px;}
    .fs_30 {font-size: 20px;}
    .fs_26 {font-size: 18px;}
    .fs_23 {font-size: 17px;}
    .fs_22 {font-size: 17px;}
    .fs_21 {font-size: 16px;}
    .fs_20 {font-size: 15px;}
    .fs_19 {font-size: 15px;}
    .fs_18 {font-size: 14px;}
    .fs_17 {font-size: 14px;}
    .fs_16 {font-size: 13px;}
    .fs_15 {font-size: 12px;}

    /* content */
    .line_tit {margin-bottom: 20px;}

    .img_wrap {padding: 5px; margin-bottom: 50px;}
    .img_list > li {padding: 5px;}

    .txt_box { padding: 20px; margin-top: 10px;}
    .txt_box .icon {margin-right: 5px;}
    .txt_list > li {padding:10px 15px;}
    .txt_list > li:nth-child(n+2) {margin-top: 5px;}


}


@media screen and (max-width: 480px) {
    .img_list > li {width: 100%;}
}
