@charset "utf-8";

/* #content */
.img_box img {width: 100%;}
.block {display: block;}
.m_color {color: #0C82FE;}

section .inner .title_text {font-weight: 700; font-size: 70px; letter-spacing: -0.02em; text-align: center; color: #000;}
section .inner .sub_text {font-weight: 700; font-size: 50px; line-height: 1.5em; padding: 50px 0 50px; text-align: center; margin-top: 50px; position: relative;}
section .inner .sub_text::before {content: ''; display: block; width: 85px; height: 4px; background: #161718; 
    position: absolute; top: 0; left: 50%; margin-left: -42.5px;}
section .inner .sub_explain p {font-weight: 300; font-size: 36px; line-height: 50px; letter-spacing: -1px; text-align: center; color: #505050; margin-bottom: 1em;}
section .inner .sub_explain p:last-of-type {margin-bottom: 0;}
section .inner .sub_explain p strong {font-weight: 500;}
section > .inner {padding: 150px 16.66%; box-sizing: border-box;}


.intro_banner {width: 100%; padding-top: calc(560/1920 *100%); position: relative;
    background-image: url(../images/img_intro_banner.png); background-size: cover; background-repeat: no-repeat; background-position: center;}
.intro_banner .inner {width: 100%; padding: 0; text-align: center; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);}
.intro_banner .inner > span {display: block; font-weight: 300; font-size: 46px; letter-spacing: -1px; line-height: 1em; color: #161718;}
.intro_banner .inner strong {display: inline-block; padding: 40px 0; color: #0C82FE;
    font-weight: 700; font-size: 90px; letter-spacing: -1px; line-height: 1em;}
.intro_banner .inner p {font-size: 28px; line-height: 130%; letter-spacing: -1px; color: #161718;}


.definition .inner .img_box {margin: 30px 0 80px;}
.definition .inner .img_box img {border-radius: 20px;}
.definition .inner .sub_explain p:first-of-type {font-weight: 700; font-size: 45px; line-height: 55px; letter-spacing: -1px; color: #161718;}


.qanda {background: #DCEFFF;}
.qanda .inner ul {margin-top: 50px;}
.qanda .inner ul li > div {padding: 20px 2%; margin-bottom: 34px; position: relative;}
.qanda .inner ul li > div span {display: inline-block; width: 70px; height: 70px; border-radius: 50%; 
    font-weight: 700; font-size: 35px; letter-spacing: -2.5px; line-height: 62px; text-align: center;}
.qanda .inner ul li .q_bubble {display: inline-block; background: #0C82FE; border-radius: 63.6px;}
.qanda .inner ul li .q_bubble::before {content: ''; display: block; width: 35px; height: 35px; background: url(../images/icon_speech_bubble_bl.png) center no-repeat;
    background-size: contain; position: absolute; left: 0; top: 0;}
.qanda .inner ul li .q_bubble span {background: #fff; color: #505050; vertical-align: middle;}
.qanda .inner ul li .q_bubble p {display: inline-block; margin: 0 36px; vertical-align: middle; font-weight: 700;
    font-size: 40px; line-height: 55px; letter-spacing: -1px; color: #fff;}
.qanda .inner ul li .a_bubble {background: #fff; border-radius: 20px;}
.qanda .inner ul li .a_bubble::before {content: ''; display: block; width: 58px; height: 65px; background: url(../images/icon_speech_bubble_wht.png) center no-repeat;
    background-size: contain; position: absolute; right: 50px; bottom: -20px;}
.qanda .inner ul li .a_bubble span {background: #E65E64; color: #fff; vertical-align: top;}
.qanda .inner ul li .a_bubble div {width: 80%; display: inline-block; margin-left: 36px; vertical-align: middle;}
.qanda .inner ul li .a_bubble div p {font-weight: 300; font-size: 30px; line-height: 45px; letter-spacing: -1px; color: #505050;}
.qanda .inner ul li .a_bubble div p .mo_ver {display: none;}


.step .inner ul {display: grid; grid-template-columns: repeat(2, 1fr); gap: 30px; margin-top: 50px;}
.step .inner ul li {display: flex; flex-direction: column; justify-content: space-between;border-radius: 20px; border: 1px solid #E2E2E2; padding: 30px 5%;}
.step .inner ul li div {display: flex; gap: 32px;}
.step .inner ul li div .img_box {width: 35%;}
.step .inner ul li div .text_box {width: 65%;}
.step .inner ul li div .text_box dt {font-weight: 700; font-size: 35px; line-height: 52px; letter-spacing: -1px; color: #161718; margin-bottom: 0.5em;}
.step .inner ul li div .text_box dd {font-weight: 300; font-size: 30px; line-height: 45px; letter-spacing: -1px; color: #505050;}
.step .inner ul li > p {font-weight: 700; font-size: 30px; line-height: 55px; letter-spacing: -1px; text-align: center; 
    color: #FFF; background: #0C82FE; border-radius: 20px; padding: 20px 2%; margin-top: 30px;}


.method {background: #DCEFFF;}
.method .inner ul {display: grid; grid-template-columns: repeat(2, 1fr); column-gap: 32px; row-gap: 35px; margin-top: 50px;}
.method .inner ul li {border-radius: 20px; overflow: hidden; background: #fff;}
.method .inner ul li .img_box img {border-radius: 20px 20px 0 0;}
.method .inner ul li .text_box {text-align: center; padding: 50px 5% 30px; position: relative;}
.method .inner ul li .text_box::after {display: block; width: 70px; height: 70px; color: #fff; text-align: center;
    font-weight: 700; font-size: 30px; line-height: 70px; letter-spacing: -1px; border-radius: 50%; background: #0C82FE;
    position: absolute; top: -35px; left: 50%; transform: translateX(-50%);}
.method .inner ul li:nth-child(1) .text_box::after {content: '01';}
.method .inner ul li:nth-child(2) .text_box::after {content: '02';}
.method .inner ul li:nth-child(3) .text_box::after {content: '03';}
.method .inner ul li:nth-child(4) .text_box::after {content: '04';}
.method .inner ul li .text_box dt {font-weight: 700; font-size: 35px; line-height: 52px; letter-spacing: -1px; color: #161718; margin-bottom: 4px;}
.method .inner ul li .text_box dd {font-weight: 300; font-size: 30px; line-height: 45px; letter-spacing: -1px; color: #505050;}


.target {width: 100%; background-image: url(../images/img_background.png); background-size: cover; background-repeat: no-repeat; background-position: center;}
.target .inner ul {margin: 50px auto 0; width: 70%; display: grid; grid-template-columns: repeat(2, 1fr); gap: 40px;}
.target .inner ul li {position: relative;}
.target .inner ul li::after {display: block; content: ""; padding-bottom: 100%;}
.target .inner ul li > div {width: 100%; height: 100%; object-fit: cover; background: #fff; border-radius: 50%;
    display: flex; flex-direction: column; justify-content: center; position: absolute; top: 0; left: 0;}
.target .inner ul li .img_box {width: 35%; padding-top: calc(160/160 * 35%); margin: 0 auto;
    background-repeat: no-repeat; background-size: contain; background-position: center;}
.target .inner ul li p {font-weight: 300; font-size: 36px; line-height: 50px; letter-spacing: -1px; text-align: center; color: #000; margin-top: 29px;}

/* PC (해상도 1440px ~ 1540px) */
@media screen and (max-width:1540px) {
    section .inner .title_text {font-size: 44px;}
    section .inner .sub_text {font-size: 22px; padding: 30px 0; margin-top: 30px;}
    section .inner .sub_text::before {width: 60px; margin-left: -30px;}
    section .inner .sub_explain p {font-size: 22px; line-height: 1.5em;}
    section > .inner {padding: 150px 12%;}

    .intro {min-height: 740px;}
    .intro_banner .inner > span {font-size: 44px;}
    .intro_banner .inner strong {font-size: 55px; padding: 0.5em 0;}
    .intro_banner .inner p {font-size: 20px;}

    .definition .inner ul li .number {font-size: 48px; line-height: 1em; letter-spacing: -1px;}
    .definition .inner ul li p {font-size: 22px; line-height: 28px;}    
    .definition .inner ul li p > span {font-size: 18px;}
    .definition .inner .sub_explain p:first-of-type {font-size: 36px;}

    .qanda .inner ul li > div span {width: 50px; height: 50px; font-size: 32px; line-height: 44px;}
    .qanda .inner ul li .q_bubble p {margin-left: 10px; font-size: 28px; line-height: 1em;}
    .qanda .inner ul li .a_bubble {background: #fff; border-radius: 20px;}
    .qanda .inner ul li .a_bubble div {width: 85%; margin-left: 9px;}
    .qanda .inner ul li .a_bubble div p {font-size: 22px; line-height: 1.5em;}

    .step .inner ul li div .text_box dt {font-size: 22px; line-height: 30px;}
    .step .inner ul li div .text_box dd {font-size: 18px; line-height: 23px;}
    .step .inner ul li > p {font-size: 20px; padding: 6px 2%;}

    .method .inner ul li .text_box dt {font-size: 28px;}
    .method .inner ul li .text_box dd {font-size: 20px; line-height: 1.5em;}

    .target .inner ul li p {font-size: 26px; line-height: 1.5em;}
}
/* PC (해상도 1058px ~ 1440px) */
@media screen and (max-width:1440px) {
    section > .inner {padding: 150px 10%;}
}
/* PC (해상도 1024px ~ 1058px) */
@media screen and (max-width:1058px) {
    section > .inner {padding: 150px 8%;}
}


/* 태블릿 (해상도 769px ~ 1024px) */
@media screen and (max-width:1024px) {
    /* content */
    section .inner .title_text {font-size: 34px; letter-spacing: -1px;}
    section .inner .sub_text {font-size: 26px; padding: 20px 0; margin-top: 20px;}
    section .inner .sub_text::before {width: 32px; height: 2px; margin-left: -16px;}
    section .inner .sub_explain p {font-size: 16px; line-height: 22px;}
    section > .inner {padding: 80px 5%;}

    .intro_banner {padding-top: calc(238/768 *100%);}
    .intro_banner .inner > span {font-size: 23px; letter-spacing: -1px; color: #161718;}
    .intro_banner .inner strong {padding: 15px 0 18px; font-size: 42px; letter-spacing: -1px; line-height: 1em;}
    .intro_banner .inner p {font-size: 14px;}
    
    .definition .inner .img_box {margin: 18px 0 40px;}
    .definition .inner .img_box img {border-radius: 10px;}
    .definition .inner .sub_explain p:first-of-type {font-size: 26px; line-height: 1em; color: #000;}

    .qanda .inner ul {margin-top: 20px;}
    .qanda .inner ul li {margin-bottom: 20px;}
    .qanda .inner ul li:last-child {margin-bottom: 0;}
    .qanda .inner ul li > div {padding: 8px 2%; margin-bottom: 16px;}
    .qanda .inner ul li > div span {width: 36px; height: 36px; font-size: 26px; letter-spacing: -1px; line-height: 30px;}
    .qanda .inner ul li .q_bubble {border-radius: 48px;}
    .qanda .inner ul li .q_bubble::before {width: 17px; height: 17px; left: 0; top: 0;}
    .qanda .inner ul li .q_bubble p {margin-left: 8px; font-size: 24px; line-height: 1em;}
    .qanda .inner ul li .a_bubble {border-radius: 10px;}
    .qanda .inner ul li .a_bubble::before {width: 29px; height: 32px; right: -6px; bottom: -13px;}
    .qanda .inner ul li .a_bubble div {width: 85%; margin-left: 9px;}
    .qanda .inner ul li .a_bubble div p {font-size: 16px; line-height: 22px;}
    .qanda .inner ul li .a_bubble div p .mo_ver {display: inline-block; color: #E65E64; margin-right: 1%;}
    
    .step .inner ul {gap: 16px; margin-top: 20px;}
    .step .inner ul li {border-radius: 10px; padding: 16px 5%;}
    .step .inner ul li div {display: flex; gap: 16px;}
    .step .inner ul li div .text_box dt {font-size: 18px; line-height: 30px;}
    .step .inner ul li div .text_box dd {font-size: 15px; line-height: 23px;}
    .step .inner ul li > p {font-size: 16px; line-height: 30px; border-radius: 6px; padding: 3px 2%; margin-top: 16px;}

    .method .inner ul {column-gap: 16px; row-gap: 16px; margin-top: 20px;}
    .method .inner ul li {border-radius: 10px;}
    .method .inner ul li .img_box img {border-radius: 10px 10px 0 0;}
    .method .inner ul li .text_box {padding: 30px 5% 20px;}
    .method .inner ul li .text_box::after {width: 36px; height: 36px; font-size: 18px; line-height: 36px; top: -18px; left: 50%; transform: translateX(-50%);}
    .method .inner ul li .text_box dt {font-size: 22px; line-height: 30px; margin-bottom: 6px;}
    .method .inner ul li .text_box dd {font-size: 15px; line-height: 23px;}

    .target .inner ul {margin: 40px auto 0; gap: 16px;}
    .target .inner ul li p {font-size: 18px; line-height: 22px; letter-spacing: -1px; margin-top: 0;}
}

/* 모바일 가로, 모바일 세로 (해상도 375px ~ 768px)*/
@media screen and (max-width:768px) {
    .wrap { min-width: 375px; }
    /* content */
    section .inner .title_text {font-size: 30px;}
    section .inner .sub_text {font-size: 17px; padding: 20px 0 30px; margin-top: 20px;}
    section .inner .sub_text::before {width: 40px; height: 2px; margin-left: -20px;}
    section .inner .sub_explain p {font-size: 14px; line-height: 23px;}
    section > .inner {padding: 50px 5%;}

    .intro_banner {background: #EAF2FF; padding-top: 0;}
    .intro_banner .inner {position: relative; top: 0; transform: translate(-50%, 0); padding: 56px 0 17px;}
    .intro_banner .inner > span {font-size: 23px; letter-spacing: -1px; color: #161718;}
    .intro_banner .inner strong {padding: 15px 0 18px; font-size: 42px; letter-spacing: -1px; line-height: 1em;}
    .intro_banner .inner p {font-size: 14px;}
    .intro_banner .mo_ver {width: 100%; padding-top: calc(241/375 * 100%); background: url(../images/img_intro_banner_mo.png) center no-repeat; background-size: contain;}

    .definition .inner .img_box {margin: 0 0 30px;}
    .definition .inner .sub_explain p .block {display: inline;}
    .definition .inner .sub_explain p i {display: block;}

    .qanda .inner ul {margin-top: 0;}
    .qanda .inner ul li {margin-bottom: 24px;}
    .qanda .inner ul li > div {padding: 9px 2%; margin-bottom: 12px;}
    .qanda .inner ul li > div span {width: 34px; height: 34px; font-size: 16px; line-height: 32px;}
    .qanda .inner ul li .q_bubble {border-radius: 30px;}
    .qanda .inner ul li .q_bubble::before {width: 17px; height: 17px; left: 0; top: 0;}
    .qanda .inner ul li .q_bubble p {font-size: 18px; margin-left: 14px;}
    .qanda .inner ul li .a_bubble::before {right: 22px; bottom: -12px;}
    .qanda .inner ul li .a_bubble div {width: 83%;}
    .qanda .inner ul li .a_bubble div p {font-size: 14px; line-height: 23px;}
    .qanda .inner ul li .a_bubble div p .mo_ver {margin-right: 2%;}

    .step .inner ul {grid-template-columns: repeat(1, 1fr); gap: 20px; margin-top: 0;}
    .step .inner ul li div {display: flex; gap: 16px;}
    .step .inner ul li div .text_box dt {font-size: 17px;}
    .step .inner ul li div .text_box dd {font-size: 14px;}
    .step .inner ul li > p {font-size: 17px;}

    .method .inner ul {grid-template-columns: repeat(1, 1fr); gap: 20px; margin-top: 0;}
    .method .inner ul li .text_box dt {font-size: 20px;}
    .method .inner ul li .text_box dd {font-size: 14px;}

    .target .inner ul {grid-template-columns: repeat(2, 1fr); margin: 30px auto 0; gap: 16px;}
    .target .inner ul li p {font-size: 15px; line-height: 20px;}
}
