.reservation_section .section_wrap { width: 100%; height: auto; padding: 20px 24px 0px; max-width: inherit; }

.reservation_section .cancel_btn_area { margin-top: 18px; margin-bottom: 18px; text-align: center; }
.reservation_section .cancel_btn_area .btn { width: 108px; height: 36px; line-height: 36px; font-weight: 500; font-size: 15px; text-decoration: underline; color: #888888; background:none; }

.reservation_section .bot_btn_area.pc_fix_area { max-width: 480px; left: 50%; transform: translateX(-50%); padding: 44px 24px 24px; filter: none; }
.reservation_section .bot_btn_area.pc_fix_area.type_subcopy { padding:13px 24px 24px; }
.reservation_section .bot_btn_area.pc_fix_area.pc_qa_type { position: fixed; padding: 44px 24px 24px; top: inherit; }

/* 상담 완료 포인트 지급 -> */
.reservation_section .bot_btn_area .guide_target { position: relative; background-color: #8b4ff6; }
.reservation_section .bot_btn_area .complete_guide_text { position: absolute; display: inline-block; display: inline-block; width: auto; height: 40px; line-height: 40px; background-color: rgba(34,34,34,0.7); border-radius: 12px; top: -44px; right: 50%; z-index: 1; text-align: center; color: #ffffff; font-weight: 700; font-size: 14px; transform: translateX(50%); padding: 0 39px; white-space: nowrap; }
.reservation_section .bot_btn_area .complete_guide_text em { color: #C69EFF; }
.reservation_section .bot_btn_area .complete_guide_text::after { content: ""; display: inline-block; width: 20px; height: 12px; position: absolute; left: 50%; bottom: -12px; background-image: url(../image/icon_tail_grey02.svg); background-repeat: no-repeat; background-position: center; transform: translateX(-50%); }

/* 상담 예약 */
.reservation_section .section_wrap.type_reservation_time { padding-top: 68px; }
.reservation_section .reservation_guide_box { background-color: #f2f4f6; border-radius: 8px; padding: 12px; display: flex; justify-content: center; align-items: center;; }
.reservation_section .reservation_guide_box .icon_area { display: flex; flex-direction: column; justify-content: center; align-items: center; margin-right: 8px; }
.reservation_section .reservation_guide_box .icon_area em { font-weight: 700; font-size: 14px; line-height: 20px; }
.reservation_section .reservation_guide_box .icon_area .label { height: 22px; line-height: 22px; background-color: rgba(34,34,34,0.7); border-radius: 24px; padding: 0 8px; font-weight: 700; font-size: 12px; color: #ffffff; }
.reservation_section .reservation_guide_box .text_area { font-weight: 400; font-size: 12px; line-height: 20px; color: rgba(34,34,34,0.7); }

.reservation_section .time_chk_area { margin-top: 24px; padding-bottom: 124px; }
.reservation_section .time_chk_area .title_area { display: flex; justify-content: space-between; align-items: center; }
.reservation_section .time_chk_area .title_area .title { font-weight: 700; font-size: 16px; line-height: 20px; }
.reservation_section .time_chk_area .title_area .guide { display: flex; justify-content: flex-end; align-items: center; }
.reservation_section .time_chk_area .title_area .guide .inner_box { display: flex; }
.reservation_section .time_chk_area .title_area .guide .inner_box + .inner_box { margin-left: 8px; }
.reservation_section .time_chk_area .title_area .guide .inner_box i { width: 10px; height: 10px; border: 1px solid; border-radius: 3px; margin-right: 2px; }
.reservation_section .time_chk_area .title_area .guide .inner_box.type_ture i { border-color: #8B4FF6; background-color: rgba(138,82,220,0.24); }
.reservation_section .time_chk_area .title_area .guide .inner_box.type_false i { border-color: #BFBFBF; background-color: #f3f3f3; }

.reservation_section .time_chk_area .title_area .guide .inner_box span { font-weight: 400; font-size: 12px; line-height: 14px; color: #888888; }
.reservation_section .time_list_wrap .chk_list_area { margin-top: 12px; }
.reservation_section .time_list_wrap .chk_list_area.date_chk ul { display: flex; justify-content: center; align-items: center; }
.reservation_section .time_list_wrap .chk_list_area.time_chk ul { display: flex; justify-content: flex-start; flex-wrap: wrap; width: calc(100% + 8px); margin-left: -4px; }
.reservation_section .time_list_wrap .chk_list_area.date_chk ul li + li { margin-left: 8px; }
.reservation_section .time_list_wrap .chk_list_area.time_chk ul li { margin: 0 4px 8px; width: calc(25% - 8px); }
.reservation_section .time_list_wrap .chk_list_area.time_chk ul + ul { margin-top: 16px; }
.reservation_section .time_list_wrap .chk_list_area.date_chk input[type="radio"],
.reservation_section .time_list_wrap .chk_list_area.time_chk input[type="radio"] { display: none; }
.reservation_section .time_list_wrap .chk_list_area.date_chk input[type="radio"] + label { display: inline-block; width: 72px; height: 55px; background-color: #ffffff; border: 1px solid rgba(34,34,34,0.24); border-radius: 6px; font-weight: 500; font-size: 14px; line-height: 20px; padding: 7px 0; text-align: center; }
.reservation_section .time_list_wrap .chk_list_area.date_chk input[type="radio"]:checked + label,
.reservation_section .time_list_wrap .chk_list_area.time_chk input[type="radio"]:checked + label { border-color: #8B4FF6; background-color: rgba(138,82,220,0.1); color: #8B4FF6; }
.reservation_section .time_list_wrap .chk_list_area.time_chk input[type="radio"] + label { display: inline-block; width: 100%; height: 38px; background-color: #ffffff; border: 1px solid rgba(34,34,34,0.24); border-radius: 6px; font-weight: 500; font-size: 14px; line-height: 36px;text-align: center; }

.reservation_section .time_list_wrap .chk_list_area.date_chk input[type="radio"]:disabled + label,
.reservation_section .time_list_wrap .chk_list_area.time_chk input[type="radio"]:disabled + label { background-color: #F3F3F3; color: rgba(34, 34, 34, 0.24); }

.reservation_section .time_list_wrap .chk_list_area + .title_area,
.reservation_section .time_list_wrap .chk_list_area ul + .title_area { margin-top: 24px; border-top: 8px solid #fafafa; width: calc(100% + 48px); margin-left: -24px; padding: 24px 24px 0; }
.reservation_section .time_list_wrap .chk_list_area .title_area + ul { margin-top: 8px; }

.toast_popup .reservation_time_contents { margin-top: 14px; display: flex; justify-content: space-between; }
.toast_popup .reservation_time_contents .box { height: 74px; padding: 9px 0; width: calc(50% - 11px); text-align: center; background-color: #f2f4f6; border-radius: 6px; display: flex; flex-direction: column; justify-content: center; align-items: center; }
.toast_popup .reservation_time_contents .box.date i { display: inline-block; width: 24px; height: 28px; background-image: url(../image/reservation/icon_date01.svg); background-repeat: no-repeat; background-position: center center; }
.toast_popup .reservation_time_contents .box.time i { display: inline-block; width: 24px; height: 28px; background-image: url(../image/reservation/icon_time01.svg); background-repeat: no-repeat; background-position: center center; }
.toast_popup .reservation_time_contents .box span { margin-top: 8px; font-weight: 400; font-size: 14px; line-height: 20px; }
.toast_popup .reservation_kakao_text { display: flex; justify-content: flex-start; align-items: center; margin-top: 14px; }
.toast_popup .reservation_kakao_text i { width: 14px; height: 14px; display: inline-block; background-image: url(../image/reservation/icon_kakao01.svg); background-repeat: no-repeat; background-position: center; }
.toast_popup .reservation_kakao_text p { margin-left: 8px; font-weight: 400; font-size: 12px; line-height: 20px; color: rgba(34,34,34,0.7); }

.toast_popup .bot_btn_area .btn:first-child { border: 1px solid #8B4FF6; color: #8B4FF6; }
.toast_popup .bot_btn_area .btn:last-child { background-color: #8B4FF6; }

.reservation_section .first_select_wrap { padding-top: 4px; }
.reservation_section .first_select_wrap .section_title { font-weight: 700; font-size: 26px; line-height: 34px; }
.reservation_section .first_select_wrap .first_select_area { margin-top: 16px; }
.reservation_section .first_select_wrap .first_select_area input[type="radio"] { display: none; }
.reservation_section .first_select_wrap .first_select_area > ul > li + li { margin-top: 12px; }
.reservation_section .first_select_wrap .first_select_area .radio_box { width: 100%; height: 64px; position: relative; }
.reservation_section .first_select_wrap .first_select_area .radio_box input[type="radio"] + label,
.reservation_section .first_select_wrap .first_select_area .radio_box input[type="radio"] + label + .radio_contents { position: absolute; left: 0; top: 0; width: 100%; height: 100%; }
.reservation_section .first_select_wrap .first_select_area .radio_box input[type="radio"] + label { z-index: 1; text-indent: -999999px; }
.reservation_section .first_select_wrap .first_select_area .radio_box input[type="radio"] + label + .radio_contents { z-index: 0; background-color: #ffffff; border: 1px solid #d0d0d0; border-radius: 12px; display: flex; justify-content: space-between; align-items: center; padding: 0 24px 0 56px; background-image: url(../image/common/icon_radio01_off.svg); background-repeat: no-repeat; background-position: 26px center; }
.reservation_section .first_select_wrap .first_select_area .radio_box input[type="radio"] + label + .radio_contents .date { font-weight: 400; font-size: 18px; line-height: 24px; color: #363636; display: flex; flex-direction: column; }
.reservation_section .first_select_wrap .first_select_area .radio_box input[type="radio"] + label + .radio_contents .date .guide_text { font-weight: 400; font-size: 13px; line-height: 16px; color: #fb5058; }
.reservation_section .first_select_wrap .first_select_area .radio_box input[type="radio"] + label + .radio_contents .price { font-weight: 400; font-size: 16px; line-height: 24px; color: #363636; }
.reservation_section .first_select_wrap .first_select_area .radio_box .select_guide_text { position: absolute; bottom: -44px; left: 8px; height: 40px; line-height: 40px; background: rgba(34, 34, 34, 0.7); border-radius: 12px; padding: 0 20px; font-weight: 700; font-size: 14px; color: #ffffff; display: none; }
.reservation_section .first_select_wrap .first_select_area .radio_box .select_guide_text::after { content: ""; width: 20px; height: 12px; display: inline-block; background-image: url(../image/icon_tail_grey02.svg); position: absolute; left: 18px; top: -12px; transform: rotate(180deg); }
.reservation_section .first_select_wrap .first_select_area .radio_box .select_guide_text em { color: #C19EFF; }


.reservation_section .first_select_wrap .first_select_area .radio_box input[type="radio"]:checked + label + .radio_contents { background-image: url(../image/common/icon_radio01_on.svg); border: 1px solid #8B4FF6; box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.1); }
.reservation_section .first_select_wrap .first_select_area .radio_box input[type="radio"]:checked + label + .radio_contents .date,
.reservation_section .first_select_wrap .first_select_area .radio_box input[type="radio"]:checked + label + .radio_contents .price { font-weight: 600; }
.reservation_section .first_select_wrap .first_select_area .radio_box input[type="radio"]:checked + label + .radio_contents + .select_guide_text { display: block; }

.reservation_section .first_select_wrap  + .bot_btn_area { margin-top: 88px; }
.reservation_section .first_select_wrap  + .bot_btn_area .reservation_guide_text { margin-top: 12px; width: 100%; text-align: center; font-weight: 400; font-size: 15px; line-height: 24px; }
.reservation_section .first_select_wrap  + .bot_btn_area .reservation_guide_text em { color: #8B4FF6; }


.reservation_section .reservation_bridge_area { padding-top: 16px; }
.reservation_section .reservation_bridge_area .area_title { font-weight: 700; font-size: 26px; line-height: 34px; }
.reservation_section .reservation_bridge_area .area_title em { color: #8B4FF6; }
.reservation_section .reservation_bridge_area .area_title.sm { font-size: 20px; line-height: 26px; }

.reservation_section .reservation_bridge_area .area_title .sub_copy { font-weight: 400; font-size: 16px; line-height: 20px; color: #888888; display: block; }
.reservation_section .reservation_bridge_area .counsel_gudie_area .area_list { margin-top: 16px; }
.reservation_section .reservation_bridge_area .counsel_gudie_area .area_list li { height: 50px; line-height: 50px; display: flex; align-items: center; padding-left: 16px; }
.reservation_section .reservation_bridge_area .counsel_gudie_area .area_list li + li { border-top: 1px solid #f2f4f6; }
.reservation_section .reservation_bridge_area .counsel_gudie_area .area_list img { width: 24px; height: 24px; }
.reservation_section .reservation_bridge_area .counsel_gudie_area .area_list .inner_text { margin-left: 12px; font-weight: 500; font-size: 18px; line-height: 26px; }
.reservation_section .reservation_bridge_area .counsel_gudie_area .area_list .inner_text em { color: #8B4FF6; }
.reservation_section .reservation_bridge_area .purchase_guide_area { margin-top: 48px; }
.reservation_section .reservation_bridge_area .purchase_guide_area .text_box { margin-top: 16px; border: 1px solid #f2f4f6; border-radius: 16px; padding: 14px 20px 14px 20px; position: relative; }
.reservation_section .reservation_bridge_area .purchase_guide_area .text_box .inner_text { font-weight: 400; font-size: 15px; line-height: 22px; word-break: keep-all; }
.reservation_section .reservation_bridge_area .purchase_guide_area .text_box .inner_text em { color: #8B4FF6; }
.reservation_section .reservation_bridge_area .purchase_guide_area .text_box img { position: absolute; right: 10px; bottom: 0; }
.reservation_section .reservation_bridge_area .purchase_guide_area .area_sub_guide_text { margin-top: 48px; font-weight: 500; font-size: 14px; line-height: 20px; color: #888888; margin-bottom: 12px; word-break: keep-all; }

.section_wrap.type_reservation_time .titlte_area .main_title { font-weight: 700; font-size: 26px; line-height: 34px;  }
.section_wrap.type_reservation_time .titlte_area .main_title em { color: #8b4ff6; }
.section_wrap.type_reservation_time .titlte_area .sub_copy { margin-top: 4px; font-weight: 400; font-size: 16px; line-height: 20px; color: #363636; }


.reservation_section .reservation_complete_area .title_area { margin-top: 24px; }
.reservation_section .reservation_complete_area + .bot_btn_area { margin-top: 36px; }
.reservation_section .reservation_complete_area .title_area .title { font-size: 26px; font-weight: 700; color: #222; line-height: 34px; }
.reservation_section .reservation_complete_area .title_area .sub_copy { margin-top: 4px; font-size: 16px; font-weight: 400; color: rgba(34, 34, 34, 0.7); line-height: 24px;}
.reservation_section .reservation_complete_area .guide_box_area { margin-top: 24px; display: flex; justify-content: space-between; align-items: center; }
.reservation_section .reservation_complete_area .guide_box_area .box { width: calc(50% - 4px); text-align: center; background-color: #f2f4f6; padding: 12px 0; border-radius: 6px; }
.reservation_section .reservation_complete_area .guide_box_area .box .text { margin-top: 8px; font-weight: 500; font-size: 20px; line-height: 28px; color: #363636; }


/* 예약 취소 */
.type_reservation_cancel .cancel_contents_area { padding-top: 24px; }
.cancel_contents_area .title_area .title { font-weight: 700; font-size: 26px; line-height: 34px; }
.cancel_contents_area .info_view_area { margin-top: 24px; }
.cancel_contents_area .info_view_area .title { font-weight: 700; font-size: 18px; line-height: 26px; }
.cancel_contents_area .info_view_area .box_area { margin-top: 16px; display: flex; justify-content: space-between; }
.cancel_contents_area .info_view_area .box_area .contents_box { width: calc(50% - 4px); height: 84px; background-color: #f2f4f6; border-radius: 6px; display: flex; justify-content: center; align-items: center; flex-direction: column; }
.cancel_contents_area .info_view_area .box_area .contents_box img { width: 24px; }
.cancel_contents_area .info_view_area .box_area .contents_box .text { margin-top: 8px; font-weight: 500; font-size: 20px; line-height: 28px; color: #363636; }
.cancel_contents_area .info_view_area .inner_btn_wrap { margin-top: 16px; text-align: center; }
.cancel_contents_area .info_view_area .inner_btn_wrap .reservation_btn { display: inline-block; background-color: #ffffff; border: 1px solid #8b4ff6; padding: 0 18px; height: 40px; line-height: 38px; border-radius: 12px; font-weight: 700; font-size: 15px; color: #8b4ff6; box-sizing: border-box; }
.cancel_contents_area .guide_text_area { margin-top: 40px; }
.cancel_contents_area .guide_text_area .title { font-weight: 700; font-size: 18px; line-height: 26px; }
.cancel_contents_area .guide_text_area .sub_copy { margin-top: 8px; font-weight: 400; font-size: 16px; line-height: 24px; color: rgba(34,34,34,0.72); }
.cancel_contents_area .guide_text_area .sub_copy em { color: #8b4ff6 }
.type_reservation_cancel .cancel_contents_area + .bot_btn_area { margin-top: 24px; }

/* PL-613 */
.time_chk_area .chk_title { display: flex; align-items: center; height: 60px; cursor: pointer; }
.time_chk_area .chk_title img { width: 24px; margin-right: 8px; min-width: 24px; }
.time_chk_area .chk_title .area_title { font-weight: 700; font-size: 20px; line-height: 24px; flex-grow: 1; }
.time_chk_area .chk_title i { display: inline-block; width: 12px; height: 6px; background-image: url(../image/reservation/calendar/icon_arrow02.svg); background-repeat: no-repeat; background-position: center; transform: rotate(180deg); }
.time_chk_area .chk_title.active i { transform: rotate(0); }
.time_chk_area .inner_contents_wrap { border-bottom: 1px solid #eff0f6; }

.time_chk_area .chk_title + .inner_contents_wrap { height: 0; overflow: hidden; }
.time_chk_area .chk_title.active + .inner_contents_wrap { height: auto; }

.time_chk_area .guide { display: flex; justify-content: flex-end; align-items: center; padding: 8px 0; }
.time_chk_area .guide .inner_box { display: flex; }
.time_chk_area .guide .inner_box + .inner_box { margin-left: 8px; }
.time_chk_area .guide .inner_box i { width: 10px; height: 10px; border: 1px solid; border-radius: 3px; margin-right: 2px; }
.time_chk_area .guide .inner_box.type_true i { border-color: #8B4FF6; background-color: rgba(138,82,220,0.24); }
.time_chk_area .guide .inner_box.type_able i { border-color: rgba(34,34,34,0.24); background-color: #ffffff; }
.time_chk_area .guide .inner_box.type_false i { border-color: #f3f3f3; background-color: #f3f3f3; }

.time_chk_area .guide .inner_box span { font-weight: 400; font-size: 12px; line-height: 14px; color: #888888; }
.time_chk_area .time_chk_wrap .group_chk_area { display: grid; gap: 8px; grid-template-columns: repeat(2, 1fr); }
.time_chk_area .time_chk_wrap .group_chk_area .group_chk_btn { background-color: #ffffff; border: 1px solid rgba(34, 34, 34, 0.24); border-radius: 6px; padding: 9px 0; }
.time_chk_area .time_chk_wrap .group_chk_area .group_chk_btn .text { font-weight: 500; font-size: 14px; line-height: 20px; }
.time_chk_area .time_chk_wrap .group_chk_area .group_chk_btn .time { margin-top: 4px; font-weight: 500; font-size: 12px; line-height: 13px; }
.time_chk_area .time_chk_wrap .group_chk_area .group_chk_btn.active { background: rgba(139, 79, 246, 0.1); border: 1px solid #8B4FF6; }
.time_chk_area .time_chk_wrap .group_chk_area .group_chk_btn.active .text { font-weight: 700; color: #8b4ff6; }
.time_chk_area .time_chk_wrap .group_chk_area .group_chk_btn:disabled { background: #F3F3F3; border: 1px solid #F3F3F3; }
.time_chk_area .time_chk_wrap .group_chk_area .group_chk_btn:disabled .text { color: rgba(34,34,34,0.24); }
.time_chk_area .time_chk_wrap .group_chk_area .group_chk_btn:disabled .time { color: rgba(34,34,34,0.24); }
.time_chk_area .time_chk_wrap .time_list_area { margin-top: 8px; }
.time_chk_area .time_chk_wrap .time_list_area .time_chk_group { display: grid; gap: 8px; grid-template-columns: repeat(4, 1fr); }
.time_chk_area .time_chk_wrap .time_list_area .time_chk_group .time_chk_box input[type="radio"] { display: none; }
.time_chk_area .time_chk_wrap .time_list_area .time_chk_group .time_chk_box input[type="radio"] + label { display: inline-block; border-radius: 6px; width: 100%; height: 38px; line-height: 38px; text-align: center; font-weight: 500; font-size: 14px; background: #FFFFFF; border: 1px solid rgba(34, 34, 34, 0.24); }
.time_chk_area .time_chk_wrap .time_list_area .time_chk_group .time_chk_box input[type="radio"]:checked + label { background: rgba(138, 82, 220, 0.1); border: 1px solid #8A52DC; color: #8A52DC; }
.time_chk_area .time_chk_wrap .time_list_area .time_chk_group .time_chk_box input[type="radio"]:disabled + label { background: #F3F3F3; border: 1px solid #F3F3F3; color: rgba(34,34,34,0.24); }

/* 달력 */
.date_chk_area .calendar-container .buttons-container { padding: 0 30px; border-bottom: 0; height: 40px; margin-bottom: 8px; }
.date_chk_area .calendar-container .prev-button, 
.date_chk_area .calendar-container .next-button { text-indent: -99999px; width: 34px; height: 40px; background-image: url('../image/reservation/calendar/icon_arrow01.svg'); background-repeat: no-repeat; background-position: center; }
.date_chk_area .calendar-container .prev-button:disabled, 
.date_chk_area .calendar-container .next-button:disabled { opacity: 0.1; }
.date_chk_area .calendar-container .prev-button { transform: rotate(180deg); }
.date_chk_area .calendar-container .buttons-container .label-container { display: flex; justify-content: center; flex-direction: row-reverse; font-weight: 700; font-size: 18px; line-height: 21px; }
.date_chk_area .calendar-container .buttons-container .year-label { margin-right: 6px; }
.date_chk_area .calendar-container .buttons-container .year-label::after { content: "년"; }
.date_chk_area .calendar-container .week { margin: 0; }
.date_chk_area .calendar-container .weeks-wrapper { margin-top: 8px; }
.date_chk_area .calendar-container .weeks-wrapper.header { border-bottom: 0; }
.date_chk_area .calendar-container .week .day.header { font-weight: 700; font-size: 16px; line-height: 22px; letter-spacing: 0.25px; color: #9f98c7; height: 40px; line-height: 40px; }
.date_chk_area .calendar-container .week.highlight { background-color: transparent; }
.date_chk_area .calendar-container .week .day span { width: 36px; height: 36px; line-height: 34px; font-weight: 700; font-size: 14px; letter-spacing: -0.25px; color: #222222; border: 1px solid transparent; }

.date_chk_area .calendar-container .week .day[disabled="disabled"].disabled span { color: transparent; cursor: auto; }
.date_chk_area .calendar-container .week .day[disabled="disabled"] span { color: rgba(34, 34, 34, 0.24); }
.date_chk_area .calendar-container .week .day.selected span { background: rgba(139, 79, 246, 0.1); border: 1px solid #8B4FF6; border-radius: 8px; color: #8B4FF6; }
.date_chk_area .calendar-container .week .day.today span::after { display: none; }

.none_reservation_area { margin-top: 42px; text-align: center; }
.none_reservation_area img { width: 76px; }
.none_reservation_area .text_area { margin-top: 12px; }
.none_reservation_area .text_area .title { font-weight: 700; font-size: 18px; line-height: 26px; }
.none_reservation_area .text_area .sub_copy { margin-top: 4px; font-weight: 400; font-size: 14px; line-height: 20px; color: rgba(34,34,34,0.72); }
.none_reservation_area .btn { margin-top: 24px; width: 192px; height: 40px; line-height: 40px; box-sizing: border-box; background-color: #ffffff; border: 1px solid #8b4ff6; border-radius: 12px; font-weight: 700; font-size: 15px; color: #8b4ff6; }