@charset "UTF-8";
/* 초기화 및 초기 세팅 */
:root {
    /* 버튼 및 인풋 폼 높이 세팅 */
    /*--hd_height: 9rem;*/
    --hd_height_m: 6rem;
    --ic_date: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='25' height='25' viewBox='0 0 25 25'%3E%3Cg id='ic_calenda' transform='translate(-0.214)'%3E%3Crect id='사각형_9174' data-name='사각형 9174' width='25' height='25' transform='translate(0.214)' fill='none'/%3E%3Cpath id='calendar_month_FILL0_wght400_GRAD0_opsz24' d='M122.193-858.068a2.112,2.112,0,0,1-1.549-.644,2.112,2.112,0,0,1-.644-1.549v-15.352a2.112,2.112,0,0,1,.644-1.549,2.112,2.112,0,0,1,1.549-.644h1.1V-880h2.193v2.193h8.773V-880h2.193v2.193h1.1a2.112,2.112,0,0,1,1.549.644,2.112,2.112,0,0,1,.644,1.549v15.352a2.112,2.112,0,0,1-.644,1.549,2.112,2.112,0,0,1-1.549.644Zm0-2.193h15.352v-10.966H122.193Zm0-13.159h15.352v-2.193H122.193Zm0,0v0Zm7.676,6.58a1.061,1.061,0,0,1-.781-.315,1.061,1.061,0,0,1-.315-.781,1.061,1.061,0,0,1,.315-.781,1.061,1.061,0,0,1,.781-.315,1.061,1.061,0,0,1,.781.315,1.061,1.061,0,0,1,.315.781,1.061,1.061,0,0,1-.315.781A1.061,1.061,0,0,1,129.869-866.841Zm-4.386,0a1.061,1.061,0,0,1-.781-.315,1.061,1.061,0,0,1-.315-.781,1.061,1.061,0,0,1,.315-.781,1.061,1.061,0,0,1,.781-.315,1.061,1.061,0,0,1,.781.315,1.061,1.061,0,0,1,.315.781,1.061,1.061,0,0,1-.315.781A1.061,1.061,0,0,1,125.483-866.841Zm8.773,0a1.061,1.061,0,0,1-.781-.315,1.061,1.061,0,0,1-.315-.781,1.061,1.061,0,0,1,.315-.781,1.061,1.061,0,0,1,.781-.315,1.061,1.061,0,0,1,.781.315,1.061,1.061,0,0,1,.315.781,1.061,1.061,0,0,1-.315.781A1.061,1.061,0,0,1,134.256-866.841Zm-4.386,4.386a1.061,1.061,0,0,1-.781-.315,1.061,1.061,0,0,1-.315-.781,1.061,1.061,0,0,1,.315-.781,1.061,1.061,0,0,1,.781-.315,1.061,1.061,0,0,1,.781.315,1.061,1.061,0,0,1,.315.781,1.061,1.061,0,0,1-.315.781A1.061,1.061,0,0,1,129.869-862.454Zm-4.386,0a1.061,1.061,0,0,1-.781-.315,1.061,1.061,0,0,1-.315-.781,1.061,1.061,0,0,1,.315-.781,1.061,1.061,0,0,1,.781-.315,1.061,1.061,0,0,1,.781.315,1.061,1.061,0,0,1,.315.781,1.061,1.061,0,0,1-.315.781A1.061,1.061,0,0,1,125.483-862.454Zm8.773,0a1.061,1.061,0,0,1-.781-.315,1.061,1.061,0,0,1-.315-.781,1.061,1.061,0,0,1,.315-.781,1.061,1.061,0,0,1,.781-.315,1.061,1.061,0,0,1,.781.315,1.061,1.061,0,0,1,.315.781,1.061,1.061,0,0,1-.315.781A1.061,1.061,0,0,1,134.256-862.454Z' transform='translate(-116.786 882)' fill='%23585e65'/%3E%3C/g%3E%3C/svg%3E%0A");
    --ic_time:url("data:image/svg+xml,%3Csvg id='ic_clock' xmlns='http://www.w3.org/2000/svg' width='25' height='25' viewBox='0 0 25 25'%3E%3Crect id='사각형_9176' data-name='사각형 9176' width='25' height='25' fill='none'/%3E%3Cpath id='schedule_FILL0_wght400_GRAD0_opsz24_1_' data-name='schedule_FILL0_wght400_GRAD0_opsz24 (1)' d='M94.319-864.173l1.507-1.507-3.984-3.984v-4.953H89.69v5.814Zm-3.553,5.706a10.484,10.484,0,0,1-4.2-.848,10.873,10.873,0,0,1-3.418-2.3,10.873,10.873,0,0,1-2.3-3.418,10.484,10.484,0,0,1-.848-4.2,10.484,10.484,0,0,1,.848-4.2,10.873,10.873,0,0,1,2.3-3.418,10.875,10.875,0,0,1,3.418-2.3,10.485,10.485,0,0,1,4.2-.848,10.485,10.485,0,0,1,4.2.848,10.875,10.875,0,0,1,3.418,2.3,10.872,10.872,0,0,1,2.3,3.418,10.484,10.484,0,0,1,.848,4.2,10.484,10.484,0,0,1-.848,4.2,10.873,10.873,0,0,1-2.3,3.418,10.873,10.873,0,0,1-3.418,2.3A10.484,10.484,0,0,1,90.766-858.467ZM90.766-869.234Zm0,8.613a8.3,8.3,0,0,0,6.1-2.517,8.3,8.3,0,0,0,2.517-6.1,8.3,8.3,0,0,0-2.517-6.1,8.3,8.3,0,0,0-6.1-2.517,8.3,8.3,0,0,0-6.1,2.517,8.3,8.3,0,0,0-2.517,6.1,8.3,8.3,0,0,0,2.517,6.1A8.3,8.3,0,0,0,90.766-860.62Z' transform='translate(-78 882)' fill='%23585e65'/%3E%3C/svg%3E%0A");
}


div::-webkit-scrollbar, .custom_scroll::-webkit-scrollbar {
    width: 0.6rem;
    height: 0.6rem;
}
div::-webkit-scrollbar-thumb, .custom_scroll::-webkit-scrollbar-thumb {
    background-color: var(--gray-200);
    border-radius: 100px;
}


html { font-size:10px;}
body { margin:0 auto; padding:0; /*overflow: hidden scroll;*/ background-color: var(--primary);}

html, h1, h2, h3, h4, h5, h6, form, fieldset, img { margin:0; padding:0; border:0 }
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display:block }

ul, dl,dt,dd { margin:0; padding:0; list-style:none }
legend { position:absolute; margin:0; padding:0; font-size:0; line-height:0; text-indent:-9999em; overflow:hidden;}
label, input, button, select, img { vertical-align:middle; }
input, button { margin:0; padding:0;}
input[type="submit"] {cursor:auto;}
button {cursor: auto;word-break: keep-all;}
select {margin:0}
p { margin:0; padding:0;}
hr { display:none }
a { text-decoration:none;}
a:hover { text-decoration: none; color: inherit;}
.un_reboot_a { color: var(--text); text-decoration: underline; }
*, :after, :before {
	-webkit-box-sizing:border-box;
	-moz-box-sizing:border-box;
	box-sizing:border-box;
	word-break: normal;
	word-wrap: break-word;
}

img { max-width:100%; display:inline-block; height: auto; }

/* iOS에서 input date 텍스트정렬 */
input[type="date"]::-webkit-date-and-time-value{
	text-align: left;
	vertical-align: center;
}


/* ==================== 공통 class 설정 ==================== */
/* .container-fluid { max-width: 2560px;} */
.hidden_ip{ display: none;}

.flex_center{ align-items: center; justify-content: center;}

.cursor_pointer{ cursor: pointer;}
.cursor_default{ cursor: default;}

.over_hidden{ overflow:hidden;}

/* 스크롤바 none */
.scroll_bar_none { -ms-overflow-style: none; scrollbar-width: none; }
.scroll_bar_none::-webkit-scrollbar { display: none; }

/*터치 스크롤*/
.touch_scroll { overflow-x: auto; overflow-y: hidden; }

/* 터치 스크롤 inner 버전 */
.touch_scroll2 { position: relative;}
.touch_scroll2 .scroll_inner{ overflow-x: auto; overflow-y: hidden; -webkit-overflow-scrolling: touch;}

/* 스크롤 발생 시 오른쪽에 그라데이션 표시 */
.touch_scroll2.right_gra::after {
	content: "";
	display: block;
	height: 100%;
	width: 6.0rem;
	position: absolute;
	top: 0;
	right: 0;
	background: linear-gradient(90deg,rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 100%);
	pointer-events: none;
	opacity: 0;
}
.touch_scroll2.right_gra.scrollable:not(.at-end)::after{ opacity: 1;}

/*터치 스크롤 안 요소 드래그 방지 */
.touch_scroll *, .touch_scroll2 *{
	-webkit-user-select:none;
	-moz-user-select:none;
	-ms-user-select:none;
	user-select:none;
	-webkit-user-drag: none;
	-khtml-user-drag: none;
	-moz-user-drag: none;
	-o-user-drag: none;
	user-drag: none;
}

.vh_min100{ min-height:100vh;}
.vh_100_vh{ height:100vh;}
.w-auto{ width:auto;}

.zd_2{ position:relative; z-index:2;}

/* gap */
.gap_4{ gap: 0.4rem;}
.gap_5{ gap: 0.5rem;}
.gap_6{ gap:0.6rem;}
.gap_8{ gap:0.8rem;}
.gap_10{ gap:1.0rem;}
.gap_12{ gap:1.2rem;}
.gap_14{ gap:1.4rem;}
.gap_15{ gap:1.5rem;}
.gap_16{ gap:1.6rem;}
.gap_20{ gap: 2.0rem;}
.gap_24{ gap: 2.4rem;}
.gap_25{ gap:2.5rem;}
.gap_30{ gap:3.0rem;}
.gap_40{ gap:4.0rem;}
.gap_50{ gap:5.0rem;}
.gap_60{ gap:6.0rem;}


/* 아이콘 너비 */
.icon_4{ width: 0.4rem; height: auto; flex-shrink: 0;}
.icon_6{ width: 0.6rem; height: auto; flex-shrink: 0;}
.icon_7{ width: 0.7rem; height: auto; flex-shrink: 0;}
.icon_8{ width: 0.8rem; height: auto; flex-shrink: 0;}
.icon_10{ width: 1.0rem; height: auto; flex-shrink: 0;}
.icon_12{ width: 1.2rem; height: auto; flex-shrink: 0;}
.icon_14{ width: 1.4rem; height: auto; flex-shrink: 0;}
.icon_15{ width: 1.5rem; height: auto; flex-shrink: 0;}
.icon_16{ width: 1.6rem; height: auto; flex-shrink: 0;}
.icon_18{ width: 1.8rem; height: auto; flex-shrink: 0;}
.icon_20{ width: 2.0rem; height: auto; flex-shrink: 0;}
.icon_24{ width: 2.4rem; height: auto; flex-shrink: 0;}
.icon_25{ width: 2.5rem; height: auto; flex-shrink: 0;}
.icon_28{ width: 2.8rem; height: auto; flex-shrink: 0;}
.icon_30{ width: 3.0rem; height: auto; flex-shrink: 0;}
.icon_32{ width: 3.2rem; height: auto; flex-shrink: 0;}
.icon_35{ width: 3.5rem; height: auto; flex-shrink: 0;}
.icon_36{ width: 3.6rem; height: auto; flex-shrink: 0;}
.icon_38{ width:3.8rem;  height: auto; flex-shrink: 0;}
.icon_40{ width: 4.0rem; height: auto; flex-shrink: 0;}
.icon_48{ width:4.8rem; height: auto; flex-shrink: 0;}
.icon_50{ width: 5.0rem; height: auto; flex-shrink: 0;}
.icon_56{ width:5.6rem; height: auto; flex-shrink: 0;}
.icon_60{ width: 6.0rem; height: auto; flex-shrink: 0;}
.icon_120{ width:12.0rem; height: auto; flex-shrink: 0;}


/* bg */
.bg-gra01{ background: var(--gra01);}
.bg-gra02{ background: var(--gra02);}
.bg-gra03{ background: var(--gra03);}
.bg-gra04{ background: var(--gra04);}



/* ==================== 텍스트 설정 ==================== */
.text_dynamic{ white-space: pre-line;}
.wh_pre { white-space: pre-line; }
.wh_nowrap { white-space: nowrap; }

.break_all{word-break: break-all;}


/*폰트커스텀 기본사이즈 10px*/
.tit_h1{ font-size: 2.8rem; font-weight: 600; line-height: 1.35;}
.tit_h2{ font-size: 2.6rem; font-weight: 600; line-height: 1.35;}
.tit_h3{ font-size: 2.2rem; font-weight: 600; line-height: 1.35;}
.tit_h4{ font-size: 2.0rem; font-weight: 600; line-height: 1.35;}
.tit_h5{ font-size: 1.8rem; font-weight: 600; line-height: 1.35;}

.caption{ font-size: 1.3rem; line-height: 1.4;}

.body_17{ font-size: 1.7rem; line-height: 1.5;}
.body_16{ font-size: 1.6rem; line-height: 1.5;}
.body_15{ font-size: 1.5rem; line-height: 1.5;}

.modal_cont_tit{ font-size: 1.6rem; font-weight: 600; line-height: 1.3;}


/* 폰트컬러 */
/* 부트스트랩 class는 --var값으로 설정이 되어 있지 않아서 따로 만들었습니다. 필요시 추가해서 사용 */
.fc_primary{color: var(--primary);}
.fc_primary_100{color: var(--primary-100);}
.fc_primary_200{color: var(--primary-200);}
.fc_primary_300{color: var(--primary-300);}
.fc_primary_400{color: var(--primary-400);}
.fc_primary_500{color: var(--primary-500);}
.fc_primary_600{color: var(--primary-600);}
.fc_primary_700{color: var(--primary-700);}
.fc_primary_800{color: var(--primary-800);}
.fc_primary_900{color: var(--primary-900);}
.fc_secondary{color: var(--secondary);}
.fc_text{color: var(--text);}
.fc_gray_50{color: var(--gray-50);}
.fc_gray_100{color: var(--gray-100);}
.fc_gray_200{color: var(--gray-200);}
.fc_gray_300{color: var(--gray-300);}
.fc_gray_400{color: var(--gray-400);}
.fc_gray_500{color: var(--gray-500);}
.fc_gray_600{color: var(--gray-600);}
.fc_gray_700{color: var(--gray-700);}
.fc_gray_800{color: var(--gray-800);}
.fc_gray_900{color: var(--gray-900);}
.fc_deep{color: var(--deep);}
.fc_light{color: var(--light);}
.fc_dark{color: var(--dark);}

.text-black{color:#000;}

/* a:hover 색상 */
a.fc_primary_200:hover{color: var(--primary-200);}
a.fc_primary_300:hover{color: var(--primary-300);}

/* 라인 헤이트 */
.line_h1 { line-height:1.0; }
.line_h1_1 { line-height:1.1; }
.line_h1_2 { line-height:1.2; }
.line_h1_3 { line-height:1.3; }
.line_h1_35 { line-height:1.35; }
.line_h1_4 { line-height:1.4; }
.line_h1_5 { line-height:1.5; }
.line_h1_6 { line-height:1.6; }
.line_h1_7 { line-height:1.7; }
.line_h1_8 { line-height:1.8; }
.line_h1_9 { line-height:1.9; }
.line_h2 { line-height:2.0; }


.fs_8 { font-size: 0.8rem; }
.fs_9 { font-size: 0.9rem; }
.fs_10 { font-size: 1.0rem; }
.fs_11 { font-size: 1.1rem }
.fs_12 { font-size: 1.2rem }
.fs_13 { font-size: 1.3rem }
.fs_14 { font-size: 1.4rem }
.fs_15 { font-size: 1.5rem }
.fs_16 { font-size: 1.6rem }
.fs_17 { font-size: 1.7rem }
.fs_18 { font-size: 1.8rem }
.fs_19 { font-size: 1.9rem }
.fs_20 { font-size: 2.0rem }
.fs_21 { font-size: 2.1rem }
.fs_22 { font-size: 2.2rem; }
.fs_23 { font-size: 2.3rem; }
.fs_24 { font-size: 2.4rem; }
.fs_25 { font-size: 2.5rem; }
.fs_26 { font-size: 2.6rem; }
.fs_27 { font-size: 2.7rem; }
.fs_28 { font-size: 2.8rem; }
.fs_29 { font-size: 2.9rem; }
.fs_30 { font-size: 3.0rem; }
.fs_31 { font-size: 3.1rem; }
.fs_32 { font-size: 3.2rem; }
.fs_33 { font-size: 3.3rem; }
.fs_34 { font-size: 3.4rem; }
.fs_35 { font-size: 3.5rem; }
.fs_36 { font-size: 3.6rem; }
.fs_37 { font-size: 3.7rem; }
.fs_38 { font-size: 3.8rem; }
.fs_39 { font-size: 3.9rem; }
.fs_40 { font-size: 4.0rem; }
.fs_41 { font-size: 4.1rem; }
.fs_42 { font-size: 4.2rem; }
.fs_43 { font-size: 4.3rem; }
.fs_44 { font-size: 4.4rem; }
.fs_45 { font-size: 4.5rem; }
.fs_46 { font-size: 4.6rem; }
.fs_47 { font-size: 4.7rem; }
.fs_48 { font-size: 4.8rem; }
.fs_49 { font-size: 4.9rem; }
.fs_50 { font-size: 5.0rem; }
.fs_51 { font-size: 5.1rem; }
.fs_52 { font-size: 5.2rem; }


.fw_100 { font-weight: 100; }
.fw_200 { font-weight: 200; }
.fw_300 { font-weight: 300; }
.fw_400 { font-weight: 400; }
.fw_500 { font-weight: 500; }
.fw_600 { font-weight: 600; }
.fw_700 { font-weight: 700; }
.fw_800 { font-weight: 800; }
.fw_900 { font-weight: 900; }


/*글자 줄임말/자르기*/
.line_text { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; word-break: break-all;word-break: break-all;}
.line1_text { white-space: normal; overflow: hidden; text-overflow: ellipsis;word-wrap: break-word; display: -webkit-box; -webkit-line-clamp: 1; line-clamp: 1; -webkit-box-orient: vertical;word-break: break-all;}
.line2_text { white-space: normal; overflow: hidden; text-overflow: ellipsis;word-wrap: break-word; display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical;word-break: break-all;}
.line3_text { white-space: normal; overflow: hidden; text-overflow: ellipsis;word-wrap: break-word; display: -webkit-box; -webkit-line-clamp: 3; line-clamp: 3; -webkit-box-orient: vertical;word-break: break-all;}



/**************************************************/
/*								공통 여백 class	  								*/
/**************************************************/
/*마진*/
.mt_8{margin-top:0.8rem;}
.mt_12{margin-top:1.2rem;}
.mt_16{margin-top:1.6rem;}
.mt_20{margin-top:2.0rem;}
.mt_24{margin-top:2.4rem;}
.mt_25{margin-top:2.5rem;}
.mt_28{margin-top:2.8rem;}
.mt_35{margin-top:3.5rem;}
.mt_36{margin-top:3.6rem;}
.mt_40{margin-top:4.0rem;}
.mt_60{margin-top:6.0rem;}
.mt_70{margin-top:7.0rem;}
.mt_80{margin-top:8.0rem;}


.mb_4{margin-bottom:0.4rem;}
.mb_6{margin-bottom:0.6rem;}
.mb_8{margin-bottom:0.8rem;}
.mb_12{margin-bottom:1.2rem;}
.mb_14{margin-bottom:1.4rem;}
.mb_16{margin-bottom:1.6rem;}
.mb_18{margin-bottom:1.8rem;}
.mb_20{margin-bottom:2.0rem;}
.mb_24{margin-bottom:2.4rem;}
.mb_25{margin-bottom:2.5rem;}
.mb_36{margin-bottom:3.6rem;}
.mb_40{margin-bottom:4.0rem;}
.mb_50{margin-bottom:5.0rem;}
.mb_60{margin-bottom:6.0rem;}
.mb_70{margin-bottom:7.0rem;}
.mb_90{margin-bottom:9.0rem;}


.mr_4{margin-right:0.4rem;}
.mr_6{margin-right:0.6rem;}
.mr_8{margin-right:0.8rem;}
.mr_12{margin-right:1.2rem;}
.mr_16{margin-right:1.6rem;}
.mr_20{margin-right:2.0rem;}


.ml_6{margin-left:0.6rem;}
.ml_8{margin-left:0.8rem;}
.ml_16{margin-left:1.6rem;}
.ml_20{margin-left:2.0rem;}


.mx_n16{margin-left:-1.6rem;margin-right:-1.6rem;}
.mx_n20{margin-left:-2.0rem;margin-right:-2.0rem;}



/*패딩*/
.pt_6{padding-top:0.6rem;}
.pt_14{ padding-top: 1.4rem;}
.pt_20{ padding-top: 2.0rem;}
.pt_24{padding-top:2.4rem;}
.pt_25{padding-top:2.5rem;}
.pt_28{padding-top:2.8rem;}
.pt_40{ padding-top: 4.0rem;}
.pt_50{ padding-top: 5.0rem;}
.pt_60{ padding-top: 6.0rem;}
.pt_80{padding-top:8.0rem;}
.pt_120{padding-top:12.0rem;}


.pb_8 { padding-bottom: 0.8rem;}
.pb_14 { padding-bottom: 1.4rem;}
.pb_16 { padding-bottom: 1.6rem;}
.pb_18{padding-bottom:1.8rem;}
.pb_20{padding-bottom:2.0rem;}
.pb_24{ padding-bottom: 2.4rem;}
.pb_25{padding-bottom:2.5rem;}
.pb_40{padding-bottom:4.0rem;}
.pb_50{padding-bottom:5.0rem;}
.pb_60{padding-bottom:6.0rem;}
.pb_70{padding-bottom:7.0rem;}
.pb_80{padding-bottom:8.0rem;}
.pb_90{padding-bottom:9.0rem;}
.pb_100{padding-bottom:10.0rem;}


.pl_16 { padding-left: 1.6rem;}


.pr_16{padding-right:1.6rem;}


.py_8{ padding-top: 0.8rem; padding-bottom: 0.8rem;}
.py_20{padding-top:2.0rem;padding-bottom:2.0rem;}
.py_35{padding-top:3.5rem;padding-bottom:3.5rem;}


.px_8{padding-left:0.8rem;padding-right:0.8rem;}
.px_12{padding-left:1.2rem;padding-right:1.2rem;}
.px_18{padding-left:1.8rem;padding-right:1.8rem;}
.px_16{padding-left:1.6rem;padding-right:1.6rem;}
.px_20{padding-left:2.0rem;padding-right:2.0rem;}


.p_20{ padding: 2rem;}



/* ==================== 공통 요소 설정 ==================== */
/* mobile wr 기본설정 */
.mobile_wr {
    position: relative;
	box-sizing: content-box;
	min-height: 100vh;
	max-width:576px;
	margin:0 auto;
    background-color: #fff;
}

/*노데이터*/
.no_data {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
}

/* 고탑버튼*/
.go_top2 {
	width: 4.4rem;
	height: 4.4rem;
	background: url(../img/go_top.png)no-repeat center;
	background-color: #fff;
	background-size: 1.6rem auto;
	z-index: 1000;
	border-radius: 50%;
	display: none;
	position: fixed;
	right: 50%;
	bottom: 2rem;
	transform: translateX(272px);
	border: 1px solid var(--border);
}
.go_top2.show{display: block;}


/* bar 회색바 */
.bar{ height: 1.0rem; background-color: #F8F8F8;}


/* 뱃지 디자인 */
.badge {
	padding: 0.6rem 0.8rem;
	border-radius: 1.8rem;
	font-size: 1.3rem;
	font-weight: 600;
	line-height: 1.1;
}
.badge-lg{
    height: 3.2rem;
    padding: 0.5rem 1.2rem;
    border-radius: 1.8rem;
    font-size: 1.5rem;
    line-height: 1.4;
}
.badge-primary { background-color: var(--primary); color:#fff;}
.badge-primary-100{ background-color: var(--primary-100); color: var(--primary);}
.badge-gray-50{ background-color: var(--gray-50); color: var(--gray-600);}
.badge-outline-gray-200{ border: 1px solid var(--gray-200); color: var(--gray-500);}
.badge-danger_bg{ background-color: var(--danger_bg); color: var(--danger);}


/* List Style */
.list_style_1 li {display: flex;padding-bottom: 0.7rem;line-height: 1.4;}
.list_style_1 li:last-child{padding-bottom:0;}
.list_style_1 li > span{display: inline-block; width:8.0rem; padding-right: 0.5rem;flex-shrink: 0;}


.list_style_2 li{display: flex; padding-bottom:0.8rem;}
.list_style_2 li:before{content:'-';display: inline-block;margin-right:1.0rem;}

.list_style_3 li {display: flex;justify-content: space-between;flex-wrap: wrap;}
.list_style_3 li:last-child{margin-bottom:0 !important;}


/* collapse 화살표 아이콘 */
/* 초기 상태에서는 화살표 아래 아이콘을 보여줌 */
.collapse_ex .btn[aria-expanded="false"] img{transform: rotate(0deg);}

/* 펼쳐진 상태에서는 화살표 위 아이콘을 보여줌 */
.collapse_ex .btn[aria-expanded="true"] img{transform: rotate(180deg);}


/*탭*/
.tab_sticky{
	position: sticky;
	top: 4.8rem;
	z-index: 15;
}

/*nav-tabs*/
.nav-tabs {
	background: #F5F6F8;
	border-radius: 0.8rem;
	padding: 0.8rem;
	border: 0;
	flex-wrap: nowrap;
}
.nav-tabs .nav-link {
	height: 4.4rem;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.4rem;
	color: #999;
	border: 0;
	margin-bottom: 0px;
	padding-left: 0.2rem;
	padding-right: 0.2rem;
	border-radius: 0.8rem;
	font-weight: 600;
	word-break: keep-all;
}
.nav-tabs .nav-link.active, .nav-tabs .nav-item.show .nav-link {
	color: #495057;
	background: #fff;
	color: #000;
	box-shadow: 0 0.3rem 0.6rem rgba(0,0,0,0.06);
}

/*nav-pills*/
.nav-pills{
	margin-left:-0.4rem;
	margin-right:-0.4rem;
	flex-wrap: nowrap;
}
.nav-pills .col{
	padding-left:0.4rem;
	padding-right:0.4rem;
}
.nav-pills .nav-link {
	background: none;
	border: 0;
	border-radius: 1rem;
	background: #AAB1B7;
	color: #fff;
}



/*nav_tab_line*/
.nav_tab_line{
	width: 100%;
	margin: 0;
	background-color: #fff;
}
.nav_tab_line {
	border: unset;
	border-bottom:1px solid #E3E3E3;
}
.nav_tab_line .nav-item{
	text-align: center;
/*	background-color: #fff;*/
	border: none;
	-ms-flex-preferred-size: 0;
	flex-basis: 0;
	-ms-flex-positive: 1;
	flex-grow: 1;
	max-width: 100%;
	width: 100%;
}
.nav_tab_line .nav-link {
	position: relative;
/*	border: 1px solid white;*/
	border: none;
	color: #000;
	height: 4.9rem;
	padding: 1.5rem;
	width: 100%;
	font-size: 1.6rem;
	font-weight: 600;
	background: transparent;
}
.nav_tab_line .nav-link.active, .nav_tab_line .nav-item.show .nav-link {
	/*border-bottom: 0.2rem solid var(--primary);
	color: var(--primary);
	transform: translateY(0.15rem);
	padding-bottom:1.15rem;*/
	color: var(--primary);
}
.nav_tab_line .nav-link.active::after, .nav_tab_line .nav-item.show .nav-link::after{
	content: "";
	display: block;
	position: absolute;
	width: 100%;
	height: 2px;
	background-color: var(--primary);
	left: 0;
	bottom: -1px;
}


/*nav_tab_line2*/
.nav_tab_line2 {
	width: 100%;
	margin: 0;
	background-color: #fff;
}
.nav_tab_line2 {
	border: unset;
/*	border-bottom:1px solid #E3E3E3;*/
}
.nav_tab_line2 .nav-item{
	text-align: center;
	background-color: #fff;
	-ms-flex-preferred-size: 0;
	flex-basis: 0;
	-ms-flex-positive: 1;
	flex-grow: 1;
	max-width: 100%;
	width: 100%;
}
.nav_tab_line2 .nav-link {
	color: var(--text);
	height: 6.0rem;
	padding: 1rem;
	width: 100%;
	font-size: 1.6rem;
	font-weight: 600;
	background: transparent;
	border: 0;
	border-bottom: 1px solid var(--border);
}
.nav_tab_line2 .nav-link.active, .nav_tab_line2 .nav-item.show .nav-link {
	border-color: var(--primary);
	color: var(--primary);
}


/*드롭다운*/
.dropdown-menu{padding-top:1rem;padding-bottom:1rem;}
.dropdown-menu .dropdown-item{padding: 1rem 2rem;}
.dropdown-menu .dropdown-item:hover, .dropdown-menu .dropdown-item:focus, .dropdown-menu .dropdown-item:active{background:transparent; color: #fff;}


/*커스텀 스위치*/
.custom-switch {
	padding: 0;
	width: 4.0rem;
	height: 2.4rem;
}
.custom-switch .custom-control-label::after {
	width: 1.95rem;
	height: 1.95rem;
	background-color: #fff;
	border-radius: 3rem;
	top: 0.225rem;
	left: 0.225rem;
}
.custom-control-label::after {
	position: absolute;
	top: 0.3rem;
	display: block;
	width: 1rem;
	height: 1rem;
	content: "";
	cursor: pointer;
}
.custom-switch .custom-control-input:checked ~ .custom-control-label::after {
	background-color: #fff;
	left: 1.1rem;
}
.custom-control-input:checked ~ .custom-control-label::before {
	color: #fff;
	border-color: var(--sub_primary);
	background-color: var(--sub_primary);
}
.custom-control-label::before {
	background-color: var(--gray-200);
	border: 0;
	top: 0;
	cursor: pointer;
}
.custom-switch .custom-control-label::before {
	left: 0;
	width: 4.0rem;
	height: 2.4rem;
	border-radius: 2rem;
}


.dot_list li {
    list-style: none;
    margin-bottom:1.0rem;
	display: flex;
}

.dot_list li:before {
    content:"·";
    vertical-align:middle;
	margin-right:0.5rem;
}
.dot_list li:last-child{margin-bottom:0;}

.dot_list.fs_10 li{margin-bottom:0.3rem;}


/* 폼 사각형 */
.sq_guide { display:flex; flex-wrap: wrap; }
.sq_guide li {
	width: 80px;
	height: 40px;
	border-radius: 0.5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.4rem;
	margin: 0.5rem;
}


/*에디터스타일*/
.edit_style{}
.edit_style .h1, .edit_style h1{font-weight:700;font-size:3.5rem;margin-bottom:0.5rem;}
.edit_style .h2, .edit_style h2{font-weight:700;font-size:2.5rem;margin-bottom:0.5rem;}
.edit_style .h3, .edit_style h3{font-weight:700;font-size:1.8rem;margin-bottom:0.5rem;}
.edit_style .h4, .edit_style h4{font-weight:700;font-size:1.5rem;margin-bottom:0.5rem;}
.edit_style img {
	max-width: 100%;
	width: auto !important;
	margin: 0 auto;
	display: inline-block;
}
.edit_style p{white-space: pre-line;line-height: 160%;}
.edit_style ol, .edit_style ul{padding-left: 1.4rem;line-height: 160%;}




/* ==================== 버튼 / 인풋 디자인 ==================== */
/* ===== 버튼 ===== */
.btn {
    height: var(--height);
    display: inline-flex;
    justify-content: center;
    align-items: center;
    font-size: 1.5rem;
    font-weight: 400;
    padding-left: 1.3rem;
    padding-right: 1.3rem;
    word-break: keep-all;
    word-wrap: break-word;
}
.btn-sm {
    height: var(--height_sm);
    font-size: 1.4rem;
    padding-left: 0.7rem;
    padding-right: 0.7rem;
}
.btn-md {
    height: var(--height_md);
    font-size: 1.5rem;
    padding-left: 1.3rem;
    padding-right: 1.3rem;
}
.btn-md2 {
    height: var(--height_md2);
    font-size: 1.5rem;
    padding-left: 1.3rem;
    padding-right: 1.3rem;
}
.btn-lg {
    height: var(--height_lg);
    font-size: 1.6rem;
    padding-left: 1.8rem;
    padding-right: 1.8rem;
}
.btn-link {
    height: auto;
    padding: 0;
    cursor: pointer;
    display: flex;
    align-items: center;
    border-radius: 0;
    background: transparent;
    flex-shrink: 0;
    border: 0;
}
.btn-icon {
    height: auto;
    padding: 0;
    cursor: pointer;
    display: flex;
    align-items: center;
    border-radius: 0;
    background: transparent;
    flex-shrink: 0;
    border: 0;
}
.btn-icon img{flex-shrink: 0;}
.btn_auto{ width: unset; height: unset; padding: 0; margin: 0;}


/* SNS 버튼 */
.btn-naver{background:#1CC800;border-color:#1CC800;color:#fff;}
.btn-naver:hover, .btn-naver:focus{background:#1ABB00;border-color:#1ABB00;}

.btn-kakao{background:#FFDD00;border-color:#FFDD00;color:#333;}
.btn-kakao:hover, .btn-kakao:focus{background:#FFCC00;border-color:#FFCC00;}

.btn-apple{background:#000;border-color:#000;color:#fff;}
.btn-apple:hover, .btn-apple:focus{background:#222;border-color:#222;}


/* 버튼 disabled */
.btn.disabled, .btn:disabled {
	opacity: 1;
	color: var(--gray-500) !important;
	background: var(--gray-200) !important;
	border-color: var(--gray-200) !important;
    cursor: default;
}


/* 버튼 그룹 */
.btn-group-toggle .btn-outline-light:not(:disabled):not(.disabled).active, .btn-group-toggle .show > .btn-outline-light.dropdown-toggle {
    color: #fff;
    background-color: var(--primary);
    border-color: var(--primary);
}
.btn-group-toggle .btn-light:not(:disabled):not(.disabled).active, .btn-group-toggle .show > .btn-light.dropdown-toggle {
    color: #000;
    background-color: #fff;
    border-color: #000;
}
.btn-group-toggle .btn{margin-right:0.8rem;}
.btn-group-toggle .btn:last-child{margin-right:0;}

.btn-group-toggle .btn input[type=radio], .btn-group-toggle .btn input[type=checkbox], .btn-group-toggle .btn-group .btn input[type=radio], .btn-group-toggle .btn-group .btn input[type=checkbox] {
    position: absolute;
    clip: rect(0, 0, 0, 0);
    pointer-events: none;
}

.btn-group-full{display:flex;}
.btn-group-full .btn{display:flex;padding-left:0.4rem;padding-right:0.4rem;}

.btn_toggle_primary .btn-outline-light{border-color:#D6DAE5;}
.btn_toggle_primary .btn-outline-light:not(:disabled):not(.disabled).active{color: var(--primary);background-color: #fff;border-color: var(--primary);font-weight:600;}



/* 버튼 색상 커스텀 */
.btn:active, .btn:focus {
	outline:none !important;
	box-shadow:none !important;
}

.btn-primary {
	color: #fff;
	background-color: var(--primary);
	border-color: var(--primary);
}
.btn-primary:not(:disabled):hover, .btn-primary:not(:disabled):focus, .btn-primary:not(:disabled).focus, .btn-primary:not(:disabled):active {
	color: #fff;
	background-color: var(--primary-800);
	border-color: var(--primary-800);
}

.btn-secondary {
    color: #fff;
    background-color: var(--secondary);
    border-color: var(--secondary);
}
.btn-secondary:not(:disabled):hover, .btn-secondary:not(:disabled):focus, .btn-secondary:not(:disabled).focus, .btn-secondary:not(:disabled):active {
    color: #fff;
    background-color: #103051;
    border-color: #103051;
}

.btn-primary-100 {
    color: var(--primary);
    background-color: var(--primary-100);
    border-color: var(--primary-100);
}
.btn-primary-100:not(:disabled):hover, .btn-primary-100:not(:disabled):focus, .btn-primary-100:not(:disabled).focus, .btn-primary-100:not(:disabled):active {
    color: var(--primary);
    background-color: var(--primary-300);
    border-color: var(--primary-300);
}

.btn-gray-50 {
    color: var(--gray-700);
    background-color: var(--gray-50);
    border-color: var(--gray-50);
}
.btn-gray-50:not(:disabled):hover, .btn-gray-50:not(:disabled):focus, .btn-gray-50:not(:disabled).focus, .btn-gray-50:not(:disabled):active {
    color: var(--gray-700);
    background-color: var(--gray-100);
    border-color: var(--gray-100);
}

.btn-gray-100 {
    color: var(--gray-600);
    background-color: var(--gray-100);
    border-color: var(--gray-100);
}
.btn-gray-100:not(:disabled):hover, .btn-gray-100:not(:disabled):focus, .btn-gray-100:not(:disabled).focus, .btn-gray-100:not(:disabled):active {
    color: var(--gray-600);
    background-color: var(--gray-200);
    border-color: var(--gray-200);
}

.btn-outline-primary {
    color: var(--primary);
    background-color: #fff;
    border-color: var(--primary);
}
.btn-outline-primary:not(:disabled):hover, .btn-outline-primary:not(:disabled):focus, .btn-outline-primary:not(:disabled).focus, .btn-outline-primary:not(:disabled):active {
    color: var(--primary);
    background-color: var(--primary-100);
    border-color: var(--primary-800);
}

.btn-outline-secondary {
    color: var(--secondary);
    background-color: #fff;
    border-color: var(--secondary);
}
.btn-outline-secondary:not(:disabled):hover, .btn-outline-secondary:not(:disabled):focus, .btn-outline-secondary:not(:disabled).focus, .btn-outline-secondary:not(:disabled):active {
    color: var(--secondary);
    background-color: var(--gray-50);
    border-color: var(--secondary);
}

.btn-outline-gray-100 {
    color: var(--gray-400);
    background-color: #fff;
    border-color: var(--gray-100);
}
.btn-outline-gray-100:not(:disabled):hover, .btn-outline-gray-100:not(:disabled):focus, .btn-outline-gray-100:not(:disabled).focus, .btn-outline-gray-100:not(:disabled):active {
    color: var(--gray-400);
    background-color: var(--gray-50);
    border-color: var(--gray-100);
}

.btn-outline-gray-200 {
    color: var(--gray-600);
    background-color: #fff;
    border-color: var(--gray-200);
}
.btn-outline-gray-200:not(:disabled):hover, .btn-outline-gray-200:not(:disabled):focus, .btn-outline-gray-200:not(:disabled).focus, .btn-outline-gray-200:not(:disabled):active {
    color: var(--gray-600);
    background-color: var(--gray-50);
    border-color: var(--gray-200);
}



/*바텀 버튼*/
.bottom_btn {
	position: fixed;
	left: 50%;
	bottom: 0;
	width: 100%;
	padding: 0 2rem;
	max-width: 576px;
	transform: translateX(-50%);
	z-index:1040;
}
.bottom_btn::after{
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    bottom: 0; left: 0;
    background: linear-gradient(0deg, rgba(255, 255, 255, 0.01) 0%, rgba(255, 255, 255, 0) 100%);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    -webkit-mask-image: linear-gradient(
        to top,
        rgba(0,0,0,1) 0%,
        rgba(0,0,0,1) 55%,
        rgba(0,0,0,0) 100%
    );
    mask-image: linear-gradient(
        to top,
        rgba(0,0,0,1) 0%,
        rgba(0,0,0,1) 55%,
        rgba(0,0,0,0) 100%
    );
    z-index: -1;
}

/* ===== 인풋 ===== */
/* 인풋 자동완성 초기화 */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
	-webkit-text-fill-color: var(--text);
    -webkit-box-shadow: 0 0 0px 1000px var(--bg) inset;
    box-shadow: 0 0 0px 1000px var(--bg) inset;
    transition: background-color 5000s ease-in-out 0s;
}

input:autofill,
input:autofill:hover,
input:autofill:focus,
input:autofill:active {
	-webkit-text-fill-color: var(--text);
    -webkit-box-shadow: 0 0 0px 1000px var(--bg) inset;
    box-shadow: 0 0 0px 1000px var(--bg) inset;
    transition: background-color 5000s ease-in-out 0s;
}

/* 인풋 높이 */
.form-control {height: var(--height_md);}
.form-control-sm {height: var(--height_sm);border-radius: 0.8rem;}
.form-control-md {height: var(--height_md);border-radius: 0.8rem;}
.form-control-lg {height: var(--height_lg);border-radius: 0.8rem;}
.form-control-auto {height: auto;}

input.form-control{white-space: nowrap; overflow: hidden; text-overflow: ellipsis; word-break: break-all;}

/* 인풋 타이틀, 필수값 표시 */
.ip_wr .ip_tit { display: block; margin-bottom: 1.0rem;}
.ip_tit:has(.text_count){ display: flex; justify-content: space-between; align-items: center;}
.ip_tit h5 { font-size: 1.5rem; font-weight: 500; display: inline-block; position: relative; line-height: 1.4;}
.ip_tit.required h5::after{ content: "*"; position: absolute; color: var(--danger); top: 0; right: -1.0rem;}

/* 기본 디자인 */
.form-control{
    font-size: 1.5rem;
    font-weight: 400;
    color: var(--text);
    background-color: #fff;
    border: 1px solid var(--gray-100);
    border-radius: 0.8rem;
    padding: 1.2rem;
}
.form-control:focus{
    border-color: var(--gray-100);
}
.form-control::placeholder{ color: var(--gray-500);}

/* disabled / readonly */
.form-control:disabled{
    background-color: var(--gray-200);
    border-color: var(--gray-200);
    color: var(--gray-500);
}
.form-control[readonly]{
    background-color: var(--gray-200);
    border-color: var(--gray-200);
    color: var(--gray-500);
}

/* 인풋 gray */
.form-control.gray_50{
    background-color: var(--gray-50);
    border: 1px solid var(--gray-50);
}
.form-control.gray_100{
    background-color: var(--gray-100);
    border: 1px solid var(--gray-100);
}

/* 비밀번호 인풋 */
.form-password{position:relative;}
.form-password .form-control{padding-right:5.0rem;}
.form-password .pw_icon {
	width: 2.5rem;
	height: 2.5rem;
	border: 0;
	background: transparent;
	padding: 0;
	position: absolute;
	right: 1.5rem;
	top: 50%;
	transform: translateY(-50%);
}

/* 플로팅 텍스트 있는 인풋 */
.with_text_input{
    display: flex;
    align-items: center;
    padding: 0 1.2rem;
    background: #fff;
    gap: 2rem;
}
.with_text_input input{
    border: 0;
    padding-right: 0;
    padding-left: 0;
    background: transparent;
}
.with_text_input input:focus{ background: transparent;}
.with_text_input:has(input:focus) {border-color: var(--gray-100);}

/* 인증번호 타이머 */
.code_timer {
    font-size: 1.5rem;
    font-weight: 500;
    color: var(--danger);
    line-height: 1.3;
    text-align: right;
    flex-shrink: 0;
}

/* 단위 텍스트 */
.unit_txt{
    min-width: 4.3rem;
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--gray-900);
    line-height: 1.4;
    text-align: right;
    flex-shrink: 0;
}

/* form-text */
.form-text {
	display: none;
	margin-top: 0.5rem;
	font-size: 1.4rem;
	color: var(--gray-500);
    line-height: 1.3;
}
.ip_invalid .ip_invalid{ display: flex; color: var(--danger);}
/* .ip_invalid input.form-control, .ip_invalid input.form-control:focus {
	border-color: var(--danger);
	color: var(--danger)
} */
.ip_valid .ip_valid{ display: flex; color: var(--success);}

.form-text.help_text{
	display: flex;
    align-items: start;
    gap: 0.5rem;
}
.form-text.help_text::before{
    content: "※";
    display: inline-block;
}
/* 앞에 마크 없이 사용하는 경우 */
.form-text.help_text.no_marker::before{ display: none;}

.text_count{
	font-size: 1.3rem;
    font-weight: 500;
	color: var(--gray-500);
	text-align: right;
}
.form_text_timer{
	font-size: 1.4rem;
	font-weight: 500;
	color: var(--danger);
}

/*.form-row*/
/*.form-row{margin-left:-0.4rem;margin-right:-0.4rem;}
.form-row > .col, .form-row > [class*=col-]{padding-left:0.4rem;padding-right:0.4rem;}
.form-row > .col-3 .btn{padding-left:0.5rem;padding-right:0.5rem;}*/


/* textarea 높이 */
textarea.form-control {
    min-height: 13.6rem;
    padding: 1.2rem;
    line-height: 1.4;
    resize: none;
}
.form-control textarea::placeholder {
	color: var(--gray-500);
	opacity: 1;
}


/* 셀렉트 박스 */
.custom-select, .custom-select2 {
	padding-right: 3.6rem;
	background-size: 2.4rem;
	padding-left: 1.2rem;
	font-size: 1.5rem;
	font-weight: 400;
	color: var(--text);
	min-width: 13.5rem;
	text-align: left;
	position:relative;
}
.custom-select {
    background: url(../img/ic_ip_select.png)no-repeat center right 1.2rem;
    background-size: 2.4rem;
}
.custom-select2:after {
    content: '';
    display: block;
    width: 2.0rem;
    height: 2.0rem;
    background: url(../img/ic_ip_select.png)no-repeat center center;
    background-size: cover;
    position: absolute;
    right: 1.5rem;
    top: 50%;
    transform: translateY(-50%);
}


/* 커스텀 셀렉트 드롭다운 */
.custom-select2[aria-expanded="true"] {
    border-radius: 1rem 1rem 0 0;
    border-color: var(--gray);
}
.custom-select2[aria-expanded="true"]:after {
    transform: translateY(-50%) rotate(180deg);
}
.custom-select2 + .dropdown-menu {
    min-width: 100%;
    margin: -1px 0 0;
    border-color: var(--border);
    font-size: 1.5rem;
    border-radius: 0 0 1rem 1rem;
    border-color: var(--gray);
    border-top-color: var(--border);
    max-width: 100%;
}
.custom-select2 + .dropdown-menu a {
    padding: 1.0rem 1.5rem;
    white-space: break-spaces;
    word-break: break-all;
}
.custom-select2 + .dropdown-menu a:hover {
    color: var(--primary);
    background: var(--light);
}


/* 날짜 선택 */
input.form-control[type="date"], input.form-control[type="time"]{position: relative;}
input.form-control[type="date"]::-webkit-calendar-picker-indicator, input.form-control[type="time"]::-webkit-calendar-picker-indicator{
    -webkit-appearance: none;
    background: none;
    width: 100%; height: 100%; cursor: pointer;
    position: absolute; left: 0; top: 0;
}
input.form-control[type="date"]::before, input.form-control[type="time"]::before{
    content: ''; display: block; width: 2.4rem; height: 2.4rem; position: absolute; top: 50%;
    transform: translateY(-50%); right: 1.6rem; background: var(--gray); cursor: pointer;
    -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat; -webkit-mask-position: center; mask-position: center; -webkit-mask-size: contain; mask-size: contain;
}
input.form-control[type="time"]::before{
    -webkit-mask: var(--ic_time); mask: var(--ic_time);
}
input.form-control[type="date"]::before{
    -webkit-mask: var(--ic_date); mask: var(--ic_date);
}


input.form-control.no-icon[type="date"]::before, input.form-control.no-icon[type="time"]::before{ display: none;}


/*검색*/
.sch_ip {display: flex;border:1px solid var(--border);background: #fff;padding: 0 1.5rem 0 1.5rem;border-radius: 1.0rem;}
.sch_ip .form-control{height:4.8rem;padding: 0.5rem 0;}
.sch_ip .form-control:focus { background-color: transparent; box-shadow: none;}
.sch_ip .sch_btn{width:3.0rem;height:3.0rem;border:0;background: transparent;}
.sch_ip .sch_btn img{ width: 2.5rem;}


/*회색 검색*/
.sch_gray.sch_ip{ background: var(--light); border:0; padding-left: 2.0rem;}
.sch_gray.sch_ip .form-control{ background: transparent; font-size: 1.4rem;}


/* 검색어 삭제 버튼 */
input[type=search]::-ms-clear, input[type=search]::-ms-reveal {
	display:none;
}
input[type="search"]::-webkit-search-decoration,
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-results-button,
input[type="search"]::-webkit-search-results-decoration{
	display:none;
}
.sch_ip .sch_clear_btn{
	width: 2.4rem;
	height: 2.4rem;
	display: none;
}
.sch_ip .sch_clear_btn img{
	width: 2.4rem;
	height: 2.4rem;
}


/* 체크박스, 라디오 공통 */
.checks_wr, .radios_wr{ display: flex; flex-wrap: wrap; gap: 3rem; row-gap: 1.6rem;}
.checks label, .radios label{display: flex; align-items: center; cursor: pointer; gap: 1rem;}
.checks input, .radios input{ display: none;}

/* 텍스트 */
.chk_p{ padding-top:0.1rem; font-size: 1.5rem; font-weight: 500; color: var(--gray-600); line-height: 1.1;}
.checks input:checked ~ .chk_p{}

/* 인풋 오른쪽 */
.checks label.chk_right, .radios label.chk_right{ flex-flow: row-reverse; justify-content: flex-end;}

/* 체크박스*/
.checks .ic_box {
	display: inline-block;
	width: 2.2rem;
	height: 2.2rem;
	border: 1px solid var(--gray-200);
	border-radius:0.6rem;
	background-color: #fff;
	background-image: url(../img/check01_off.png);
	background-position: center;
	background-size: 1.0rem auto;
	background-repeat: no-repeat;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.checks input:checked + .ic_box {
	background-image: url(../img/check01_on.png);
	background-color: var(--sub_primary);
	border-color: var(--sub_primary);
}

/* 라디오 */
.radios .ic_box {
	position: relative;
	flex-shrink: 0;
	width: 2.2rem;
	height: 2.2rem;
	text-align: center;
	background-color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	border: 1px solid var(--gray-200);
}
.radios .ic_box::after{
	content: '';
	display: block;
	width: 1.2rem;
	height: 1.2rem;
	border-radius: 50%;
	background-color: var(--gray-400);
}
.radios input:checked + .ic_box{ border-color: var(--sub_primary);}
.radios input:checked + .ic_box:after {background-color: var(--sub_primary);}


/* 체크박스, 라디오 disabled */
label:has(input:disabled){ cursor: default;}
input:disabled + .ic_box{ opacity: 0.5; cursor: default;}
input:disabled ~ .chk_p{ cursor: default; color: var(--gray-300) !important;}

/* 라디오 버튼 */
.rdchk_btn_wr .btn-outline-gray-100{ color: var(--gray-400); font-weight: 600;}
.rdchk_btn_wr .btn:has(input:checked){ border-color: var(--secondary); color: var(--secondary);}


/* 이미지 업로드 */
.touch_scroll:has(.image_upload) .container{ width: max-content;}
.img_upl_wr .container{ margin-right: unset; margin-left: unset;}
.image_upload{display: inline-block;position: relative;margin-right:1.0rem;}
.image_upload:last-of-type{ margin-right: 0;}
.upload_box{
	width: 11rem;
	/* border: 1px solid var(--border); */
	overflow: hidden;
	cursor: pointer;
	background: url(../img/btn_add_img.png) no-repeat center top 35% / 4.0rem;
	background-color: var(--gray-100);
	border-radius: 1.0rem;
	position: relative;
}
.upload_box .max_img {
	position: absolute;
	bottom: 20%;
	width: 100%;
	left: 0;
	font-size: 1.5rem;
	text-align: center;
	color: var(--gray-500);
	font-weight:500;
}
.image_upload.on .upload_box{background: none;}
.upload_del {
    position: absolute;
    top: 0.8rem;
    right: 0.8rem;
    width: 2.4rem;
    height: 2.4rem;
    border-radius: 50%;
    background-color: transparent;
    padding: 0 !important;
    display: none;
}
.upload_del img{width:100%;}
.image_upload.on .upload_del{display: flex;}



/* 페이지네이션 */
.pagination {display: flex; justify-content: center; align-items: center; }
.pagination li { height: 100%; }
.pagination a {
    color: #000;
    font-weight: 500;
    margin: 0 0.4rem;
	width: 2.8rem;height: 2.8rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
}
.pagination a.on {
	background-color: var(--primary);color:#fff; font-weight: 400;
    color: #fff;
}
.pagination a.arrow{background-color: #fff;color: #626C79;}
.pagination a.arrow{margin:0;}
.pagination a.arrow.disabled img{opacity:0.3;}

/* 페이지네이션 ver2 */
.pagination_wr.pgn_ver2{
	display: flex;
	justify-content: center;
}
.pgn_ver2 .btn.pg_arrow{
	border: 1px solid var(--gray-100);
	background: #fff;
	width: 4.0rem;
	height: 4.0rem;
	padding: 0;
}
.pgn_ver2 .btn.pg_arrow:disabled{
	border: 1px solid var(--gray-100) !important;
	background: #fff !important;
}
.pgn_ver2 .btn.pg_arrow:disabled img{ opacity: 0.3;}
.pgn_ver2 .btn.pg_arrow img{
	width: 2.0rem;
	flex-shrink: 0;
}

.pgn_ver2 .btn.pg_arrow.prev{
	border-top-right-radius: 0;
	border-bottom-right-radius: 0;
	border-right: 0;
}
.pgn_ver2 .btn.pg_arrow.next{
	border-top-left-radius: 0;
	border-bottom-left-radius: 0;
	border-left: 0;
}

.pgn_ver2 .pgn_number {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 4.0rem;
	padding: 0.3rem 0.4rem;
	border: 1px solid var(--gray-100);
	border-radius: 0;
}
.pgn_ver2 .pagination li { height: 100%; }
.pgn_ver2 .pagination a {
	color: var(--gray-500);
	font-weight: 400;
	width: 3.2rem;
	height: 3.2rem;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 0.4rem;
}
.pgn_ver2 .pagination a.on {
	background-color: var(--primary);
	color:#fff;
	font-weight: 500;
}


/* 페이저 */
.pager {
    background: #ffffff;
    border-radius: 15rem;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 170px;
    height: 45px;
    margin: 3rem auto 0;
    border: 1px solid var(--border);
}

/* 테이블 */
.table_01 {width:100%; border-collapse: collapse;   border-bottom:1px solid #e3e3e3;border-top: 1px #eee solid;line-height: 140%;}
.table_01 th {
    border-bottom: 1px solid #eee;
    color: #1C1C1E;
    font-weight: 500;
    padding: 0.7rem 1.2rem 0.7rem 1.2rem;
    background: #F8F8F8;
    vertical-align: top;

}
.table_01 td {border-bottom:1px solid #eee;  padding:0.7rem 1.2rem;color: #1C1C1E;}


/* 테이블 슬래쉬 */
.table_01 th.slash {
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg"><line x1="0" y1="100%" x2="100%" y2="0" stroke="rgb(77,77,77)" /></svg>'); background-repeat: no-repeat;
}
.table_01 th.backslash {
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg"><line x1="0" y1="0" x2="100%" y2="100%" stroke="rgb(77,77,77)" /></svg>'); background-repeat: no-repeat;
}
.table_01 th.slash, .table_01 th.backslash { text-align: left; }
.slash div, .backslash div { text-align: right; }

/*테이블 반응형때*/
.table_scroll { overflow-x: auto; overflow-y: hidden; padding: 0px !important; }


/* 이미지 크롭 */
.rect{width: 100%;position: relative;overflow: hidden; }
.rect:after{content: "";display: block;padding-bottom: 100%; }
.rect img{ position: absolute;width: 100%;height: 100%;object-fit: cover;object-position: center;top: 50%;left: 50%;transform: translate(-50%,-50%);}

.rect2{width: 100%;position: relative;overflow: hidden; }
.rect2:after{content: "";display: block;padding-bottom:24.212%; }
.rect2 img{ position: absolute;width: 100%;height: 100%;object-fit: cover;object-position: center;top: 50%;left: 50%;transform: translate(-50%,-50%);}


.rect3 {width: 100%;overflow: hidden;position: relative;display: block;}
.rect3::after { content: '';display: block; padding-bottom:58.255%;}
.rect3 img {position: absolute;width: 100%;height: 100%;object-fit: cover;object-position: center;top: 50%;left: 50%;transform: translate(-50%,-50%);}

.rect4{width: 100%;position: relative;overflow: hidden; }
.rect4:after{content: "";display: block;padding-bottom:67.962%; }
.rect4 img{ position: absolute;width: 100%;height: 100%;object-fit: cover;object-position: center;top: 50%;left: 50%;transform: translate(-50%,-50%);}





/* ==================== 모달 디자인 ==================== */
/* ===== 모달 공통 ===== */
body{padding-right: 0px !important;}
body.modal-open[style]{overflow-y: scroll;
	position: fixed;
    top: 0px;
    width: 100%;
}
.modal{padding-right: 0px !important; overflow-y: auto;}
.modal-dialog {max-height: 100%;height: 100%;}
.modal .modal-dialog-scrollable .modal-body {
	overscroll-behavior: none;	/* 모달 내에서만 스크롤 */
	-webkit-overflow-scrolling: touch;	/* 아이폰에서 스크롤 부드럽게 */
}

/* ===== modal-default ===== */
.modal-default {
	max-width: var(--body_width);
	margin: 0 auto;
	padding-left: 0;
	padding-right: 0;
	padding: 2.0rem 1.6rem;
}

.modal .modal-content {border: 0;border-radius: 2.8rem; background: var(--deep);}

.modal .modal-header{align-items:center;padding:1.6rem 2.4rem;justify-content:space-between; border-color: rgb(255 255 255 / 10%); gap: 1rem;}
.modal .modal-header .modal-title {font-weight: 600;font-size: 1.8rem;flex: 1 1 auto;}
.modal .modal-header .close{text-shadow: none;opacity: 1;width:2.5rem;padding: 0;margin: 0;}

.modal .modal-body { position: relative; flex: 1 1 auto;padding:2.4rem 2.0rem;}
.modal .modal-body .close_bar{width:4.4rem;height:0.4rem;background:#E3E3E3;border-radius:1.0rem;margin:0 auto 1.0rem;border: 0;display: block;}

.modal .modal-footer > *{margin:0;}
.modal .modal-footer {padding: 1.5rem 2.0rem 2.5rem;border:0;display: block;}
.modal .modal-footer .form-row{margin-right: -0.5rem; margin-left: -0.5rem;}

.modal_bd_tit{
	font-size: 1.8rem;
	font-weight: 600;
	line-height: 1.3;
	color: var(--text);
	margin-bottom: 1.0rem;
}
.modal_bd_text{
	font-size: 1.5rem;
	color: var(--gray-100);
	line-height: 1.5;
}


/* ===== modal-sm ===== */
.modal-sm {
	max-width: calc(30rem + 3.2rem);
	margin: 0 auto;
	padding: 1.5rem;
	padding: 2rem 1.6rem;
    text-align: center;
}
.modal .modal-sm .modal-header{ padding: 1.6rem 2rem;}
.modal .modal-sm .modal-body{ border:0; padding: 4rem 2.0rem 3.0rem;}
.modal .modal-sm .modal-footer{ padding: 0 2.0rem 2.0rem;}


/* ===== modal-md ===== */
.modal-md {
	max-width: calc(42rem + 3.2rem);
	margin: 0 auto;
	padding: 1.5rem;
	padding: 2rem 1.6rem;
}

.modal .modal-md .modal-header{}
.modal .modal-md .modal-body{}
.modal .modal-md .modal-footer{padding: 0 2.0rem 2.0rem;}



/* ===== 풀사이즈 모달 ===== */
.modal_full.modal{overflow-y: auto;}
.modal_full.modal .modal-content {border-radius: 0;max-height: 100vh;height: 100vh;}
.modal_full.modal .modal-header {
	width: 100%;
	padding: 0rem 2rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: var(--hd_height_m);
    border-radius: 0;
}
.modal_full.modal .modal-header button{border:0;background:transparent;width:3.0rem;}
.modal_full.modal .modal-dialog{margin:0 auto;max-width:57.6rem;transform: translate(0%, 0);max-height: 100%;}
.modal_full.modal .modal-body{border:0;padding-left:1.6rem;padding-right:1.6rem;}
.modal_full.modal .modal-footer{padding-top:1.4rem;padding-bottom:1.4rem;display: block;padding-left: 1.6rem;padding-right: 1.6rem;}
.modal_full.modal .modal-footer .form-row{margin-left: -5px;margin-right: -5px;}
.modal_full.modal .bg-black .modal-title{background:#000;}


/* ===== modal_bottom =====*/
.modal_bottom.modal{padding-right:0 !important;overflow-y: hidden;}
.modal_bottom.modal.show .modal-dialog {
    padding-right: 0 !important;
    transform: translate(-50%, 0);
}
.modal_bottom.modal .modal-dialog {
    transform: translate(0, 5rem);position: fixed;
	bottom: 0;
	width: 100%;
	max-width:100%;
	transform: translate(-50%, 5rem);
	left: 50%;
    justify-content: flex-end;
    margin: 0 auto;
    min-height: 100%;
    max-width: 57.6rem;
}
.modal_bottom.modal .modal-title button{border:0;background:transparent;width:3.2rem;position:absolute;right:2.0rem;top:1.6rem;}
.modal_bottom.modal .modal-content{border-radius: 2.8rem 2.8rem 0 0;margin-top: 3.0rem;}
.modal_bottom.modal .modal-header{border-bottom: 0; padding: 2.0rem;}
.modal_bottom.modal .modal-body{border-bottom:0; padding: 1rem 2.0rem;}
.modal_bottom.modal .modal-footer {padding: 1.0rem 2.0rem 1.2rem;}

/* 모달 뒷배경 */
.modal-backdrop {left: 50%; width: 100%;transform: translateX(-50%);max-width:57.6rem; backdrop-filter: blur(2px); -webkit-backdrop-filter: blur(2px);}


/* 토스트팝업 */
.toast{
    color: #fff;
    border-radius: 0.6rem;
    font-size: 1.5rem;
    font-weight: 500;
    padding: 0.5rem 1rem;
}
/* toast */
.toast{
    position: fixed;
    top: 7.2rem;
    left: 50%;
    transform: translateX(-50%);
    padding: 0 1.4rem;
    box-shadow: none;
    font-weight: 300;
    z-index: 9999;
    border: 0;
    background: transparent;
}
.toast-body {
    padding: 1.3rem 2rem;
    background-color: rgba(51, 51, 51, 0.8);
    color: var(--white);
    font-size: 1.4rem;
    font-weight: 500;
    border-radius: 1.0rem;
    text-align: center;
}
.toast-body p{
    display: flex;
    align-items: center;
    line-height: 1.3;
	justify-content:center;
}
.toast-body p i{
    margin-right: 0.6rem;
}



/* ==================== 헤더 / 푸터 ==================== */
/* ===== 헤더 ===== */
.hd_m {
	display:flex;
	align-items: center;
	justify-content: space-between;
	height: var(--hd_height_m) !important;
	width: 100%;
	max-width: 576px;
	position: fixed;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	padding:0 2rem;
	z-index: 1000;
	background: linear-gradient(180deg,rgba(2, 6, 23, 1) 0%, rgba(2, 6, 23, 0.8) 100%);
	backdrop-filter: blur(20px);
}
/* 헤더 버튼 공통 */
.hd_btn{ width: 3rem;}
/* 헤더 드롭다운 */
.hd_drop .dropdown-menu{
    background-color: var(--deep);
    text-align: center;
    box-shadow: 0 0 1.2rem rgb(0 0 0 / 20%);
}
.hd_drop .dropdown-item{ color: var(--gray-100); transition: color 0.3s;}
.hd_drop .dropdown-item:hover{ background: transparent; color: #fff;}




/* ==================== 메인 서브 공통 ==================== */
.mobile_wr:has(.hd_m) .page_wr{ padding-top: var(--hd_height_m);}
/* 바텀 버튼 있을 경우 페이지 하단 여백
    바텀 버튼 높이 80px + 12px 상단 공간 확보 */
.mobile_wr:has(.bottom_btn) .page_wr{ padding-bottom: 9.2rem;}
/* 바텀 메뉴 있을 경우 페이지 하단 여백 */
.mobile_wr:has(.bt_menu) .page_wr{ padding-bottom: 8.2rem;}




/* ==================== 반응형==================== */
/*반응형 max 1200 xl*/
@media (max-width: 1199.98px) {


}

/*반응형 max 992px lg*/
@media (max-width: 991.98px) {

}


/*반응형 max 767px md*/
@media (max-width: 767.98px) {

}

/*반응형 max 576px sm*/
@media (max-width: 575.98px) {

}

/*반응형 max 375px*/
@media (max-width: 375px) {
	html { font-size:9.4px; }
}