@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 ul {display: grid; grid-template-columns: repeat(3, 1fr); gap: 34px; margin: 100px 0 50px;}
.definition .inner ul li {border-radius: 20px; border: 2px solid #E2E2E2;}
.definition .inner ul li .img_box img {border-radius: 20px 20px 0 0;}
.definition .inner ul li .text_box {padding: 56px 2% 46px; text-align: center; position: relative;}
.definition .inner ul li .text_box > span {display: inline-block; width: 120px; height: 120px; line-height: 120px; font-weight: 700; font-size: 40px; letter-spacing: -2px;
    color: #161718; background: #fff; border-radius: 50%; position: absolute; top: -60px; left: 50%; transform: translateX(-50%);}
.definition .inner ul li .text_box p {font-weight: 300; font-size: 30px; line-height: 40px; letter-spacing: -2.15px; color: #505050;}


.maxillary {background: #F7F7F7;}
.maxillary .inner .maxillary_sinus {border-radius: 20px; border: 2px solid #E2E2E2; margin-top: 100px;}
.maxillary .inner .maxillary_sinus .img_box {width: 100%; }
.maxillary .inner .maxillary_sinus .img_box img {border-radius: 20px 20px 0 0;}
.maxillary .inner .maxillary_sinus p {padding: 76.5px 2%; background: #fff; border-radius: 0 0 20px 20px;
    font-weight: 300; font-size: 30px; line-height: 45px; letter-spacing: -1px; text-align: center; color: #505050;}
.maxillary .inner ul {display: grid; grid-template-columns: repeat(2, 1fr); gap: 40px; margin: 80px 0 20px;}
.maxillary .inner ul li {border-radius: 20px; border: 2px solid #E2E2E2;}
.maxillary .inner ul li .img_box {width: 100%; }
.maxillary .inner ul li .img_box img {border-radius: 20px 20px 0 0;}
.maxillary .inner ul li p {font-weight: 700; font-size: 40px; line-height: 50px; letter-spacing: -1px; color: #fff; 
    padding: 30px 2%; text-align: center; border-radius: 0 0 20px 20px;}
.maxillary .inner ul li:nth-child(1) p {background: #8B898D;}
.maxillary .inner ul li:nth-child(2) p {background: #0C82FE;}
.maxillary .inner .notice {font-weight: 350; font-size: 30px; line-height: 46px; letter-spacing: -1px; color: #505050; text-align: center; margin-bottom: 80px;}


.step .inner ul {margin-top: 50px;}
.step .inner ul li {display: grid; grid-template-columns: repeat(2, 1fr); border-radius: 20px; border: 2px solid #E2E2E2; margin-bottom: 45px;}
.step .inner ul li:last-child {margin-bottom: 0;}
.step .inner ul li .img_box img {height: 100%; object-fit: cover; border-radius: 20px 0 0 20px;}
.step .inner ul li .text_box {padding: 40px 7%; box-sizing: border-box; display: flex; flex-direction: column; justify-content: center;}
.step .inner ul li .text_box dt {font-weight: 700; font-size: 40px; line-height: 55px; letter-spacing: -1px; color: #505050; margin-bottom: 0.5em;}
.step .inner ul li .text_box dt span {display: block;}
.step .inner ul li .text_box dd {font-weight: 300; font-size: 30px; line-height: 45px; letter-spacing: -1px; color: #505050;}


.effect {background: #F7F7F7;}
.effect .inner ul {width: 80%; display: flex; justify-content: center; gap: 90px; margin: 190px auto 50px;}
.effect .inner ul li {width: 30%; position: relative;}
.effect .inner ul li::before {display: block; content: ""; width: 60%; padding-top: calc(324/168*60%); background: url(../images/icon_arrow_bg.png) center no-repeat;
    background-size: 100%; position: absolute; top: -33%; right: -10%;}
.effect .inner ul li::after {display: block; content: ""; padding-bottom: 100%;}
.effect .inner ul li p {width: 100%; height: 100%; object-fit: cover; background: #fff; border: 5px solid #FFD852; border-radius: 50%;
    font-size: 40px; line-height: 55px; letter-spacing: -1px; text-align: center;
    display: flex; flex-direction: column; justify-content: center; position: absolute; top: 0; left: 0;}
.effect .inner ul li p strong {display: block;}


.material {background: #EAF2FF;}
.material .inner ul {display: grid; grid-template-columns: repeat(5, 1fr); gap: 10px; margin: 50px 0;}
.material .inner ul li {background: #fff; border-radius: 20px; overflow: hidden; padding: 35px 2%; text-align: center;}
.material .inner ul li > span {display: inline-block; width: 60px; height: 60px; line-height: 60px;
    font-weight: 700; font-size: 26px; letter-spacing: -2.5px; color: #fff; background: #0C82FE; border-radius: 50%;}
.material .inner ul li dl dt {font-weight: 700; font-size: 40px; line-height: 55px; letter-spacing: -1px; color: #161718; margin: .4em 0 .2em;}
.material .inner ul li dl 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: 100px 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: 40px; line-height: 55px; letter-spacing: -1px; text-align: center; color: #000; margin-top: 29px;}


.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;}


/* 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 .text_box > span {width: 100px; height: 100px; line-height: 100px; font-size: 28px; top: -50px;}
    .definition .inner ul li .text_box p {font-size: 22px; line-height: 28px;}

    .maxillary .inner .maxillary_sinus p {font-size: 22px; line-height: 1.5em;}
    .maxillary .inner ul li p {font-size: 28px; line-height: 1.2em;}
    .maxillary .inner .notice {font-size: 20px; line-height: 1.5em;}

    .step .inner ul li .text_box dt {font-size: 22px; line-height: 30px;}
    .step .inner ul li .text_box dd {font-size: 18px; line-height: 23px;}

    .effect .inner ul li p {font-size: 22px; line-height: 1.2em;}

    .material .inner ul li > span {width: 44px; height: 44px; line-height: 44px; font-size: 22px;}
    .material .inner ul li dl dt {font-size: 28px; line-height: 1.2em;}
    .material .inner ul li dl dd {font-size: 22px; line-height: 1.2em;}

    .target .inner ul li p {font-size: 26px; line-height: 1.5em;}

    .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;}
}
/* 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 ul {width: 90%; gap: 16px; margin: 40px auto 20px;}
    .definition .inner ul li {border-radius: 10px; border: 1px solid #E2E2E2;}
    .definition .inner ul li .img_box img {border-radius: 10px 10px 0 0;}
    .definition .inner ul li .text_box {padding: 26px 2%;}
    .definition .inner ul li .text_box > span {width: 56px; height: 56px; line-height: 56px; font-size: 18px; letter-spacing: -1px; top: -28px;}
    .definition .inner ul li .text_box p {font-size: 16px; line-height: 22px; letter-spacing: -1px;}


    .maxillary .inner .maxillary_sinus {border-radius: 10px; border: 1px solid #E2E2E2; margin-top: 40px;}
    .maxillary .inner .maxillary_sinus .img_box img {border-radius: 10px 10px 0 0;}
    .maxillary .inner .maxillary_sinus p {padding: 30px 2%; border-radius: 0 0 10px 10px; font-size: 16px; line-height: 22px;}
    .maxillary .inner ul {gap: 16px; margin: 32px 0 20px;}
    .maxillary .inner ul li {border-radius: 10px; border: 1px solid #E2E2E2;}
    .maxillary .inner ul li .img_box img {border-radius: 10px 10px 0 0;}
    .maxillary .inner ul li p {font-size: 22px; line-height: 30px; padding: 12px 2%; border-radius: 0 0 10px 10px;}
    .maxillary .inner .notice {font-size: 16px; line-height: 22px; margin-bottom: 40px;}


    .step .inner ul {margin-top: 20px;}
    .step .inner ul li {border-radius: 10px; border: 1px solid #E2E2E2; margin-bottom: 16px;}
    .step .inner ul li .img_box img {border-radius: 10px 0 0 10px;}
    .step .inner ul li .text_box dt {font-size: 22px; line-height: 30px;}
    .step .inner ul li .text_box dt span {font-size: 20px;}
    .step .inner ul li .text_box dd {font-size: 16px; line-height: 22px;}


    .effect .inner ul {gap: 46px; margin: 75px auto 20px;}
    .effect .inner ul li p {border: 3px solid #FFD852; font-size: 16px; line-height: 22px;}


    .material .inner ul {display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; margin: 20px 0;}
    .material .inner ul li {border-radius: 10px; padding: 10px 2%;}
    .material .inner ul li > span {width: 32px; height: 32px; line-height: 32px; font-size: 14px; letter-spacing: -0.6px;}
    .material .inner ul li dl dt {font-size: 22px; line-height: 30px;}
    .material .inner ul li dl dd {font-size: 16px; line-height: 22px;}


    .target .inner ul {margin: 40px auto 0; gap: 16px;}
    .target .inner ul li p {font-size: 22px; line-height: 22px; letter-spacing: -1px; margin-top: 0;}


    .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%;}
}

/* 모바일 가로, 모바일 세로 (해상도 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; 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 {padding: 50px 5% 0;}
    .intro_banner .inner {position: relative; top: 0; transform: translate(-50%, 0);}
    .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(262/375 * 100%); background: url(../images/img_intro_banner_mo.png) center no-repeat; background-size: contain;}


    .definition .inner .sub_explain p .block {display: inline;}
    .definition .inner .sub_explain p i {display: block;}
    .definition .inner ul {width: 100%; gap: 20px; margin: 30px 0; grid-template-columns: repeat(1, 1fr);}
    .definition .inner ul li {display: flex; align-items: center;}
    .definition .inner ul li .img_box {width: 50%;}
    .definition .inner ul li .img_box img {border-radius: 10px 0 0 10px;}
    .definition .inner ul li .text_box {width: 50%; padding: 0 7%; box-sizing: border-box;}
    .definition .inner ul li .text_box > span {width: 50px; height: 50px; line-height: 50px; top: 50%; left: -25px; transform: translateY(-50%);}
    .definition .inner ul li .text_box p {font-size: 16px; line-height: 22px; letter-spacing: -1px;}


    .maxillary .inner .sub_explain .block {display: inline;}
    .maxillary .inner .sub_explain i {display: block;}
    .maxillary .inner .maxillary_sinus {margin-top: 30px;}
    .maxillary .inner .maxillary_sinus p {font-size: 15px;}
    .maxillary .inner .maxillary_sinus p .block {display: inline;}
    .maxillary .inner .maxillary_sinus p i {display: block;}
    .maxillary .inner ul {grid-template-columns: repeat(1, 1fr); gap: 20px; margin: 40px 0 20px;}
    .maxillary .inner ul li p {font-size: 24px; line-height: 38px; padding: 10px 2%;}
    .maxillary .inner .notice {font-size: 14px; line-height: normal;}


    .step .inner .title_text i {display: block;}
    .step .inner ul {margin-top: 10px;}
    .step .inner ul li {grid-template-columns: repeat(1, 1fr); margin-bottom: 20px;}
    .step .inner ul li .img_box img {border-radius: 10px 10px 0 0;}
    .step .inner ul li .text_box {padding: 30px 5%;}
    .step .inner ul li .text_box dt {font-size: 20px; color: #000;}
    .step .inner ul li .text_box dt span {font-size: 17px;}
    .step .inner ul li .text_box dd {font-size: 15px;}


    .effect .inner ul {width: 100%; gap: 20px; margin: 60px auto 30px;}
    .effect .inner ul li p {font-size: 20px; line-height: 25px;}
    .effect .inner ul li::before {top: -39%;}
    .effect .inner .sub_explain i {display: block;}


    .material .inner ul {grid-template-columns: repeat(1, 1fr); gap: 12px; margin: 10px 0 30px;}
    .material .inner ul li {border-radius: 8px; padding: 15px 5%; display: flex; align-items: center;}
    .material .inner ul li > span {width: 36px; height: 36px; line-height: 36px; font-size: 24px; letter-spacing: -1px; margin-right: 4%;}
    .material .inner ul li dl {text-align: left;}
    .material .inner ul li dl dt {font-size: 20px;}
    .material .inner ul li dl dd {font-size: 14px; line-height: 23px;}
    .material .inner ul li dl dd .block {display: inline;}
    .material .inner .sub_explain .block {display: inline;}
    .material .inner .sub_explain i {display: block;}


    .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;}


    .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%;}
}



/*20241204 dim 추가*/
.img_box {
    position: relative;
    display: inline-block;
}

.img_box .overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.7); /* 반투명 배경 */
    color: white;
    font-size: 1.6rem;
    font-weight: bold;
    text-align: center;
    line-height: 100%; /* 이미지 높이에 따라 조정 */
    display: flex;
    align-items: center; /* 수직 가운데 정렬 */
    justify-content: center; /* 수평 가운데 정렬 */
    border-radius: 14px 14px 0 0;
}
