@charset "utf-8";
.btn_auth_link { position: absolute; top: 19px; right: 16px; width: 76px; height: 30px; font-size: 13px; font-weight: 700; color: var(--white); line-height: 31px; text-align: center; padding-left: 2px; background: var(--primary-900); border-radius: 8px; } 
.btn_auth_link::after { width: 10px; height: 14px; background: url(../image/icon/icon_arrow_right_white.svg) no-repeat center center; background-size: 24px; content: ''; display: inline-block; vertical-align: -2px; margin-left: 4px; } 


/* 건강고민선택 */
.concern_section .select_list_box { border-top: 1px solid var(--primary-100); padding-top: 16px; margin-top: 16px; } 
.concern_section .check_list_box ul { display: grid; gap: 8px; grid-template-columns: auto auto auto; } 
.concern_section .check_list_box input + label { position: relative; width: 100%; font-size: 14px; font-weight: 500; line-height: 36px; text-align: center; background: var(--white); border: 1px solid var(--gray-100); border-radius: 4px; display: inline-block; } 
.concern_section .check_list_box input + label span { display: none; position: absolute; right: 4px; top: -10px; width: 34px; height: 20px; font-size: 11px; font-weight: 500; color: var(--white); line-height: 21px; text-align: center; background: var(--gray-700); border-radius: 12px; overflow: hidden; } 
.concern_section .check_list_box input:checked + label { color: var(--primary-500); background: var(--primary-100); border: 1px solid var(--primary-500); } 
.concern_section .check_list_box input:checked + label span { display: block; } 
.concern_section .select_count { color: var(--white); } 
.concern_section .question_box + .toggle_cont { display: none; }
.concern_section .question_box + .toggle_cont .question_box { border-top: 1px solid var(--primary-100); padding-top: 24px; margin-top: 24px; } 
.concern_section .upload_wrap_box { position: relative; }
.concern_section .btn_file_upload { position: absolute; width: 96px; height: 96px; background: var(--gray-50); border: 1px solid var(--primary-100); border-radius: 4px; overflow: hidden; }
.concern_section .btn_file_upload .file_input_box { position: absolute; left: 0; top: 0; width: 100%; height: 100%; z-index: 5; }
.concern_section .btn_file_upload .file_input_box input[type=file] { position: absolute; left: 0; top: 0; width: 100%; height: 100%; cursor: pointer; display: inline-block; opacity: 0; z-index: 5; }
.concern_section .btn_file_upload .file_input_box input[type=file].hide { z-index: 0; }
.concern_section .btn_file_upload .file_count { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); font-size: 15px; font-weight: 700; color: var(--gray-400); line-height: 22px; }
.concern_section .btn_file_upload .file_count::before { width: 24px; height: 24px; background: url(../image/icon/icon_camera.svg) no-repeat center center; background-size: contain; content: ''; display: block; margin: 0 auto 4px; }
.concern_section .btn_file_upload .file_count em { color: var(--primary-500); }
.concern_section .file_list_box::before { width: 96px; height: 96px; content: ''; display: block; margin: 0 8px 8px 0; }
.concern_section .file_list_box { position: relative; display: flex; flex-wrap: wrap; width: 100% }
.concern_section .file_list_box .item { position: relative; width: 96px; height: 96px; background: var(--gray-50); border: 1px solid var(--primary-100); border-radius: 4px; overflow: hidden; box-sizing: border-box; margin: 0 8px 8px 0; } 
.concern_section .file_list_box .item img { height: 100%; object-fit: cover; } 
.concern_section .file_list_box .item .btn_delete { position: absolute; right: 5px; top: 5px; width: 20px; height: 20px; background: url(../image/btn/btn_exit_white.svg) no-repeat center center, rgba(0, 0, 0, 0.7); background-size: 14px; border-radius: 50%; text-indent: -9999px; z-index: 1; display: block; overflow: hidden; } 


/* 검진결과확인방법 */
.checkup_guide_section .checkup_list_box { width: 100%; border: 1px solid var(--gray-100); border-radius: 8px; } 
.checkup_guide_section .checkup_list_box .toggle_tab { width: 100%; font-size: 14px; font-weight: 500; color: var(--gray-400); line-height: 24px; text-align: center; padding: 10px 16px; display: block; } 
.checkup_guide_section .checkup_list_box .toggle_tab::after { width: 24px; height: 24px; background: url(../image/icon/icon_arrow_down_black.svg) no-repeat center center; background-size: contain; content: ''; display: inline-block; opacity: 0.5; vertical-align: -7px; margin-left: 4px; transition: transform 0.1s ease; } 
.checkup_guide_section .checkup_list_box .toggle_tab.on::after { transform: rotate(-180deg); } 
.checkup_guide_section .checkup_list_box .toggle_tab em { color: var(--gray-400); } 
.checkup_guide_section .checkup_list_box .toggle_cont { display: none; overflow: hidden; } 
.checkup_guide_section .checkup_list_box ul { padding: 0 16px 8px; } 
.checkup_guide_section .checkup_list_box ul li { display: flex; align-items: center; padding-top: 8px; border-top: 1px solid var(--gray-75); margin-bottom: 8px; } 
.checkup_guide_section .checkup_list_box ul li:first-of-type { border-top: none; margin-top: 0; } 
.checkup_guide_section .checkup_list_box ul li .name { width: 80px; min-width: 80px; height: 28px; font-size: 13px; font-weight: 400; line-height: 28px; text-align: center; background: var(--gray-75); border-radius: 30px; display: inline-block; margin-right: 8px; } 
.checkup_guide_section .checkup_list_box ul li .text { width: calc(100% - 88px); font-size: 13px; font-weight: 400; color: var(--gray-400); line-height: 18px; word-break: keep-all; } 
.checkup_guide_section .link_list_box { position: relative; } 
.checkup_guide_section .link_list_box .tooltip_box .tooltip_wrap { background: var(--red); } 
.checkup_guide_section .link_list_box .tooltip_box.top .tooltip_wrap::before { border-top: 10px solid var(--red); } 
.checkup_guide_section .link_list_box ul li { margin-bottom: 12px; } 
.checkup_guide_section .link_list_box a { position: relative; width: 100%; padding: 16px; background: var(--white); border: 1px solid var(--primary-500); border-radius: 12px; display: block; } 
.checkup_guide_section .link_list_box a::after { position: absolute; right: 8px; top: 50%; transform: translateY(-50%); width: 24px; height: 24px; background: url(../image/icon/icon_arrow_right_black.svg) no-repeat center center; background-size: contain; content: ''; display: block; z-index: 5; opacity: 0.5; } 
.checkup_guide_section .link_list_box a p { font-size: 16px; font-weight: 700; line-height: 24px; } 
.checkup_guide_section .link_list_box .point { background: var(--primary-500); box-shadow: 0 0 7px 2px rgba(0, 0, 0, 0.1); } 
.checkup_guide_section .link_list_box .point::after { background: url(../image/icon/icon_arrow_right_white.svg) no-repeat center center; opacity: 1; } 
.checkup_guide_section .link_list_box .point p { color: var(--white); } 
.checkup_guide_section .link_list_box .point em { font-size: 13px; font-weight: 400; color: var(--white); line-height: 20px; display: block; margin-top: 2px; } 
.checkup_guide_section .link_list_box .point .img_box { display: inline-block; vertical-align: 2px; margin-left: 4px; } 
.checkup_guide_section .link_list_box .point .img_box img { width: 22px; height: 22px; vertical-align: middle; } 


/* 직접입력 */
@keyframes line-made { 
    0% { width: 0; height: 0; } 
    20% { width: 55px; height: 0; } 
    100% { width: 55px; height: calc(100vh - 100px); } 
}
@keyframes twinkle { 
    0% { opacity: 0; } 
    100% { opacity: 1; } 
}
.checkup_input_section .data_input_wrap { position: relative; border-bottom: 1px solid var(--primary-100); } 
.checkup_input_section .data_title_box { position: relative; display: flex; align-items: center; justify-content: space-between; padding: 18px 32px 18px 0; cursor: pointer; } 
.checkup_input_section .data_title_box::after { position: absolute; right: 0; top: 16px; width: 24px; height: 24px; background: url(../image/icon/icon_arrow_down_black.svg) no-repeat center center; background-size: contain; content: ''; display: block; z-index: 5; } 
.checkup_input_section .active .data_title_box::after { transform: rotate(180deg); } 
.checkup_input_section .data_title_box .label { display: inline-block; height: 24px; font-size: 13px; font-weight: 700; color: var(--gray-400); line-height: 24px; padding: 0 6px; background: var(--gray-75); border-radius: 4px; } 
.checkup_input_section .data_title_box .label.complete { color: var(--black); background: var(--sub-400); } 
.checkup_input_section .data_inner_box { display: none; padding-bottom: 16px; } 
.checkup_input_section .data_inner_box .btn_guide { width: 100%; text-align: left; padding: 20px 24px; background: var(--primary-100); border-radius: 12px; border-top-left-radius: 0; margin-top: 8px; } 
.checkup_input_section .data_inner_box .btn_guide span { font-size: 13px; font-weight: 700; color: var(--primary-500); line-height: 14px; border-bottom: 1px solid var(--primary-500); display: inline-block; } 
.checkup_input_section .data_inner_box .radio_title { display: block; font-size: 14px; font-weight: 500; color: var(--gray-400); margin-bottom: 8px; }
#popup .btn_guide_box { position: fixed; left: 50%; bottom: 0; transform: translateX(-50%); width: 100%; max-width: 480px; height: 100%; z-index: 2000; overflow: hidden; } 
#popup .btn_guide_box .guide_line { position: absolute; right: 100%; top: 14px; width: 0; height: 0; border-top: 1px solid var(--white); border-left: 1px solid var(--white); display: block; z-index: 1; animation: line-made 1s 0.2s ease-in forwards; } 
#popup .btn_guide_box .guide_line::before { position: absolute; right: -7px; top: -9px; width: 18px; height: 18px; background: rgba(255, 255, 255, 0.5); content: ''; display: inline-block; border-radius: 50%; opacity: 0; animation: twinkle 0.5s 1s infinite linear alternate; } 
#popup .btn_guide_box .guide_line::after { position: absolute; right: -3px; top: -5px; width: 10px; height: 10px; background: rgba(255, 255, 255, 1); content: ''; display: inline-block; border-radius: 50%; opacity: 0; animation: twinkle 0.5s 1s infinite linear alternate; } 
#popup .popup_checkup { overflow: visible; } 
#popup .popup_checkup::before { position: absolute; top: -4px; right: 143px; width: 7px; height: 7px; background: var(--white); border-radius: 50%; content: ""; display: inline-block; } 
#popup .popup_checkup .text_box { width: 100%; padding: 20px; background: var(--primary-100); border-radius: 12px; } 
#popup .popup_checkup .text_box p { word-break: keep-all; } 


/* 간편인증 - 인증 수단 선택 */
.certi_select_section .cont_box { position: relative; }
.certi_select_section .icon_nhis { position: absolute; right: 24px; top: 24px; width: 40px; height: 40px; background: url(../image/icon/icon_nhis.svg) no-repeat center center; background-size: contain; display: block; opacity: 0.5; }
.certi_select_section .link_box li { margin-bottom: 8px; }
.certi_select_section .link_box li a { width: 100%; font-size: 16px; font-weight: 500; line-height: 28px; padding: 16px; border: 1px solid var(--primary-100); border-radius: 12px; display: block; }
.certi_select_section .link_box li a::before { width: 28px; height: 28px; content: ''; display: inline-block; vertical-align: -9px; margin-right: 12px; }
.certi_select_section .link_box li a.kakaotalk::before { background: url(../image/icon/icon_pay_kakaotalk.svg) no-repeat center center; background-size: contain; }
.certi_select_section .link_box li a.pass::before { background: url(../image/icon/icon_pay_pass.svg) no-repeat center center; background-size: contain; }
.certi_select_section .link_box li a.toss::before { background: url(../image/icon/icon_pay_toss.svg) no-repeat center center; background-size: contain; }
.certi_select_section .link_box li a.naver::before { background: url(../image/icon/icon_pay_naver.svg) no-repeat center center; background-size: contain; }


/* 간편인증 - 간편인증입력 */
.certi_agree_section .all_check { width: 100%; margin-top: 16px; } 
.certi_agree_section .all_check input[type="checkbox"] { display: none; } 
.certi_agree_section .all_check input[type="checkbox"] + label { display: block; width: 100%; font-size: 16px; font-weight: 700; line-height: 24px; background: var(--white); border: 1px solid var(--primary-100); border-radius: 16px; padding: 16px 12px; }
.certi_agree_section .all_check input[type="checkbox"] + label::before { width: 24px; height: 24px; background: url(../image/icon/icon_chkbox_circle_off.svg) no-repeat center center; background-size: contain; vertical-align: -7px; margin-right: 12px; display: inline-block; content: ''; } 
.certi_agree_section .all_check input[type="checkbox"]:checked + label::before { background: url(../image/icon/icon_chkbox_circle_on.svg) no-repeat center center; background-size: contain; } 
.certi_agree_section .agree_chk_list { padding: 16px 12px 0; } 
.certi_agree_section .agree_chk_list li { display: flex; align-items: center; justify-content: space-between; margin-bottom: 24px; } 
.certi_agree_section .agree_chk_list li:last-of-type { margin-bottom: 0; } 
.certi_agree_section .agree_chk_list li button { font-size: 15px; color: var(--gray-400); line-height: 24px; text-decoration: underline; } 
.certi_agree_section .agree_chk_list .chk_box input[type="checkbox"] { display: none; } 
.certi_agree_section .agree_chk_list .chk_box input[type="checkbox"] + label { position: relative; font-size: 15px; line-height: 24px; padding-left: 32px; } 
.certi_agree_section .agree_chk_list .chk_box input[type="checkbox"] + label::before { position: absolute; left: 0; top: 50%; transform: translateY(-50%); width: 24px; height: 24px; background: url(../image/icon/icon_check_gray.svg) no-repeat center center; background-size: contain; border-radius: 50%; content: ""; display: inline-block; } 
.certi_agree_section .agree_chk_list .chk_box input[type="checkbox"]:checked + label::before { background: url(../image/icon/icon_check_primary.svg) no-repeat center center; background-size: contain; } 
.certi_agree_section .agree_chk_list .chk_box input[type="checkbox"]:checked + label { font-weight: bold; color: var(--primary-500); }


/* 간편인증 - 인증메세지 */
.certi_confirm_section .guide_box.type_kakao { text-align: center; }
.certi_confirm_section .guide_box.type_kakao img { width: 170px; }
.certi_confirm_section .guide_box.type_kakao p { font-size: 16px; font-weight: 700; color: var(--gray-400); line-height: 24px; }
.certi_confirm_section .guide_box .icon { width: 94px; height: 94px; display: block; margin: 0 auto; }
.certi_confirm_section .guide_box .icon_naver { background: url(../image/icon/icon_mobile_naver.svg) no-repeat center center; background-size: contain;  }
.certi_confirm_section .guide_box .icon_toss { background: url(../image/icon/icon_mobile_toss.svg) no-repeat center center; background-size: contain; }
.certi_confirm_section .guide_box .icon_pass { background: url(../image/icon/icon_mobile_pass.svg) no-repeat center center; background-size: contain; }
.certi_confirm_section .guide_box .text_box { padding: 16px; background: var(--primary-100); border-radius: 12px; }
.certi_confirm_section .guide_box .text_box h3 { font-size: 16px; font-weight: 700; color: var(--primary-500); line-height: 22px; margin-bottom: 8px; }
.certi_confirm_section .guide_box .text_box p { font-size: 14px; font-weight: 400; line-height: 20px; word-break: keep-all; }
.certi_confirm_section .guide_box .text_box p img { width: 14px; vertical-align: middle; }
.certi_confirm_section .guide_box .text_box p a { color: var(--primary-500); text-decoration: underline; display: inline-block; }


/* 간편인증 - 검진기록 확인 */
@keyframes aniProgressImg {
    0% { opacity: 0; transform: scale(0%); }
    10% { opacity: 1; transform: scale(100%); }
    100% { opacity: 1; transform: scale(100%); } 
}
@keyframes aniProgressBar { 
    0% { width: 0; }
    8% { width: 0; }
    30% { width: 56px; }
}
@keyframes aniProgressBar2 { 
    0% { width: 0; }
    20% { width: 0; }
    50% { width: 100%; }
}
.checkup_inquiry_section .icon_nhis { width: 40px; height: 40px; background: url(../image/icon/icon_nhis.svg) no-repeat center center; background-size: contain; display: block; }
.checkup_inquiry_section .progress_box { text-align: left; }
.checkup_inquiry_section .progress_box ul { width: 168px; }
.checkup_inquiry_section .progress_box ul li { margin-bottom: 8px; }
.checkup_inquiry_section .progress_box ul li:last-of-type { margin-bottom: 0; }
.checkup_inquiry_section .progress_box .bar_wrap { display: flex; align-items: center; }
.checkup_inquiry_section .progress_box .bar_wrap .img_box { width: 40px; height: 40px; background: var(--primary-100); border-radius: 8px; margin-right: 8px; animation: aniProgressImg 4s infinite; }
.checkup_inquiry_section .progress_box .bar_wrap .desc_box { width: calc(100% - 48px); }
.checkup_inquiry_section .progress_box .bar_wrap .desc_box span { height: 8px; background: var(--primary-100); border-radius: 2px; display: block; }
.checkup_inquiry_section .progress_box .bar_wrap .desc_box .bar01 { width: 56px; animation: aniProgressBar 4s infinite; }
.checkup_inquiry_section .progress_box .bar_wrap .desc_box .bar02 { width: 100%; margin-top: 4px; animation: aniProgressBar2 4s infinite; }
.checkup_inquiry_section .progress_box .bar_wrap:last-of-type .img_box { animation-delay: 2s; } 
.checkup_inquiry_section .progress_box .bar_wrap:last-of-type .bar01 { animation-delay: 2s; } 
.checkup_inquiry_section .progress_box .bar_wrap:last-of-type .bar02 { animation-delay: 2s; } 
.checkup_inquiry_section .progress_box .text { font-size: 14px; font-weight: 400; line-height: 22px; }
.checkup_inquiry_section .progress_box .text span,
.checkup_inquiry_section .progress_box .text strong { color: var(--primary-500); }
.checkup_inquiry_section .progress_box .text .min::after { content: "분"; display: inline-block; }
.checkup_inquiry_section .progress_box .text .sec::after { content: "초"; display: inline-block; }
.checkup_inquiry_section .tip_slider_box { position: absolute; bottom: 0; width: 100%; padding: 24px; overflow: hidden; }
.checkup_inquiry_section .tip_slider_box .swiper-slide { width: 100%; padding: 16px 20px; border: 1px solid var(--gray-75); border-radius: 12px; }
.checkup_inquiry_section .tip_slider_box .swiper-slide .label { font-size: 13px; font-weight: 700; color: var(--sub-500); line-height: 18px; text-align: center; padding: 0 8px; background: var(--white); border: 2px solid var(--sub-500); border-radius: 12px; display: inline-block; }
.checkup_inquiry_section .tip_slider_box .swiper-slide .name { font-size: 14px; font-weight: 700; line-height: 22px; display: inline-block; vertical-align: -1px; margin-left: 4px; }
.checkup_inquiry_section .tip_slider_box .swiper-slide .guide_text { font-size: 14px; font-weight: 400; line-height: 20px; margin-top: 4px; }


/* 간편인증 - 인증완료 */
.concern_result_section .text_box { width: 100%; text-align: center; padding-top: 64px; }
.concern_result_section .text_box .icon_clap { width: 68px; height: 68px; background: url(../image/icon/icon_clap.svg) no-repeat center center; background-size: contain; display: inline-block; }


/* 간편인증 - 완료 */
.concern_final_section .running_box { display: flex; align-items: flex-end; }
.concern_final_section .running_box img:first-of-type { width: 138px; }
.concern_final_section .running_box span { font-size: 16px; font-weight: 700; color: var(--gray-300); line-height: 24px; display: inline-block; margin: 0 2px 0 8px; }
.concern_final_section .running_box img:last-of-type { width: 24px; }


/* 설문조사 */
.survey_section .chkbox_area.type_mul01 > ul { display: grid; gap: 8px; grid-template-columns: repeat(3, 1fr); }
.survey_section .chkbox_area.type_mul01 > ul input + label { position: relative; width: 100%; height: 38px; font-size: 14px; font-weight: 500; line-height: 36px; text-align: center; background: var(--white); border: 1px solid var(--gray-100); border-radius: 8px; box-sizing: border-box; display: inline-block; }
.survey_section .chkbox_area.type_mul01 > ul input + label span { display: none; position: absolute; right: 4px; top: -10px; width: 34px; height: 20px; font-size: 11px; font-weight: 500; color: var(--white); line-height: 21px; text-align: center; background: var(--gray-700); border-radius: 12px; overflow: hidden; } 
.survey_section .chkbox_area.type_mul01 > ul input:checked + label { color: var(--primary-500); background: var(--primary-100); border: 1px solid var(--primary-500); }
.survey_section .chkbox_area.type_mul01 > ul input:checked + label span { display: block; } 
.survey_section .chkbox_area.type_2way > ul { display: grid; gap: 12px; grid-template-columns: repeat(2, 1fr); }
.survey_section .chkbox_area.type_2way > ul input + label { display: flex; flex-direction: column; justify-content: center; align-items: center; height: 104px; background: var(--white); border: 1px solid var(--gray-100); border-radius: 12px; box-sizing: border-box; }
.survey_section .chkbox_area.type_2way > ul input:checked + label { background: var(--primary-100); border: 1px solid var(--primary-500); }
.survey_section .chkbox_area.type_2way > ul label img { width: 40px; }
.survey_section .chkbox_area.type_2way > ul label .text { font-size: 16px; font-weight: 500; line-height: 22px; margin-top: 8px; }
.survey_section .chkbox_area.type_2way > ul input:checked + label .text { color: var(--primary-500); }
.survey_section .select_list_area.type_mul01 > ul > li { display: flex; justify-content: space-between; align-items: center; }
.survey_section .select_list_area.type_mul01 > ul > li + li { margin-top: 16px; }
.survey_section .select_list_area.type_mul01 .text_area { display: flex; align-items: center; }
.survey_section .select_list_area.type_mul01 .text_area .main_text { font-size: 16px; font-weight: 500; line-height: 22px; }
.survey_section .select_list_area.type_mul01 .text_area .unit_text { font-size: 14px; font-weight: 500; color: var(--gray-300); line-height: 22px; }
.survey_section .select_list_area.type_mul01 select { width: 92px; height: 40px; font-size: 16px; font-weight: 400; line-height: 40px; padding: 0 36px 0 16px; background: url(../image/icon/icon_arrow_down_black.svg) no-repeat calc(100% - 10px) center, var(--white); background-size: 24px; border: 1px solid var(--gray-100); border-radius: 8px; }
.survey_section .name_view_area { position: relative; width: 260px; height: 300px; background: url(../image/img_pack.png) no-repeat center center; background-size: contain; margin: 0 auto; }
.survey_section .name_view_area .text_box { position: absolute; left: 40px; top: 60px; width: 175px; font-size: 22px; font-weight: 700; line-height: 20px; }
.survey_section .name_view_area .text_box .target_name { display: inline-block; vertical-align: middle; }
.survey_section .btn_box { text-align: center; }
.survey_section .btn_box .btn_reset { font-size: 14px; font-weight: 500; color: var(--gray-300); line-height: 20px; border-bottom: 1px solid var(--gray-300); display: inline-block; }
.progress_bar_box .text { font-size: 14px; font-weight: 700; color: var(--primary-500); line-height: 22px; text-align: right; display: block; }
.progress_bar_box .bar_wrap { position: relative; width: 100%; height: 8px; background: var(--primary-100); overflow: hidden; margin-top: 12px; }
.progress_bar_box .bar { position: absolute; left: 0; top: 0; height: 100%; background: var(--primary-500); display: block; }

/* 설문조사 */
.survey_result_section .img_box { width: 90%; min-width: 310px; margin: 0 auto; }