@charset "utf-8";
/* common */
.mt02 { margin-top: 2px !important; }
.mt06 { margin-top: 6px !important; }
.mt10 { margin-top: 10px !important; }
.mt12 { margin-top: 12px !important; }
.mt16 { margin-top: 16px !important; }
.mt20 { margin-top: 20px !important; }
.mt26 { margin-top: 26px !important; }
.mt30 { margin-top: 30px !important; }
.mt40 { margin-top: 40px !important; }
.mt60 { margin-top: 60px !important; }
.mt72 { margin-top: 72px !important; }
.mr12 { margin-right: 12px !important; }
.fs32 { font-size: 32px; line-height: 40px; }
.fs28 { font-size: 28px; line-height: 36px; }
.fs24 { font-size: 24px; line-height: 32px; }
.fs20 { font-size: 20px; line-height: 28px; }
.fs18 { font-size: 18px; font-weight: 700; line-height: 24px; }
.fs16 { font-size: 16px; line-height: 22px; }
.fs14 { font-size: 14px; line-height: 20px; }
.fs13 { font-size: 13px; line-height: 19px; }
.fs12 { font-size: 12px; line-height: 18px; }
.fw500 { font-weight: 500 !important; }
.fw700 { font-weight: 700 !important; }
.f_blue { color: #3D5DF0 !important; }
.f_black { color: #222 !important; }

/* GREEN */
.package_wrap.type_green .package_main_box .package_title,
.package_wrap.type_green .package_main_box .tag_list span,
.package_wrap.type_green .package_detail_box .title_line span,
.package_wrap.type_green .content_graph_box .graph_title b,
.package_wrap.type_green .content_graph_box .graph_wrap .bar_label,
.package_wrap.type_green .nuts_card_box .detail_box .title,
.package_wrap.type_green .pillgram_tip > p b,
.package_wrap.type_green .why_pillgram > p b,
.package_wrap.type_green .why_pillgram .qna_box .a_box b,
.package_wrap.type_green .package_add_box .btn_add_box .btn { color: #2aad5c; }
.package_wrap.type_green .package_detail_box .title_line span::before,
.package_wrap.type_green .package_detail_box .title_line span::after,
.package_wrap.type_green .content_graph_box .graph_wrap .bar,
.package_wrap.type_green .nuts_card_box .detail_box .unit,
.package_wrap.type_green .point_info_box .point_title > span { background: #2aad5c; }
.package_wrap.type_green .package_main_box .tag_list span { border: 1px solid #2aad5c; }
.package_wrap.type_green .package_components_box .nuts_list_box ul li::before { background: url(../../image/icon/icon_check_circle_primary.svg) no-repeat center center; background-size: contain; }

/* BLUE */
.package_wrap.type_blue .package_main_box .mark,
.package_wrap.type_blue .package_main_box .package_title,
.package_wrap.type_blue .package_main_box .tag_list span,
.package_wrap.type_blue .package_detail_box .title_line span,
.package_wrap.type_blue .package_main_text p b ,
.package_wrap.type_blue .content_graph_box .graph_title b,
.package_wrap.type_blue .content_graph_box .graph_wrap .bar_label,
.package_wrap.type_blue .nuts_card_box .detail_box .title,
.package_wrap.type_blue .pillgram_tip > p b,
.package_wrap.type_blue .why_pillgram > p b,
.package_wrap.type_blue .why_pillgram .qna_box .a_box b,
.package_wrap.type_blue .package_add_box .btn_add_box .btn,
.package_wrap.type_blue .package_components_box .nuts_list_box ul li .nuts_name { color: #3D5DF0; }
.package_wrap.type_blue .package_detail_box .title_line span::before,
.package_wrap.type_blue .package_detail_box .title_line span::after,
.package_wrap.type_blue .content_graph_box .graph_wrap .bar,
.package_wrap.type_blue .nuts_card_box .detail_box .unit,
.package_wrap.type_blue .point_info_box .point_title > span { background: #3D5DF0; }
.package_wrap.type_blue .package_main_box .tag_list span { border: 1px solid #3D5DF0; }
.package_wrap.type_blue .package_main_box .mark::before { background: rgba(61, 93, 240, 0.20); }
.package_wrap.type_blue .package_components_box .nuts_list_box ul li::before { background: url(../../image/icon/icon_check_circle_blue.svg) no-repeat center center; background-size: contain; }


/* 면역튼튼패키지 */
.package_immune.package_wrap .package_main_box { height: 114vw; max-height: 547px; min-height: 410px; padding: 40px; background: url(../../image/bg_care_package_main.webp) no-repeat center center; background-size: cover; }


/* SKY패키지 */
.package_sky.package_wrap .main_package_sky { width: 100%; height: 161vw; max-height: 755px; min-height: 576px; text-align: center; padding: 24px 40px; background: url(../../image/bg_sky_package_main.webp) no-repeat center center; background-size: cover; }
.package_sky.package_wrap .main_package_sky > .sticker { display: block; width: 99px; height: 92px; background: url(../../image/img_sky_package_sticker.webp) no-repeat center center; background-size: contain; margin: 0 auto; }
.package_sky.package_wrap .main_package_sky > .text { position: relative; font-size: 24px; font-weight: 400; color: #222; line-height: 28px; display: inline-block; z-index: 1; }
.package_sky.package_wrap .main_package_sky > .text::before { position: absolute; left: 0; bottom: 0; width: 100%; height: 10px; background: #fff; content: ''; display: block; z-index: -1; }
.package_sky.package_wrap .main_package_sky > h2 { font-size: 48px; font-weight: 800; color: #222; line-height: 57px; }
.package_sky.package_wrap .package_main_text p:first-of-type::before,
.package_sky.package_wrap .package_main_text p:first-of-type::after { background: url(../../image/icon/icon_quotes_blue.svg) no-repeat center center; background-size: contain; }
.package_sky.package_wrap .bg_blue { background: #ECEFFE; }
.package_sky.package_wrap .bg_gray { background: #f6f6f6; }
.package_sky.package_wrap .bg_wave { position: relative; padding-top: 100px !important; background: url(../../image/bg_sky_package_wave.svg) no-repeat center top; background-size: 100%; }
.package_sky.package_wrap .package_detail_box { padding: 48px 20px; }

/* 공통 */
.package_main_box { width: 100%; overflow: hidden; }
.package_main_box .mark { position: relative; font-size: 16px; font-weight: 400; line-height: 20px; display: inline-block; z-index: 1; margin-bottom: 8px; }
.package_main_box .mark::before { position: absolute; left: 0; bottom: 0; width: 100%; height: 8px; content: ''; display: block; z-index: -1; }
.package_main_box .package_title { font-size: 38px; font-weight: 800; line-height: 46px; }
.package_main_box .tag_list { display: flex; flex-wrap: wrap; align-items: center; }
.package_main_box .tag_list span { display: inline-block; font-size: 12px; font-weight: 500; white-space: nowrap; padding: 4px 10px; border-radius: 6px; margin: 0 4px 4px 0; }
.package_main_box .tag_list span.main_tag { font-size: 18px; } 

.package_detail_box { padding: 60px 20px 20px; }
.package_detail_box .title_line { width: 100%; text-align: center; overflow: hidden; }
.package_detail_box .title_line span { position: relative; font-size: 18px; font-weight: 700; line-height: 24px; display: inline-block; }
.package_detail_box .title_line span::before,
.package_detail_box .title_line span::after { position: absolute; top: 50%; transform: translateY(-50%); width: 200px; height: 1px; content: ''; display: block; }
.package_detail_box .title_line span::before { right: calc(100% + 10px); }
.package_detail_box .title_line span::after { left: calc(100% + 10px); }

.package_main_text { text-align: center; }
.package_main_text p:first-of-type::before,
.package_main_text p:first-of-type::after { width: 24px; height: 20px; content: ''; display: block; margin: 0 auto; }
.package_main_text p:first-of-type::before { margin-bottom: 20px; }
.package_main_text p:first-of-type::after { transform: scale(-1); margin-top: 20px; }
.package_main_text p:last-of-type::before { width: 2px; height: 45px; background: #E0E0E0; content: ''; display: block; margin: 24px auto; }

.package_group_box { text-align: center; }
.package_group_box .img_box { max-width: 340px; margin: 0 auto; }

.keypoint_box ul { padding: 0 16px; }
.keypoint_box ul li { position: relative; font-size: 16px; font-weight: 400; color: #222; line-height: 32px; padding-left: 32px; }
.keypoint_box ul li::before { position: absolute; left: 0; top: 3px; width: 24px; height: 24px; background: url(../../image/icon/icon_check_circle_black.svg); background-size: contain; content: ''; display: block; }

.content_graph_box { width: 100%; padding: 10px 20px; background: #f2f2f2; border-radius: 12px; }
.content_graph_box ul li { padding: 30px 0; border-bottom: 1px solid #e3e3e3; }
.content_graph_box ul li:last-of-type { border-bottom: none; }
.content_graph_box .graph_title { font-size: 16px; font-weight: 700; line-height: 20px; margin-bottom: 12px; }
.content_graph_box .graph_wrap { display: flex; align-items: center; margin-top: 4px; }
.content_graph_box .graph_wrap .bar_label { width: 100px; font-size: 12px; font-weight: 400; line-height: 14px; }
.content_graph_box .graph_wrap .bar_wrap { position: relative; width: calc(100% - 110px); height: 8px; border-radius: 4px; overflow: hidden; margin-left: 10px; }
.content_graph_box .graph_wrap .bar { position: absolute; left: 0; top: 0; height: 100%; border-radius: 4px; display: block; }
.content_graph_box .graph_wrap.standard .bar_label { color: #999 !important; }
.content_graph_box .graph_wrap.standard .bar { background: #D9D9D9 !important; }


.content_graph_list > .text { font-size: 10px; font-weight: 400; color: #757575; text-align: right; display: block; }
.content_graph_box02 { width: 100%; padding: 18px 12px; background: #fff; border: 1px solid #3D5DF0; border-radius: 8px; }
.content_graph_box02 .graph_title { font-size: 18px; font-weight: 700; line-height: 22px; text-align: center; }
.content_graph_box02 .graph_title span { display: inline-block; margin: 0 4px; }

.point_info_box .point_title { width: 100%; text-align: center; }
.point_info_box .point_title > span { display: inline-block; font-size: 14px; font-weight: 700; color: #ffffff; line-height: 18px; padding: 6px 16px; border-radius: 20px 20px 0px 20px; }
.point_info_box .point_title > h3 { font-size: 28px; font-weight: 700; color: #222; line-height: 36px; }
.point_info_box .point_title p span { display: inline-block; }
.point_info_box .point_title p img { vertical-align: -2px; }
.point_info_box .img_box { width: 100%; overflow: hidden; }
.point_info_box .img_box p { font-size: 13px; font-weight: 400; color: #939393; line-height: 16px; text-align: right; margin-top: 8px; }
.point_info_box .supplier_list_box li { display: flex; align-items: center; justify-content: center; padding: 12px 0; border-bottom: 1px solid #eee; }
.point_info_box .supplier_list_box li:last-of-type { border-bottom: none; }
.point_info_box .supplier_list_box .flag_box { width: 70px; height: 70px; background: #aaa; border-radius: 50%; overflow: hidden; }
.point_info_box .supplier_list_box dl { width: 180px; margin-left: 20px; }
.point_info_box .supplier_list_box dl dt { font-size: 16px; font-weight: 700; color: #222; line-height: 22px; }
.point_info_box .supplier_list_box dl dd { font-size: 14px; font-weight: 400; color: #aaa; line-height: 20px; }

.nuts_card_box .text_sources { font-size: 8px; font-weight: 400; color: #757575; line-height: 12px; text-align: center; }
.nuts_card_box .img_box { width: 100%; border-radius: 12px 12px 0 0; overflow: hidden; }
.nuts_card_box .detail_box { position: relative; width: 100%; padding: 48px 20px; border-radius: 0 0 12px 12px; }
.nuts_card_box .detail_box .unit { position: absolute; right: 12px; top: -80px; width: 107px; height: 107px; display: flex; flex-direction: column; align-items: center; justify-content: center; font-size: 14px; color: #fff; letter-spacing: -0.5px; line-height: 18px; text-align: center; background: #2aad5c; border-radius: 50%; }
.nuts_card_box .detail_box .unit em { font-size: 8px; letter-spacing: 0; line-height: 12px; }
.nuts_card_box .detail_box .effect { font-size: 18px; font-weight: 700; line-height: 24px; text-align: center; display: block; }
.nuts_card_box .detail_box dl { width: 100%; text-align: center; }
.nuts_card_box .detail_box .title { font-size: 26px; font-weight: 700; line-height: 32px; }
.nuts_card_box .detail_box .origin { font-size: 14px; font-weight: 400; color: #aaa; line-height: 22px; }
.nuts_card_box .detail_box .desc { font-size: 16px; font-weight: 400; color: #222; line-height: 22px; }
.nuts_card_box .detail_box .desc .mark { background: rgb(61,93,240); background: linear-gradient(0deg, rgba(61,93,240,0.2) 0%, rgba(61,93,240,0.2) 40%, rgba(61,93,240,0) 40%, rgba(61,93,240,0) 100%); }
.nuts_card_box .detail_box .features li { position: relative; font-size: 16px; font-weight: 700; color: #222; line-height: 24px; padding-left: 24px; }
.nuts_card_box .detail_box .features li span{font-size: 10px;}
.nuts_card_box .detail_box .features li::before { position: absolute; left: 0; top: 2px; width: 18px; height: 18px; background: url(../../image/icon/icon_check_circle_black.svg); background-size: contain; content: ''; display: block; }
.nuts_card_box .detail_box .features li em { font-size: 14px; font-weight: 400; }
.nuts_card_box.propolis .detail_box { background: #F2EADF; }
.nuts_card_box.zinc .detail_box { background: #E4E4E0; }
.nuts_card_box.probiotics .detail_box { background: #EAF2F6; }
.nuts_card_box.vitaminC .detail_box { background: #FFF6DD; }
.nuts_card_box.vitaminD .detail_box { background: #FFEED9; }
.nuts_card_box.vitaminB .detail_box { background: #FDFBEA; }
.nuts_card_box.vitaminC_02 .detail_box { background: #FFF4E7; }
.nuts_card_box.lactobacillus .detail_box { background: #FFF0F0; }
.nuts_card_box.omega3 .detail_box { background: #FFFCF9; }
.nuts_card_box.theanine .detail_box { background: #FFF8F3; }


.certif_text_box { width: 100%; text-align: center; }
.certif_text_box img { width: 32px; }
.certif_text_box p { font-size: 10px; font-weight: 500; color: #757575; line-height: 12px; margin-top: 8px; }

.instruction_box ul { display: flex; align-items: flex-start; justify-content: center; }
.instruction_box ul li { width: 90px; text-align: center; margin: 0 10px; }
.instruction_box ul li p { font-size: 14px; font-weight: 400; line-height: 20px; margin-top: 12px; }

.pillgram_tip { text-align: center; }


.pillgram_rule_box .mark { display: inline-block; color: #E8ECFF; padding: 0 3px; background: #3d5df0; }
.pillgram_rule_box ul { padding-left: 34px; }
.pillgram_rule_box ul li { position: relative; }
.pillgram_rule_box ul li::before { position: absolute; left: -17px; top: 6px; width: 11px; height: 11px; background: #3d5df0; border-radius: 50%; content: ''; display: block; }
.pillgram_rule_box ul li::after { position: absolute; left: -12px; top: 6px; width: 1px; height: calc(100% + 26px); background: #3d5df0; content: ''; display: block; }
.pillgram_rule_box ul li:last-of-type:after { display: none; }
.pillgram_rule_box ul li .numb { position: absolute; left: -34px; font-size: 18px; font-weight: 400; color: #3d5df0; line-height: 26px; font-family:'Gmarket Sans'; display: inline-block; }
.pillgram_rule_box ul li .text_box h4 { color: #3d5df0; }
.pillgram_rule_box > p { color: #828282; }

.pillgram_review_box { text-align: center; }
.pillgram_review_box .star_grade_box { font-size: 24px; font-weight: 300; line-height: 60px; }
.pillgram_review_box .star_grade_box b { font-size: 60px; font-weight: 800; color: #3d5df0; letter-spacing: -1px;  }
.pillgram_review_box .review_chat_box { position: relative; width: 320px; padding: 30px 0; margin: 0 auto; }
.pillgram_review_box .review_chat_box .text { position: absolute; background: #fff; padding: 20px; box-shadow: 1px 4px 9.2px 0px rgba(0, 0, 0, 0.25); }
.pillgram_review_box .review_chat_box .text:nth-of-type(1) { right: -4px; top: 0; border-radius: 20px 20px 20px 0px; }
.pillgram_review_box .review_chat_box .text:nth-of-type(2) { left: -10px; top: 50%; transform: translateY(-50%); border-radius: 20px 20px 0px 20px; }
.pillgram_review_box .review_chat_box .text:nth-of-type(3) { right: -4px; bottom: 0; border-radius: 0px 20px 20px 20px; }
.pillgram_review_box .btn { display: inline-block; font-size: 16px; font-weight: 500; color: #ffffff; line-height: 20px; background: #3d5df0; padding: 10px 20px 10px 24px; border-radius: 20px; box-shadow: 0px 4px 7.3px 0px rgba(0, 0, 0, 0.12); }
.pillgram_review_box .btn::after { width: 20px; height: 20px; background: url(../../image/icon/icon_arrow_right_white.svg) no-repeat center center; background-size: contain; content: ''; display: inline-block; vertical-align: -4px; margin-left: 4px; }
 
.why_pillgram > p { text-align: center; }
.why_pillgram .qna_box { border-top: 1px solid #eee; }
.why_pillgram .qna_box li { border-bottom: 1px solid #eee; }
.why_pillgram .qna_box .q_box { position: relative; width: 100%; font-size: 16px; font-weight: 700; line-height: 20px; word-break: keep-all; padding: 20px 32px 20px 0; }
.why_pillgram .qna_box .q_box::after { position: absolute; right: 0; top: 18px; width: 24px; height: 24px; background: url(../../image/icon/icon_arrow_down_gray.svg) no-repeat center center; background-size: contain; content: ''; display: block; transition: all 0.2s ease-in-out; }
.why_pillgram .qna_box .q_box.on::after { transform: rotate(-180deg); }
.why_pillgram .qna_box .a_box { display: none; width: 100%; font-size: 14px; font-weight: 400; color: #757575; line-height: 20px; padding: 0 32px 20px 16px; }

.package_chat_box .chat_box { position: relative; padding: 22px 45px 0 37px; }
.package_chat_box .chat_box::before { position: absolute; top: 0; content: ''; display: block; }
.package_chat_box .chat_box.type_question::before { left: 0; width: 34px; height: 34px; background: url(../../image/icon/icon_pillgram_character.svg) no-repeat center center; background-size: contain; }
.package_chat_box .chat_box.type_answer::before { right: 0; width: 45px; height: 45px; background: url(../../image/icon/icon_cs_person.svg) no-repeat center center; background-size: contain; }
.package_chat_box .chat_box p { word-break: keep-all; padding: 16px; border-radius: 20px; }
.package_chat_box .chat_box.type_question p { background: #ffffff; border-top-left-radius: 0; }
.package_chat_box .chat_box.type_answer p { background: rgba(61, 93, 240, 0.10); border-top-right-radius: 0; }

.package_components_box > p { text-align: center; }
.package_components_box .nuts_list_box ul li { position: relative; padding: 12px 0 12px 32px; border-bottom: 1px solid #eee; }
.package_components_box .nuts_list_box ul li:last-of-type { border-bottom: none; }
.package_components_box .nuts_list_box ul li::before { position: absolute; left: 0; top: 12px; width: 24px; height: 24px; content: ''; display: block; }
.package_components_box .nuts_list_box ul li .nuts_name { font-size: 18px; font-weight: 700; color: #222; line-height: 24px; padding-right: 24px; }
.package_components_box .nuts_list_box ul li .nuts_desc { font-size: 14px; font-weight: 400; color: #aaa; line-height: 20px; margin-top: 4px; }
.package_components_box .nuts_list_box ul li .btn_delete { position: absolute; right: 0; top: 14px; width: 18px; height: 18px; background: url(../../image/btn/btn_list_delete.svg) no-repeat center center; background-size: contain; text-indent: -9999px; overflow: hidden; z-index: 5; }

.package_add_box .add_list_box ul li { position: relative; padding: 10px 0 10px 32px; }
.package_add_box .add_list_box ul li:last-of-type { margin-bottom: 0; }
.package_add_box .add_list_box ul li::before { position: absolute; left: 0; top: 9px; width: 24px; height: 24px; background: url(../../image/icon/icon_check_circle_primary.svg) no-repeat center center; background-size: contain; content: ''; display: block; }
.package_add_box .add_list_box ul li .nuts_name { font-size: 18px; font-weight: 700; color: #222; line-height: 24px; padding-right: 24px; }
.package_add_box .add_list_box ul li .nuts_desc { font-size: 14px; font-weight: 400; color: #aaa; line-height: 20px; margin-top: 4px; }
.package_add_box .add_list_box ul li .btn_delete { position: absolute; right: 0; top: 14px; width: 18px; height: 18px; background: url(../../image/btn/btn_list_delete.svg) no-repeat center center; background-size: contain; text-indent: -9999px; overflow: hidden; z-index: 5; }
.package_add_box .btn_add_box { border-top: 1px solid #eee; border-bottom: 1px solid #eee; }
.package_add_box .btn_add_box .btn { width: 100%; font-size: 14px; font-weight: 400; line-height: 24px; padding: 10px 16px; background: #fff; text-align: center; display: block; box-sizing: border-box; }

/* 결제금액 확인 */
.total_price_box { display: flex; align-items: center; padding: 12px 20px; background: #F8F9FA; border-radius: 8px; }
.total_price_box .title { display: block; }
.total_price_box .text { display: block; color: #757575; }
.total_price_box .price { display: block; font-weight: 500; }

