@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 {width: 35%; margin: 30px auto 80px; text-align: center;}
.definition .inner .img_box img {border-radius: 20px;}
.definition .inner .emphasis {text-align: center; margin-bottom: 110px;}
.definition .inner .emphasis p {font-weight: 700; font-size: 48px; letter-spacing: -0.02em; display: inline-block; position: relative;}
.definition .inner .emphasis p::before {content: '“'; font-weight: 500; font-size: 130px; line-height: 1em; color: #0c82fe; display: inline-block; position: absolute; top: 0; left: -100px;}
.definition .inner .emphasis p::after {content: '”'; font-weight: 500; font-size: 130px; line-height: 1em; color: #0c82fe; display: inline-block; position: absolute; top: 0; right: -100px;}


.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; display: grid; grid-template-columns: repeat(3, 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;}


.period .inner ul {display: grid; grid-template-columns: repeat(2, 1fr); gap: 32px; margin: 50px auto;}
.period .inner ul li {border-radius: 20px; overflow: hidden; background: #fff; border: 2px solid #E2E2E2;}
.period .inner ul li .img_box img {border-radius: 20px 20px 0 0;}
.period .inner ul li .text_box {text-align: center; padding: 40px 5%; position: relative;}
.period .inner ul li .text_box p {font-weight: 300; font-size: 30px; line-height: 45px; letter-spacing: -1px; color: #505050;}


.type {background: #EAF2FF;}
.type .inner .damaged > p, 
.type .inner .material > p {font-weight: 700; font-size: 30px; line-height: 52px; letter-spacing: -1px; text-align: center; 
    color: #FFF; padding: 24px 0; background: #161718; border-radius: 20px; margin-bottom: 32px;}
.type .inner ul li .text_box dt {font-weight: 700; font-size: 35px; line-height: 52px; letter-spacing: -1px; color: #161718; margin-bottom: 4px;}
.type .inner ul li .text_box dd {font-weight: 300; font-size: 30px; line-height: 45px; letter-spacing: -1px; color: #505050;}

.type .inner .damaged {margin-bottom: 50px;}
.type .inner .damaged ul {display: grid; grid-template-columns: repeat(2, 1fr); gap: 32px;}
.type .inner .damaged ul li {border-radius: 20px; overflow: hidden; background: #fff;}
.type .inner .damaged ul li .img_box img {border-radius: 20px 20px 0 0;}
.type .inner .damaged ul li .text_box {text-align: center; padding: 50px 5% 30px; position: relative;}
.type .inner .damaged 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%);}
.type .inner .damaged ul li:nth-child(1) .text_box::after {content: '01';}
.type .inner .damaged ul li:nth-child(2) .text_box::after {content: '02';}
.type .inner .damaged ul li:nth-child(3) .text_box::after {content: '03';}
.type .inner .damaged ul li:nth-child(4) .text_box::after {content: '04';}

.type .inner .material ul li {display: flex; align-items: center; gap: 16px; border-radius: 20px; background: #fff; overflow: hidden; padding: 32px 1%; margin-bottom: 32px;}
.type .inner .material ul li:last-child {margin-bottom: 0;}
.type .inner .material ul li .img_box {width: 15%;}
.type .inner .material ul li .text_box {width: 85%;}
.type .inner .material ul li .text_box dt span {display: inline-block; padding: 0 .8em; position: relative;}
.type .inner .material ul li .text_box dt span:first-of-type {padding-left: 0;}
.type .inner .material ul li .text_box dt span:last-of-type::after {display: none;}
.type .inner .material ul li .text_box dt span::after {content: ''; display: inline-block; width: 2px; height: 33px; background: #E2E2E2;
    position: absolute; right: 0; top: 50%; margin-top: -12px;}


/* 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;}

    .target .inner ul li p {font-size: 26px; line-height: 1.5em;}

    .period .inner ul li .text_box p {font-size: 22px; line-height: 1.5em;}

    .type .inner .damaged > p, 
    .type .inner .material > p {font-size: 22px; line-height: 1.5em; padding: 8px 0;}
    .type .inner ul li .text_box dt {font-size: 26px; line-height: 1.5em;}
    .type .inner ul li .text_box dd {font-size: 22px; 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 auto 40px;}
    .definition .inner .emphasis {margin-bottom: 40px;}
    .definition .inner .emphasis p {font-weight: 500; font-size: 26px; letter-spacing: -1px;}
    .definition .inner .emphasis p::before {font-size: 60px; left: -40px; color: rgba(12, 130, 254, 0.40);}
    .definition .inner .emphasis p::after {font-size: 60px; right: -40px; color: rgba(12, 130, 254, 0.40);}
    

    .target .inner ul {width: 90%; gap: 16px;}
    .target .inner ul li p {font-size: 18px; line-height: 22px; letter-spacing: -1px; margin-top: 14px;}


    .period .inner ul {gap: 16px; margin: 20px auto 40px;}
    .period .inner ul li {border-radius: 10px; background: #F3F3F3; border: none;}
    .period .inner ul li .img_box img {border-radius: 10px 10px 0 0;}
    .period .inner ul li .text_box {padding: 17px 5%;}
    .period .inner ul li .text_box p {font-size: 16px; line-height: 22px; color: #000;}
    .period .inner ul li .text_box p i {display: block;}


    .type .inner .damaged > p, 
    .type .inner .material > p {font-size: 16px; line-height: 30px; padding: 3px 0; background: #505050; border-radius: 6px; margin-bottom: 16px;}
    .type .inner ul li .text_box dt {font-size: 22px; line-height: 30px; color: #000; margin-bottom: 6px;}
    .type .inner ul li .text_box dd {font-size: 15px; line-height: 23px;}
    
    .type .inner .damaged {margin-bottom: 40px;}
    .type .inner .damaged ul {gap: 16px;}
    .type .inner .damaged ul li {border-radius: 10px; overflow: hidden; background: #fff;}
    .type .inner .damaged ul li .img_box img {border-radius: 10px 10px 0 0;}
    .type .inner .damaged ul li .text_box {padding: 30px 5%;}
    .type .inner .damaged ul li .text_box::after {width: 36px; height: 36px; font-size: 18px; line-height: 36px; top: -18px;}
    
    .type .inner .material ul li {gap: 40px; border-radius: 10px; padding: 26px 5%; margin-bottom: 16px;}
    .type .inner .material ul li .img_box {width: 20%;}
    .type .inner .material ul li .text_box {width: 80%;}
    .type .inner .material ul li .text_box dt span::after {width: 1px; height: 16px; background: #D9D9D9; margin-top: -5px;}
    .type .inner .material ul li .text_box dd i {display: block;}
}

/* 모바일 가로, 모바일 세로 (해상도 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(233/375 * 100%); background: url(../images/img_intro_banner_mo.png) center no-repeat; background-size: contain;}


    .definition .inner .img_box {width: 70%; margin: 0 auto 30px;}
    .definition .inner .emphasis {margin-bottom: 10px;}
    .definition .inner .emphasis p {font-weight: 700; font-size: 17px; letter-spacing: -1px;}
    .definition .inner .emphasis p::before {font-size: 42px; left: -30px;}
    .definition .inner .emphasis p::after {font-size: 42px; right: -30px;}
    .definition .inner .sub_explain p .block {display: inline;}
    .definition .inner .sub_explain p i {display: block;}


    .target .inner ul {width: 100%; grid-template-columns: repeat(2, 1fr); margin: 30px auto 0; gap: 16px;}
    .target .inner ul li p {font-size: 15px; line-height: 20px;}


    .period .inner ul {grid-template-columns: repeat(1, 1fr); gap: 20px; margin: 0 auto 30px;}
    .period .inner ul li .text_box {padding: 28px 5%;}
    .period .inner ul li .text_box p {font-size: 15px; line-height: 22px; color: #000;}
    .period .inner .sub_explain p .block {display: inline;}
    .period .inner .sub_explain p i {display: block;}


    .type .inner .damaged > p, 
    .type .inner .material > p {font-size: 17px; padding: 6px 0; border-radius: 4px; margin-bottom: 20px;}
    .type .inner ul li .text_box dt {font-size: 20px;}
    .type .inner ul li .text_box dd {font-size: 14px;}
    
    .type .inner .damaged {margin-bottom: 30px;}
    .type .inner .damaged ul {grid-template-columns: repeat(1, 1fr); gap: 20px;}
    .type .inner .damaged ul li .text_box {padding: 30px 5% 18px;}
    
    .type .inner .material ul li {gap: 15px; border-radius: 10px; padding: 10px 2%; margin-bottom: 20px;}
    .type .inner .material ul li .img_box {width: 30%;}
    .type .inner .material ul li .text_box {width: 70%;}
    .type .inner .material ul li .text_box dt span {padding: 0 .3em;}
    .type .inner .material ul li .text_box dd i {display: inline;}
}
