@import url('reset.css');
@import url('slick.css');
@import url('https://cdn.jsdelivr.net/gh/moonspam/NanumSquareNeo/nanumsquareneo.css');
@import url('https://cdn.jsdelivr.net/gh/innks/NanumSquareRound@master/nanumsquareround.min.css');

:root{
    --font:"GmarketSans", sans-serif;
    --padding:20px;
    --width:1480px;
    --point-color-1:#084460;
    --point-color-2:#0c6b97;
    --header_h:100px;
}

.container{padding-top:var(--header_h);}
.cont{padding:0 var(--padding); max-width: var(--width); width:100%; margin: 0 auto; }

/* header */
.header {position:fixed; top:0; left:0; width:100%; z-index:100; height:var(--header_h); display: flex;  justify-content: space-between; align-items: center;  padding:0 2.6%; background: #fff; }
.gnb > ul { display: flex; }
.gnb > ul > li { position: relative; }
.gnb > ul > li > a {padding:10px 0;  display: block; width: 160px; color: #212121; font-family:var(--font); font-size: 1.25rem; letter-spacing: -0.01em; line-height: 1; text-align: center; }
.gnb > ul > li .s_gnb { display: none; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); padding:10px; min-width: 160px; background: #E7F5FB; box-shadow: 0 4px 12px rgba(0,0,0,0.1); border-radius: 0 0 8px 8px; padding: 12px 0; z-index: 101; }
.gnb > ul > li:hover .s_gnb { display: block; }
.gnb > ul > li .s_gnb ul { display: block; }
.gnb > ul > li .s_gnb ul li a {position:relative;  display: block; padding: 8px 20px; color: #555; font-size: 1.0625rem; font-weight: 700; letter-spacing: -0.01em; line-height: 1.4; text-align: center; white-space: nowrap; transition: color 0.2s, background 0.2s; color:#0E80B5; display:flex;  gap:5px; }
.gnb > ul > li .s_gnb ul li a:before{width:14px; aspect-ratio: 14/14; display:block; background:url(../img/bulit.svg) no-repeat center center / contain; content:""; display:block; flex-shrink: 0; opacity:0; transition: all 0.3s ease-out;}
.gnb > ul > li .s_gnb ul li a:hover:before {opacity:1;}
.header_utils { display: flex; align-items: center; gap: 20px; }
.header_utils .link_btn { display: flex; justify-content: center; align-items: center; height: 45px; padding: 12px 25px 8px; border: 1px solid #0c6b97; border-radius: 2em; }
.header_utils .link_btn span { color: #0c6b97; font-family:var(--font); font-weight: 500; font-size: 1.125rem; letter-spacing: -0.03em; line-height: 1.4; }
.header_utils .search_btn { display: flex; justify-content: center; align-items: center; width: 60px; aspect-ratio: 1/1; background: #1197d5; border-radius: 50%; }
.header_utils .menu_btn { display: flex; justify-content: center; align-items: center; width: 60px; aspect-ratio: 1/1; background: #212121; border-radius: 50%; cursor: pointer; }
.blind { position: absolute; width: 1px; height: 1px; margin: -1px; padding: 0; overflow: hidden; clip: rect(0,0,0,0); border: 0; }

/* total menu */
.total_menu { position: fixed; left: 0; top: 0; z-index: 999; width: 100%; height: 380px; background-color: #fff; box-shadow: 0 5px 10px rgba(102,102,102,0.15); box-sizing: border-box; opacity: 0; visibility: hidden; transform: translateY(-20px); transition: opacity 0.35s ease-out, transform 0.35s ease-out, visibility 0.35s ease-out; pointer-events: none; }
.total_menu.active { opacity: 1; visibility: visible; transform: translateY(0); pointer-events: auto; }
.total_menu_header { display: flex; align-items: center; gap: 64px; margin: 0 auto; padding: 0 2.6%; height: var(--header_h); box-sizing: border-box;  justify-content: space-between;}
.total_menu_header .header_logo { display: flex; align-items: center; flex-shrink: 0; }
.total_menu_nav { display: flex; align-items: center; list-style: none; gap: 50px; }
.total_menu_nav > li {width:160px; display: flex; align-items: center; justify-content: center; position: relative; }
.total_menu_nav > li > a { display: flex; align-items: center; justify-content: center; min-height: 50px; font-family: var(--font); font-size: 1.25rem; line-height: 1.15; color: #000; text-align: center; text-decoration: none; white-space: pre-line; transition: color 0.3s ease-out; }
.total_menu_nav > li > a:hover { color: #1197d5; }
.total_menu_close { flex-shrink: 0; display: flex; align-items: center; justify-content: center; width: 60px; height: 60px; padding: 0; border: none; border-radius: 50%; background: #212121; cursor: pointer; position: relative; }
.total_menu_close::before, .total_menu_close::after { content: ""; position: absolute; width: 20px; height: 2px; background: #fff; }
.total_menu_close::before { transform: rotate(45deg); }
.total_menu_close::after { transform: rotate(-45deg); }
.total_menu_nav > li .s_menu { position: absolute; left: 0; width: 100%; top: 100%; text-align: center; }
.s_menu { padding: 15px 0; }
.s_menu ul { display: flex; flex-direction: column; gap: 0; list-style: none; margin: 0; padding: 0; }
.s_menu ul li a { font-family: var(--font); font-size: 1rem; line-height: 2.12; letter-spacing: -0.02em; color: #212121; text-decoration: none; transition: all 0.3s ease-out; }
.s_menu ul li a:hover { color: #1197d5; }
.total_menu_body { padding: 0 4%; }
.total_menu_mega { display: flex; gap: 0; }
.total_menu_col { flex: 1; padding: 20px 0; }
.total_menu_col ul { list-style: none; margin: 0; padding: 0; }
.total_menu_col ul li a { display: block; font-family: var(--font); font-size: 1rem; font-weight: 500; line-height: 2; letter-spacing: -0.02em; color: #424242; text-decoration: none; transition: color 0.3s ease-out; }
.total_menu_col ul li a:hover { color: #1197d5; }

@media (max-width: 1440px) {
.gnb{display:none;}
.total_menu_nav{gap:20px;}
}
@media (max-width: 1280px) {
.total_menu { height: 100vh; overflow-y: auto; }
.total_menu_header { flex-wrap: wrap; height: auto; padding: 20px 4%; gap: 0; }
.total_menu_header .header_logo { order: 1; }
.total_menu_close { order: 2; }
.total_menu_nav { order: 3; width: 100%; flex-direction: column; gap: 0; margin-top: 20px; border-top: 1px solid #e0e0e0; }
.total_menu_nav > li { width: 100%; justify-content: flex-start; border-bottom: 1px solid #f0f0f0; }
.total_menu_nav > li > a { width: 100%; justify-content: space-between; min-height: 56px; padding: 0 16px; font-size: 1.125rem; font-weight: 700; }
.total_menu_nav > li > a::after { content: ''; display: block; width: 10px; height: 10px; border-right: 2px solid #999; border-bottom: 2px solid #999; transform: rotate(45deg); transition: transform 0.3s; flex-shrink: 0; }
.total_menu_nav > li.open > a::after { transform: rotate(-135deg); }
.total_menu_nav > li .s_menu { position: static; display: none; width: 100%; text-align: left; padding: 0; background: #f9f9f9; }
.s_menu ul li a { padding: 12px 24px; font-size: 1rem; line-height: 1.4; display: block; }
.total_menu_body { display: none; }
}

@media (max-width: 768px) {
.header_utils .link_btn{display:none;}
.header_utils{gap:10px;}
.header_utils .menu_btn{width:50px;}
.header_utils .search_btn{width:50px;}
.header .logo img{width:120px;}
.total_menu_header{padding:15px 2.6%; }
.total_menu_close{width:50px; height: auto; aspect-ratio: 1/1;}
.header_logo img{width:120px;}
.total_menu_nav > li{flex-direction: column;}

}


/* mv */
.main_visual { position: relative; width: 100%; height: 770px; overflow: hidden; }
.main_visual_bg { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.main_visual_bg img { width: 100%; height: 100%; object-fit: cover; }
.main_visual_content { position: relative; z-index: 1; display: flex; justify-content: space-between; align-items: center; max-width: 1640px; margin: 0 auto; padding:0 var(--padding); height:100%;}
.main_visual_left { display: flex; flex-direction: column; align-items: flex-start; }
.main_tag { background: #0e80b5; padding: 8px 24px 4px 16px; border-radius: 100px 100px 100px 0px; font-size: 1.25rem; color:#fff; font-family: var(--font); font-weight: 500; letter-spacing: -0.03em; line-height:1;}
.mv_title { font-size: 3.125rem; line-height: 1.4; margin-top: 16px; color:#fff; font-family: var(--font); font-weight: 400; letter-spacing: -0.03em;}
.mv_title strong { font-weight: 700; }
.main_btn_more { display: flex; align-items: center; background: #fff; color: #424242; padding: 15px 30px; border-radius: 2em; margin-top: 30px; font-weight: 600; text-decoration: none; }
.main_btn_more::after { content: ''; display: inline-block; width: 32px; height: 10px; background: url('../img/icon_arrow.svg') no-repeat center center; background-size: contain; margin-left: 8px; }
.main_visual_right { display: flex; flex-direction: column; width:900px;}
.main_card_list { display: flex; gap: 20px; }
.main_card_list.slick-initialized { display: block; gap: 0; }
.main_card_list.slick-initialized .slick-slide { margin: 0 10px; }
.main_card_list.slick-initialized .slick-list { margin: 0 -10px; }
.main_card { width: 440px; background: #fff; border-radius: 20px; padding: 24px 20px; }
.main_card_header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; }
.main_card_header h3 { font-size: 1.875rem; color: #212121; font-family: var(--font); letter-spacing: -0.03em;}
.main_card_header h3 strong { font-weight: 700; }
.main_card_header .btn_plus { display: block; width: 40px; height: 40px; background: #212121 url('../img/ic_plus.svg') no-repeat center center; border-radius: 50%; }
.main_card .img_area { width: 100%; height: 280px; border-radius: 10px; overflow: hidden; margin-bottom: 16px; }
.main_card .img_area img { width: 100%; height: 100%; object-fit: cover; }
.main_card_body { display: flex; flex-direction: column; }
.main_card_body h4 { font-size: 1.5625rem; font-weight: 600; color: #212121; text-align:center; font-weight:700;}
.main_card_body .address { position: relative; margin-top: 16px; color: #333; font-size:1.125rem; display:flex; gap:10px; align-items: center;}
.main_card_body .address::before { content: ''; display: block; width: 32px; aspect-ratio: 1/1; background: url('../img/icon_map.svg') no-repeat center center; flex-shrink: 0;}
.main_card_body .phone { position: relative; margin-top: 12px; color: #333; display:flex; gap:10px; align-items: center;}
.main_card_body .phone::before { content: ''; display: block; width: 32px; aspect-ratio: 1/1; background: url('../img/icon_tel.svg') no-repeat center center; flex-shrink: 0;}
.main_visual_controls { display: flex; align-items: center; gap: 16px; margin-top: 30px; align-self: flex-end; }
.main_progress_bar { width: 120px; height: 2px; background-color: rgba(255,255,255,0.3); }
.main_progress { width: 25%; height: 100%; background-color: #fff; }
.main_page_indicator { font-size: 1rem; }
.main_arrow_btns { display: flex; gap: 8px; }
.main_arrow_btns button { background: none; border: 1px solid rgba(255,255,255,0.5); border-radius: 50%; width: 40px; height: 40px; cursor: pointer; }
.main_arrow_btns button img { width: 10px; height: 16px; }

/* 추천코스 */
.main_recommend { position:relative;  }
.main_recommend .bg_img_area { position:absolute; top:0; left:0; width:100%; height:100%; z-index:-1; }
.main_recommend .bg_img_area img { width:100%; height:100%; object-fit:cover; }
.main_recommend_inner { display:flex; flex-direction:column; max-width:1860px; margin:0 auto; padding:140px 20px; gap:70px; }
.main_recommend .tit_wrap { display:flex; flex-direction:column; align-items:center; gap:40px; }
.main_recommend .tit_box { display:flex; flex-direction:column; align-items:center; gap:10px; }
.main_recommend .tit_main { display:flex; align-items:center; gap:10px; }
.main_recommend .tit_main span { font-family:var(--font); font-size:3.125rem; line-height:1.3; letter-spacing:-0.03em; }
.main_recommend .highlight { display:flex; align-items:center; }
.main_recommend .highlight span { font-family:var(--font); font-weight:700; font-size:2.8125rem; line-height:1.3; letter-spacing:-0.03em; color:#f58220; }
.main_recommend .sub_tit { font-family:var(--font); font-size:1.25rem; line-height:1.4; letter-spacing:-0.03em; color:#616161; }
.main_recommend .tag_wrap { display:flex; align-items:center; gap:25px; }
.main_recommend .tag_wrap .arrow_r,
.main_recommend .tag_wrap .arrow_l{width:40px;}
.main_recommend .tag_list { display:flex; gap:16px; }
.main_recommend .tag_list li a { display:block; padding:0px 18px; height:40px; line-height:40px; border-radius:2em; font-family:var(--font); font-size:1rem; letter-spacing:-0.01em; }
.main_recommend .tag_list li a.active { background:#f58220; color:#fff; font-weight:500; }
.main_recommend .tag_list li a:not(.active) { background:#ebebeb; color:#343434; }
.main_recommend .course_list { display:flex; justify-content:center; gap:25px; }
.main_recommend .course_list.slick-initialized { display:block; gap:0; }
.main_recommend .course_list.slick-initialized .slick-slide { margin:0 12px; }
.main_recommend .course_list.slick-initialized .slick-list { margin:0 -12px; }
.main_recommend .course_list li {  background:#f5f5f5; border-radius:30px; overflow:hidden; }
.main_recommend .course_list li .img_area { aspect-ratio: 400/280;}
.main_recommend .course_list li .img_area img { width:100%; height:100%; object-fit:cover; }
.main_recommend .course_list li .txt_box { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; height:110px; }
.main_recommend .course_list li strong { font-weight:700; font-size:1.5625rem; line-height:1; letter-spacing:-0.02em; color:#212121; text-align:center; }
.main_recommend .course_list li span { font-size:1.0625rem; line-height:1.3; letter-spacing:-0.02em; color:#424242; text-align:center; }
/* 지원절차 */
.main_process { position:relative; width:100%; height:915px; }
.main_process_bg { position:absolute; top:0; left:0; width:100%; height:100%; }
.main_process_bg img { width:100%; height:100%; object-fit:cover; }
.main_process_inner { display:flex; flex-direction:column; justify-content:center; align-items:center; width:100%; height:100%; max-width:var(--width); margin:0 auto; padding:140px 20px; gap:70px; position:relative; }
.main_process_tit { display:flex; flex-direction:column; align-items:center; gap:10px; }
.main_process_tit h2 { display:flex; gap:10px; font-family:var(--font); font-size:2.8125rem; line-height:1.3; letter-spacing:-0.03em; }
.main_process_tit h2 span { color:#1d1d1d; }
.main_process_tit h2 .point { font-weight:700; color:#1197d5; }
.main_process_tit p { font-family:var(--font); font-size:1.25rem; line-height:1.4; letter-spacing:-0.03em; color:#616161; }
.main_process_list { display:flex; justify-content:center; gap:40px; }
.main_process_list li { display:flex; flex-direction:column; align-items:center; }
.main_process_list li .img_area {  border-radius:31px; overflow:hidden; }
.main_process_list li .img_area img { width:100%; height:100%; object-fit:cover; }
.main_process_list li .txt_box { display:flex; flex-direction:column; align-items:center; margin-top:-25px; position:relative; gap:15px; }
.main_process_list li .txt_box .num { display:flex; justify-content:center; align-items:center;  background:#009dff; border-radius:50%; width:50px; aspect-ratio: 1/1; font-family:var(--font); font-weight:500; font-size:1.25rem; line-height:1.4; letter-spacing:-0.03em; color:#fff; }
.main_process_list li .txt_box .txt { font-weight:600; font-size:1.25rem; line-height:1.4; letter-spacing:-0.03em; color:#343434; text-align:center; }
.main_process_list li .txt_box .txt .point { color:#1197d5;  vertical-align: top;}
.main_process_link { display: flex; align-items: center; justify-content: center; background: #084460; color: #424242; padding: 15px 30px; border-radius: 2em; font-weight: 600; text-decoration: none; gap:10px; color:#fff; font-size:1.0625rem; }
.main_process_link:after{width:32px; aspect-ratio: 34/24; display:block; background:url(../img/icon_arrow_w.svg) no-repeat center center / contain; display:block; content:"";}
/* 커뮤니티+배너 */
.main_commu { padding: 8.75rem 0; }
.main_commu .main_inner { display: flex; max-width: 113.75rem; margin: 0 auto; padding: 0 2.5rem; gap: 3.125rem; }
.main_commu .main_community_wrap { flex: 1; }
.main_commu .main_banner_wrap { flex: 1; }
.main_commu .main_title_area { display: flex; align-items: baseline; justify-content: space-between;  padding-bottom: 20px;  flex-wrap:wrap;}
.main_commu .main_title_area.border{border-bottom: 1px solid #9e9e9e;}
.main_commu .main_title { font-family: var(--font); font-size:2.8125rem; font-weight: 400; letter-spacing: -0.03em; line-height: 60px; }
.main_commu .main_title strong { font-weight: 700; color: #1197d5; }
.main_commu .main_tabs {position:relative; width:100%; display: flex; gap: 0.9375rem; }
.main_commu .main_tabs:before{position:absolute; bottom:0; left:0; width:100%; height:1px; background:#9e9e9e; display:block; content:"";}
.main_commu .main_tabs li a {position:relative; display:block; line-height:2; font-family: var(--font); font-weight: 700; font-size: 1.875rem; letter-spacing: -0.03em; }
.main_commu .main_tabs li a:before{position:absolute; left:0; bottom:0; width:0; height:4px; background-color:#084460; display:block; content:"";  transition: all 0.3s ease-out;}
.main_commu .main_tabs li.active a {font-weight:700; color: #084460; }
.main_commu .main_tabs li.active a:before{width:100%;}
.main_commu .main_subtitle { font-size: 1.25rem; color: #616161; letter-spacing: -0.03em; margin-top: 1.5625rem; }
.main_commu .main_post_list{display:flex; flex-wrap:wrap; gap:1.9375rem; margin-top:4.375rem;}
.main_commu .main_post_list li{width:calc(50% - 1rem);}
.main_commu .main_post_list li a{display:flex; flex-direction:column; background:#fff; border-radius:1.25rem; padding:1.875rem; height:100%; border:1px solid #ddd; transition: all 0.3s ease-out;}
.main_commu .main_post_list li a:hover{border-color:#1197D5;}
.main_commu .main_post_list li .tag{font-size:0.9375rem; font-weight:600; color:#1197d5; border:1px solid #1197d5; border-radius:2em; padding:0.3125rem 0.9375rem; width:fit-content;}
.main_commu .main_post_list li strong{font-size:1.25rem; font-weight:600; color:#212121; margin-top:0.625rem; flex-grow:1;
text-overflow:ellipsis;
white-space:nowrap;
word-wrap:normal;
overflow:hidden;
}
.main_commu .main_post_list li .date{font-size:1rem; color:#757575; letter-spacing:-0.02em; margin-top:1.375rem; text-decoration: underline;}
.main_commu .main_banner_list{margin-top:4.375rem; display:flex; gap:32px;}
.main_commu .main_banner_list li{flex:1;}
.main_commu .main_banner_list li.bg_1{background:url(../img/main_bg_1.jpg) no-repeat center center / cover;}
.main_commu .main_banner_list li.bg_2{background:url(../img/main_bg_2.jpg) no-repeat center center / cover;}
.main_commu .main_banner_list li a{position:relative; padding:60px 40px; aspect-ratio: 426/392; display:flex; flex-direction: column; justify-content: space-between;  border-radius:1.25rem; overflow:hidden; box-sizing:border-box;}
.main_commu .main_banner_list li strong{display:block; font-size:1.875rem; font-weight:500; color:#212121; letter-spacing:-0.03em; font-family:var(--font); font-weight:700; color:#fff;}
.main_commu .main_banner_list li p{font-size:1rem; color:#fff; letter-spacing:-0.03em; margin-top:0.625rem; font-family: var(--font);}
.main_commu .main_banner_list li span{display:inline-block; background:#f5f5f5; color:#212121; font-size:1rem; font-weight:500; padding:0.75rem 2.1875rem; border-radius:2em; margin-top:1.25rem;}

/* footer */
.footer { display: flex; flex-direction: column; gap: 10px;  margin: 0 auto; padding: 50px 0; background-color: #f5f5f5; }
.footer_top {margin-bottom:40px;  display: flex; justify-content: space-between; align-items: center; }
.logo_area { display: flex; flex-direction: column; }
.logo_text { color: #424242; font-size: 1.375rem; line-height: 1.4; letter-spacing: -0.03em; }
.logo_text strong { font-weight: 500; }
.logo_main { display: flex; align-items: center; gap: 16px; }
.logo_symbol { display: flex; align-items: center; }
.symbol_text_1 { color: #f58220; font-family:var(--font); font-weight: 500; font-size: 1.625rem; line-height: 1.2; }
.symbol_graphic { position: relative; width: 52px; height: 60px; background-color: #1d9741; }
.symbol_text_2 { position: absolute; left: 6px; top: 15px; font-family: "NanumSquareRound"; font-weight: 800; font-size: 1.375rem; line-height: 1.4; letter-spacing: -0.03em; }
.symbol_text_3 { color: #212121; font-family:var(--font); font-weight: 500; font-size: 1.625rem; line-height: 1.2; }
.logo_symbol .img_area { width: 23px; height: 19px; }
.logo_title { font-family:var(--font); font-size: 2.5rem; line-height: 1.4; letter-spacing: -0.03em; }
.logo_title strong { color: #f58220; font-weight: 500; }
.arrow_icon { width: 44px; height: 12px; background-color: #212121; }
.social_list { display: flex; }
.social_list li a { display: flex; justify-content: center; align-items: center; width: 55px; height: 55px; border-radius: 50%; }

.footer_nav_banner { display: flex; justify-content: space-between; align-items: center; padding: 0 40px; background-color: #084460; border-radius: 2em; height: 60px; }
.banner_menu { display: flex; align-items: center; gap: 16px; }
.banner_menu li a { font-size: 1rem; line-height: 1; letter-spacing: -0.01em; font-family: var(--font); font-weight: 400; color:#fff;}
.banner_menu li:not(:last-child)::after { content: ''; display: inline-block; width: 4px; height: 4px; margin-left: 16px; background-color: rgba(255,255,255,0.2); border-radius: 50%; vertical-align: middle; }
.family_site { display: flex; align-items: center; gap: 40px; }
.family_site::before { content: ''; width: 2px; height: 24px; background-color: #7f85a2; }
.family_site a { display: flex; align-items: center; gap: 61px; font-size: 1rem; line-height: 1; letter-spacing: -0.01em; font-family: var(--font); font-weight: 400; color:#fff; }
.arrow_down { width: 11px; height: 7px; background-color: #fff; clip-path: polygon(0 0, 100% 0, 50% 100%); }
.footer_bottom { display: flex; flex-direction: column; gap: 25px; padding: 40px 40px 0; }
.footer_policy ul { display: flex; gap: 16px; }
.footer_policy ul li a strong { color: #212121; font-size: 0.9375rem; line-height: 1; font-weight: 700; font-family:var(--font);}
.footer_info { display: flex; flex-direction: column; gap: 10px; font-style: normal; color: #616161; font-size: 0.9375rem; line-height: 1.2; letter-spacing: -0.01em; }
.operating_hours { font-weight: 600; }
.notice { color: #0c6b97; font-weight: 600; }
.copyright { color: #616161; font-size: 0.9375rem; line-height: 1.2; letter-spacing: -0.01em; }
/* quick */
.quick_menu { position:fixed; top:50%; right:20px; transform:translateY(-50%); z-index:100; width:80px;}
.quick_menu ul { display:flex; flex-direction:column; gap:10px; }
.quick_menu li a { display:flex; flex-direction:column; justify-content:center; align-items:center; background:#fff;  border-radius:8px; gap:8px; padding:8px 0;  border: 1px solid #E0E0E0;}
.quick_menu li:last-of-type a { background: linear-gradient(to bottom, rgba(12, 107, 151, 1), rgba(8, 68, 96, 1)); border:none;}
.quick_menu li a img {  object-fit:contain; }
.quick_menu li a span { font-weight:600; font-size:0.875rem; line-height:1.4; letter-spacing:-0.04em; color:#212121; }
.quick_menu li:last-of-type a span { color:#fff; }

/* sub page common */
.sub_wrap{padding-top:var(--header_h);}
.sub_visual{position:relative; width:100%; height:320px; overflow:hidden; background:url(../img/sub_visual.jpg) no-repeat center center / cover;}
.sub_visual_inner{position:relative; display:flex; justify-content:center; align-items:center; height:100%; max-width:var(--width); margin:0 auto; padding:0 var(--padding);}
.sub_visual .txt{text-align:center; color:#fff;}
.sub_visual .txt h2{font-family:var(--font); font-size:3.125rem; font-weight:700; line-height:1.3; letter-spacing:-0.03em;}
.sub_visual .txt .en{display:block; font-family:var(--font); font-size:1.25rem; font-weight:400; line-height:1.4; letter-spacing:-0.01em; margin-top:10px; opacity:0.7;}
.navi{border-bottom:1px solid #e0e0e0; background:#fff;}
.navi>ul{display:flex;  max-width:var(--width); margin:0 auto; }
.navi>ul>li{position:relative; width:250px; display:flex; align-items:center; gap:10px; border-right:1px solid #E0E0E0;}
.navi>ul>li:first-child{border-right:none;}
.navi>ul>li .navi_btn{position:Relative; padding:0 45px 0 20px; width:100%; height:60px; font-size:1.0625rem; font-weight:600; color:#212121; letter-spacing:-0.02em;  display:flex; align-items: center;}
.navi>ul>li .navi_btn:after{position:absolute; right:15px; top:50%; width:30px; aspect-ratio: 1/1; background:url(../img/navi_arrow.svg) no-repeat center center; display:block; content:""; transform: translateY(-50%);}
.navi>ul>li.home{width:60px;  display:flex; justify-content:center; align-items:center; background:linear-gradient(135deg, #1d9741, #084460); }
.navi>ul>li.home a{display:flex; justify-content:center; align-items:center; width:100%; height:100%;}
.navi>ul>li.home a img{width:24px; height:24px;}
.navi .s_navi{position:absolute; left:0; top:60px; z-index:10; width:100%; padding:15px 20px; background-color:#084460; border-radius:0 0 10px 10px; display:none;}
.navi .s_navi ul li{padding:5px 0; }
.navi .s_navi ul li a{color:#fff; font-size:1rem; }
.sub_cont{max-width:var(--width); margin:0 auto; padding:80px var(--padding) 140px;}
.page_title{margin-bottom:60px;}
.page_title h3{font-family:var(--font); font-size:2.5rem; font-weight:700; line-height:0.7; letter-spacing:-0.03em; color:#212121; display:flex; align-items: flex-end; gap:10px;}
.page_title h3::after{content:""; display:block; width:8px; aspect-ratio: 1/1; border-radius:50%; background:var(--point-color-1); }
.con_body{margin-top:60px;}



@media (max-width: 1300px) {
:root {
    --width: 100%;
    --padding: 16px;
}
@media (max-width: 768px) {
    :root {
        --header_h:70px;
    }
}
.main_visual_content { max-width: 100%; padding: 0 30px; }
.main_card { width: 360px; }
.main_card .img_area { width: 100%; height: auto; aspect-ratio: 400/280; }
.main_recommend_inner { padding: 100px 20px; gap: 50px; }
.main_commu .main_inner { gap: 2rem; padding: 0 1.5rem; }
.main_commu .main_banner_list { gap: 20px; }
}

@media (max-width: 1440px) {


}

/* 1024px: MV vertical stack (text top, cards bottom), reduce font sizes */
@media (max-width: 1200px) {
.main_visual { height: auto; }
.main_visual_content { flex-direction: column; justify-content: center; gap: 40px; padding: 60px 30px; }
.main_visual_left { align-items: center; text-align: center; }
.mv_title { font-size: 2.5rem; }
.main_card_list { justify-content: center; }
.main_card { width: 340px; }
.main_card .img_area { height: auto; aspect-ratio: 400/250; }
.main_card_header h3 { font-size: 1.5rem; }
.main_card_body h4 { font-size: 1.25rem; }
.main_recommend .tit_main span { font-size: 2.5rem; }
.main_recommend .highlight span { font-size: 2.25rem; }
.main_recommend_inner { padding: 80px 20px; gap: 40px; }
.main_process { height: auto; }
.main_process_inner { padding: 80px 20px; gap: 50px; }
.main_process_tit h2 { font-size: 2.25rem; }
.main_commu { padding: 5rem 0; }
.main_commu .main_title { font-size: 2.25rem; line-height: 1.3; }
.main_commu .main_tabs li a { font-size: 1.5rem; }
.main_visual_right{width:100%;}

.main_card_list { gap: 16px; }
.main_card { width: 300px; }
.main_process_list { flex-wrap: wrap; gap: 30px; justify-content: center; }
.main_process_list li { width: calc(33.33% - 20px); }
.main_process_list li .img_area img { width: 100%; }
.main_commu .main_post_list li { width: 100%; }
.main_commu .main_banner_list { flex-direction: column; }
.main_commu .main_banner_list li a {padding: 40px 30px; }
}

@media (max-width: 960px) {
.footer_top{flex-direction: column;}
.footer_nav_banner{height:auto; padding:20px; flex-direction: column; gap:10px;}
.family_site::before{display:none;}
.footer_bottom{text-align:center;}

.footer_top{margin-bottom:10px;}
.banner_menu li a{font-size:12px;}
.footer_nav_banner{padding:15px 10px;}
.banner_menu li:not(:last-child)::after{display:none;}
.banner_menu{flex-wrap:wrap; justify-content: center; gap:6px;}
.footer_bottom{padding:20px 0 0;}
}

/* 768px: Full mobile layout */
@media (max-width: 768px) {
:root {
    --padding: 12px;
}
/* MV */
.main_visual { min-height: auto; }
.main_visual_content { padding: 40px 16px; gap: 30px; }
.mv_title { font-size: 1.75rem; margin-top: 12px; }
.main_tag { font-size: 1rem; padding: 6px 16px 3px 12px; }
.main_btn_more { margin-top: 20px; padding: 12px 24px; font-size: 0.9375rem; }
.main_card_list.slick-initialized .slick-slide { margin: 0 8px; }
.main_card_list.slick-initialized .slick-list { margin: 0 -8px; }
.main_card { width: 100%; max-width: 100%; padding: 20px 16px; }
.main_card .img_area { aspect-ratio: 400/240; height: auto; }
.main_card_header h3 { font-size: 1.375rem; }
.main_card_body h4 { font-size: 1.125rem; }
.main_card_body .address,
.main_card_body .phone { font-size: 0.9375rem; }
.main_visual_controls { margin-top: 20px; }

/* Recommend course: CSS-only horizontal scroll with snap */
.main_recommend .tit_main { flex-direction: column; gap: 4px; }
.main_recommend .tit_main span { font-size: 2rem; }
.main_recommend .highlight span { font-size: 1.75rem; }
.main_recommend .sub_tit { font-size: 1rem; }
.main_recommend .tag_list { gap: 8px; flex-wrap: wrap; justify-content: center; }
.main_recommend .tag_list li a { font-size: 0.875rem; padding: 0 14px; height: 36px; line-height: 36px; }
.main_recommend_inner { padding: 60px 16px; gap: 30px; }
.main_recommend .course_list.slick-initialized .slick-slide { margin: 0 8px; }
.main_recommend .course_list.slick-initialized .slick-list { margin: 0 -8px; }
.main_recommend .course_list li .txt_box { height: 90px; gap: 8px; }
.main_recommend .course_list li strong { font-size: 1.25rem; }
.main_recommend .course_list li span { font-size: 0.9375rem; }

/* Process */
.main_process_inner { padding: 60px 16px; gap: 30px; }
.main_process_tit h2 { font-size: 1.75rem; flex-wrap: wrap; justify-content: center; }
.main_process_tit p { font-size: 1rem; }
.main_process_list { gap: 20px; }
.main_process_list li { width: calc(50% - 10px); }
.main_process_list li .img_area { border-radius: 20px; }
.main_process_list li .img_area img { width: 100%; height: auto; }
.main_process_list li .txt_box .num { width: 40px; font-size: 1rem; }
.main_process_list li .txt_box .txt { font-size: 1rem; }
.main_process_link { font-size: 0.9375rem; padding: 12px 24px; }

/* Community + Banner: 1-column */
.main_commu { padding: 3rem 0; }
.main_commu .main_inner { flex-direction: column; padding: 0 16px; gap: 3rem; }
.main_commu .main_title { font-size: 1.75rem; line-height: 1.3; }
.main_commu .main_tabs li a { font-size: 1.25rem; }
.main_commu .main_subtitle { font-size: 1rem; margin-top: 1rem; }
.main_commu .main_post_list { gap: 1rem; margin-top: 2rem; }
.main_commu .main_post_list li a { padding: 1.25rem; }
.main_commu .main_banner_list { margin-top: 2rem; gap: 16px; }
.main_commu .main_banner_list li a { padding: 30px 20px; }
.main_commu .main_banner_list li strong { font-size: 1.5rem; }
.main_commu .main_banner_list li p { font-size: 0.875rem; }

/* Quick menu: bottom fixed horizontal bar */
.quick_menu {
position: fixed;
top: auto;
bottom: 0;
left: 0;
right: 0;
transform: none;
width: 100%;
z-index: 100;
background: #fff;
box-shadow: 0 -2px 10px rgba(0,0,0,0.1);
border-radius: 0;
}
.quick_menu ul {
flex-direction: row;
justify-content: space-around;
gap: 0;
padding: 8px 0;
}
.quick_menu li { flex: 1; }
.quick_menu li a {
border: none;
border-radius: 0;
padding: 4px 0;
gap: 4px;
}
.quick_menu li a img { width: 28px; height: 28px; }
.quick_menu li a span { font-size: 0.75rem; }
.quick_menu li:last-of-type a { background: transparent; }
.quick_menu li:last-of-type a span { color: #212121; }

/* Sub page adjustments */
.sub_visual { height: 200px; }
.sub_visual .txt h2 { font-size: 2rem; }
.sub_visual .txt .en { font-size: 1rem; }
.sub_cont { padding: 40px var(--padding); }
.page_title h3 { font-size: 1.75rem; }
.con_body { margin-top: 30px; }
.navi>ul>li.home{width:40px; height:40px;}
.navi>ul>li{width: calc((100% - 40px) / 2); }
.navi>ul>li .navi_btn{padding:0 20px 0 10px; height:40px; font-size:12px;}
.navi>ul>li .navi_btn:after{right:10px; width:20px; }
}

/* listType_1 */
.listType_1{display:flex; flex-direction:column; gap:70px;}
.listType_1>ul{display:flex; flex-direction:column; gap:50px;}
.listType_1>ul>li{display:flex; align-items:flex-start; gap:24px;}
.listType_1>ul>li .item_title{width:318px; display:flex; align-items:center; gap:12px; flex-shrink:0; }
.listType_1>ul>li .num{font-family:'NanumSquareNeo', sans-serif; font-size:1.5625rem; color:#3caadd; font-weight:900; line-height:1;}
.listType_1>ul>li .txt{font-family:var(--font); font-size:1.5625rem; font-weight:500; color:#212121; line-height:1.12; letter-spacing:-0.02em; font-weight:700;}
.listType_1>ul>li .item_desc{flex:1;}
.listType_1>ul>li .item_desc p{font-family:var(--font); font-size:1.25rem; color:#424242; line-height:1.5; letter-spacing:-0.02em;}

/* titleType_1 */
.titleType_1{display:flex; flex-direction:column; gap:10px; align-items:center;}
.titleType_1 h4{display:inline-flex; align-items:center; gap:12px; padding:5px 40px; background-color:#0c6b97; color:#fff; font-family:var(--font); font-size:1.875rem; font-weight:500; border-radius:2em; line-height:1.33; letter-spacing:-0.03em;}

@media screen and (max-width: 960px){
.listType_1{gap:35px;}
.listType_1>ul{gap:25px;}
.listType_1>ul>li{flex-direction:column; gap:10px;}
.listType_1>ul>li .num{font-size:18px;}
.listType_1>ul>li .txt{font-size:18px;}
.listType_1>ul>li .item_desc p{font-size:16px;}
.titleType_1 h4{font-size:20px; padding:4px 24px;}
}

/* tabType_1 */
.tabType_1{display:flex; justify-content:center;}
.tabType_1>ul{display:flex; background:#f5f5f5; border-radius:10px; padding:10px;}
.tabType_1>ul>li>a{display:flex; justify-content:center; align-items:center; width:200px; height:60px; font-size:1.125rem; font-weight:600; color:#212121; border-radius:8px; transition:all 0.3s ease-out;}
.tabType_1>ul>li.active>a{background:#084460; color:#fff;}

@media screen and (max-width: 768px){
.tabType_1>ul{width:100%;}
.tabType_1>ul>li{flex:1;}
.tabType_1>ul>li>a{width:100%; height:50px; font-size:16px;}
}

/* infoType_1 */
.infoType_1{margin-top:60px;}
.infoType_1>ul{display:flex; flex-direction:column; gap:50px;}
.infoType_1>ul>li{display:flex; gap:24px;}
.infoType_1>ul>li>.tit{position:relative; flex-shrink:0; width:318px; font-family:var(--font); font-size:1.5625rem; font-weight:700; color:#212121; line-height:1.12; letter-spacing:-0.02em; padding-left:16px;}
.infoType_1>ul>li>.tit::before{position:absolute; left:0; top:2px; width:4px; height:25px; background:#1197d5; display:block; content:"";}
.infoType_1>ul>li>.desc{flex:1; display:flex; flex-direction:column; gap:20px;}
.infoType_1>ul>li>.desc p{font-family:var(--font); font-size:1.25rem; color:#424242; line-height:1.5; letter-spacing:-0.02em;}
.infoType_1>ul>li>.desc .notice{font-size:1.125rem; font-weight:500; color:#0a5679; letter-spacing:-0.02em;}
.infoType_1>ul>li>.desc .sub_desc{display:flex; flex-direction:column; gap:4px;}
.infoType_1>ul>li>.desc .sub_desc p{font-size:1.125rem; font-weight:500; color:#424242; line-height:1.9; letter-spacing:-0.02em;}

@media screen and (max-width: 768px){
.infoType_1{margin-top:30px;}
.infoType_1>ul{gap:30px;}
.infoType_1>ul>li{flex-direction:column; gap:10px;}
.infoType_1>ul>li>.tit{width:100%; font-size:20px;}
.infoType_1>ul>li>.desc>p{font-size:16px;}
.infoType_1>ul>li>.desc .notice{font-size:15px;}
.infoType_1>ul>li>.desc .sub_desc p{font-size:15px;}
}

/* listType_2 */
.listType_2{display:flex; flex-direction:column; gap:20px;}
.listType_2>ul{display:flex; flex-direction:column; gap:20px;}
.listType_2>ul>li{display:flex; align-items:center; gap:10px;}
.listType_2>ul>li .num{display:flex; justify-content:center; align-items:center; width:30px; height:30px; background:#3caadd; border-radius:50%; font-family:var(--font); font-size:1.125rem; font-weight:500; color:#fff; flex-shrink:0; line-height:1;}
.listType_2>ul>li .txt{font-family:var(--font); font-size:1.25rem; color:#424242; line-height:1.5; letter-spacing:-0.02em;}

@media screen and (max-width: 768px){
.listType_2>ul{gap:12px;}
.listType_2>ul>li .num{width:24px; height:24px; font-size:14px;}
.listType_2>ul>li .txt{font-size:16px;}
}

/* apply_form */
.apply_form{display:flex; flex-direction:column; gap:70px;}
.apply_section{display:flex; flex-direction:column; gap:20px;}
.apply_section.has_border{padding-top:40px; border-top:1px solid #e0e0e0;}
.apply_step ul{display:flex; list-style:none; margin:0; padding:0;}
.apply_step ul li{flex:1; display:flex; align-items:center; gap:10px; height:65px; border-bottom:1px solid #bdbdbd;}
.apply_step ul li .num{display:flex; align-items:center; justify-content:center; width:35px; height:35px; border-radius:50%; background-color:#e0e0e0; font-family:var(--font); font-size:1.125rem; font-weight:500; color:#424242;}
.apply_step ul li.is-active .num{background-color:#1197d5; color:#fff;}
.apply_step ul li.is-active{border-bottom-color:#1197d5;}
.apply_step ul li .txt{font-size:1.25rem; font-weight:500; color:#212121;}
.apply_field_top{display:flex; align-items:flex-end; justify-content:space-between; padding-bottom:15px; border-bottom:2px solid #000;}
.apply_field_top.no_border{border-bottom:none;}
.apply_field_top .field_tit{font-size:1.5625rem; font-weight:700; color:#424242;}
.apply_field_top .field_required{font-size:1rem; font-weight:500; color:#424242;}
.apply_field_top .field_required .star{color:#1197d5;}
.apply_field_info{font-size:1rem; font-weight:500; color:#004e6c; line-height:1.6;}
.apply_field_list{display:flex; flex-direction:column; gap:0;}
.apply_field_row{padding:10px 0; display:flex; align-items:flex-start;}
.apply_field_row .field_label{display:flex; align-items:center; gap:3px; width:342px; min-height:50px; padding:0 50px 0 0; font-size:1.0625rem; font-weight:600; color:#000; box-sizing:border-box; flex-shrink:0;}
.apply_field_row .field_label input[type=text]{width:100%; height:50px; line-height:50px; border-radius:5px;}
.apply_field_row .field_label .star{color:#1197d5;}
.apply_field_row .field_input{flex:1; display:flex; flex-direction:column; gap:8px;}
.apply_field_row .field_input input[type="text"]{height:50px; padding:0 12px; border:1px solid #e0e0e0; border-radius:5px; font-size:1rem; color:#212121;}
.apply_field_row .field_input input[type="text"]::placeholder{color:#9e9e9e;}
.apply_field_row .field_input input[type="text"]:disabled,
.apply_field_row .field_input input[type="text"]:read-only{color:#616161; background-color:#F5F5F5;}
.apply_field_row .field_input textarea{width:100%; height:130px; padding:12px; border:1px solid #e0e0e0; border-radius:5px; font-size:1rem; color:#212121; resize:none; box-sizing:border-box;}
.apply_field_row .field_input textarea::placeholder{color:#9e9e9e;}
.input_group{display:flex; align-items:center; gap:10px; flex-wrap:wrap;}
.input_group .max600{max-width:600px; width:100%;}
.input_date{display:flex; align-items:center; gap:10px;}
.input_date .divider{font-size:1rem; color:#424242;}
.input_date .date_wrap{position:relative; }
.date_wrap .btn_calendar{position:absolute; right:10px; top:50%; transform:translateY(-50%); width:20px; height:20px; padding:0; border:none; background:none; cursor:pointer;}
.date_wrap .btn_calendar img{width:100%; height:100%; object-fit:contain;}
.input_file_list{width: 100%;}
.input_file{display:flex; align-items:center; gap:10px; }
.input_file input[type="file"]{position:absolute; width:1px; height:1px; margin:-1px; padding:0; overflow:hidden; clip:rect(0,0,0,0); border:0;}
.input_file .file_name{max-width:350px; width:100%; height:50px; line-height:50px; padding:0 12px; border:1px solid #e0e0e0; border-radius:5px; font-size:1rem; font-weight:500; color:#9e9e9e; box-sizing:border-box; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;}
.input_file_list ul{display:flex; flex-direction: column; gap:5px; }
.input_file_list ul li{width:100%; display:flex; gap:10px; }
.input_file_list .input_file{max-width:450px; width:calc(100% - 60px); }
.input_file_list .control{display:flex; gap:5px; }
.input_file_list .control .btn_plus{width:20px; aspect-ratio: 1/1; background:url(../img/ic_plus.svg) no-repeat center center / 100%;}
.input_file_list .control .btn_minus{width:20px; aspect-ratio: 1/1; background:url(../img/ic_minus.svg) no-repeat center center / 100%;}
.btn_verify{display:flex; align-items:center; justify-content:center; height:50px; padding:0 20px; border-radius:5px; background-color:#424242; font-size:1.125rem; font-weight:700; color:#fff; text-decoration:none; white-space:nowrap; transition:all 0.3s ease-out;}
.btn_verify:hover{background-color:#333;}
.btn_file{display:flex; align-items:center; justify-content:center; height:50px; padding:0 20px; border-radius:5px; background-color:#424242; font-size:1.125rem; font-weight:600; color:#fff; cursor:pointer; transition:all 0.3s ease-out; white-space: nowrap;}
.btn_file:hover{background-color:#333;}
.radio_label{display:inline-flex; align-items:center; gap:5px; font-size:1rem; font-weight:500; color:#424242; cursor:pointer;}
.radio_label input[type="radio"]{width:18px; height:18px; accent-color:#1197d5;}
.field_count{display:flex; align-items:center; }
.field_count .count{font-size:1rem; font-weight:500; color:#424242;}
.field_count .txt_count{margin-left:auto; }
.unit{font-size:1rem; font-weight:500; color:#424242;}
.apply_notice_section{display:flex; flex-direction:column; gap:30px;}
.apply_notice_title{font-size:1.5625rem; font-weight:700; color:#000;}
.apply_notice_box{padding:30px 40px; border-radius:10px; background-color:#f5f5f5;}
.apply_notice_box .notice_txt{font-size:1rem; font-weight:500; color:#666; line-height:1.8;}
.apply_notice_section .notice_highlight{display:block; padding:40px 0; border-bottom:1px solid #bdbdbd; font-size:1.25rem; font-weight:700; color:#000; text-align:center;}
.apply_notice_section .notice_highlight strong{font-weight:inherit; color:var(--point-color-2); }
.apply_agree_check{display:flex; flex-direction:column; gap:15px; padding:20px 0; align-items:center;}
.apply_agree_check .agree_tit{font-size:1.125rem; font-weight:600; color:#000;}
.apply_agree_check .agree_radio{display:flex; gap:40px; justify-content:center;}
.apply_form_btn{display:flex; gap:20px; justify-content:center;}
.apply_form_btn a{display:flex; align-items:center; justify-content:center; width:350px; height:60px; border-radius:10px; font-size:1.125rem; font-weight:700; text-decoration:none; transition:all 0.3s ease-out;}
.apply_form_btn .btn_prev{background-color:#e0e0e0; color:#212121;}
.apply_form_btn .btn_prev:hover{background-color:#ccc;}
.apply_form_btn .btn_next{background-color:#1197d5; color:#fff;}
.apply_form_btn .btn_next:hover{background-color:#084460;}

@media screen and (max-width: 768px){
.apply_step ul li{height:auto; justify-content:flex-start; gap:10px; padding:0 15px; flex-direction:column;}
.apply_step ul li .txt{text-align:center;}
.apply_field_top{flex-direction:column; align-items:flex-start; gap:10px;}
.apply_field_top .field_tit{font-size:20px;}
.apply_notice_box{padding:20px;}
.apply_notice_title{font-size:20px;}
.apply_form_btn{flex-direction:column;}
.apply_form_btn a{width:100%;}
.apply_agree_check .agree_radio{flex-direction:column; gap:10px;}
.btn_file{padding:0 10px; font-size:14px;}
}

@media screen and (max-width: 960px){
.apply_field_row{flex-direction:column;}
.apply_field_row .field_label{width:100%; min-height:auto; padding:10px 0;}
.apply_field_row .field_input{padding:5px 0; width:100%;}
.apply_field_row .field_input input[type="text"]{box-sizing:border-box;}
.input_group input[type="text"]{flex:1; min-width:0;}
.input_group .btn_verify{flex-shrink:0;}
.input_date .date_wrap{flex:1;}
.input_date .date_wrap input{width:100%; box-sizing:border-box;}
.input_file_list ul li{flex-wrap:wrap;}
}

/* apply_member */
.apply_member_agree{display:flex; align-items:center; gap:8px; font-size:1.125rem; font-weight:600; color:#424242; line-height:1.5; cursor:pointer;}
.apply_member_agree strong{color:#084460;}
.apply_member_agree input[type="checkbox"]{position:absolute; width:1px; height:1px; margin:-1px; padding:0; overflow:hidden; clip:rect(0,0,0,0); border:0;}
.apply_member_agree .ico_check{display:inline-block; width:24px; height:24px; border-radius:50%; background-color:#bdbdbd; background-image:url(../img/ic_mark.svg); background-repeat:no-repeat; background-position:center center; background-size:12px; flex-shrink:0;}
.apply_member_agree input[type="checkbox"]:checked + .ico_check{background-color:#1197d5;}
.apply_member_wrap{display:flex; flex-direction:column; gap:0;}
.apply_member_entry{display:flex; flex-direction:column; gap:20px;}
.apply_member_row{display:flex; gap:20px; align-items:flex-start;}
.apply_member_row .apply_member_table{flex:1;}
.apply_member_check{display:flex; align-items:center; cursor:pointer;}
.apply_member_check input[type="checkbox"]{position:absolute; width:1px; height:1px; margin:-1px; padding:0; overflow:hidden; clip:rect(0,0,0,0); border:0;}
.apply_member_check .ico_check{display:inline-block; width:24px; height:24px; border-radius:50%; background-color:#bdbdbd; background-image:url(../img/ic_mark.svg); background-repeat:no-repeat; background-position:center center; background-size:12px; flex-shrink:0;}
.apply_member_check input[type="checkbox"]:checked + .ico_check{background-color:#1197d5;}
.apply_member_table{margin-bottom:20px; width:100%; border-collapse:collapse; border-top:1px solid #616161;}
.apply_member_table th{width:220px;background-color:#f5f5f5; padding:0 24px; height:80px; text-align:left; font-size:1.0625rem; font-weight:600; color:#424242; white-space:nowrap; border-bottom:1px solid #e0e0e0;}
.apply_member_table th .star{color:#1197d5;}
.apply_member_table td{padding:16px; background-color:#fff; border-bottom:1px solid #e0e0e0;}
.apply_member_table td input[type="text"]{width:100%; height:50px; padding:0 12px; border:1px solid #e0e0e0; border-radius:5px; font-size:1rem; color:#212121; background-color:#f5f5f5; box-sizing:border-box;}
.apply_member_table td input[type="text"].max468{max-width: 468px;}
.apply_member_table td input[type="text"]::placeholder{color:#9e9e9e;}
.apply_member_radio{display:flex; align-items:center; gap:20px;}
.apply_member_info{font-size:1rem; font-weight:500; color:#004e6c; line-height:1.8;}
.apply_member_btn{display:flex; gap:15px; margin-top:15px; justify-content:center;}
.apply_member_btn button{display:flex; align-items:center; justify-content:center; width:350px; height:60px; padding:0 20px; border:none; border-radius:10px; background-color:#e0e0e0; font-size:1rem; font-weight:600; color:#212121; cursor:pointer; transition:all 0.3s ease-out;}
.apply_member_btn button:hover{border-color:#084460; color:#084460;}
.apply_member_btn .btn_add{background-color:#7cc8e8;}
.apply_member_count{font-size:1.25rem; font-weight:700; color:#000; margin-top:10px; text-align:center;}
.apply_member_count strong{color:#1197d5;}

@media screen and (max-width: 960px){
.apply_member_table th{width:80px; padding:0 15px; height:60px; font-size:15px;}
.apply_member_table td{padding:10px;}
.apply_member_table td input[type="text"]{height:45px;}
.apply_member_btn button{width:100%;}
}

@media screen and (max-width: 640px){
.apply_member_row{flex-direction:column; gap:10px;}
.apply_member_table,.apply_member_table tbody,.apply_member_table tr,.apply_member_table th,.apply_member_table td{display:block; width:100%; box-sizing:border-box;}
.apply_member_table tr{border-bottom:1px solid #e0e0e0;}
.apply_member_table th{width:100%; height:auto; padding:10px 15px; border-bottom:none;}
.apply_member_table td{border-bottom:none; padding:10px 10px;}
.apply_member_agree{font-size:16px;}
.apply_member_info{font-size:14px;}
}

/* apply_agree (약관동의) */
.apply_agree_list{display:flex; flex-direction:column; gap:20px; padding:30px 40px; border-radius:10px; background-color:#f5f5f5;}
.apply_agree_item{display:flex; flex-direction:column; gap:0;}
.apply_agree_item label{display:flex; align-items:center; gap:8px; cursor:pointer;}
.apply_agree_item input[type="checkbox"]{position:absolute; width:1px; height:1px; margin:-1px; padding:0; overflow:hidden; clip:rect(0,0,0,0); border:0;}
.apply_agree_item .ico_check{display:inline-block; width:24px; height:24px; border-radius:50%; background-color:#bdbdbd; background-image:url(../img/ic_mark.svg); background-repeat:no-repeat; background-position:center center; background-size:12px; flex-shrink:0;}
.apply_agree_item input[type="checkbox"]:checked + .ico_check{background-color:#1197d5;}
.apply_agree_item label span:last-child{font-size:1.0625rem; font-weight:500; color:#424242; line-height:2;}
.apply_agree_all{flex-direction:row; align-items:center; gap:8px; padding-bottom:20px; border-bottom:1px solid #e0e0e0; cursor:pointer;}
.apply_agree_all span:last-child{font-size:1.0625rem; font-weight:700; color:#424242;}
.apply_agree_item_top{display:flex; align-items:center; justify-content:space-between;}
.apply_agree_item_top label{flex:1;}
.btn_toggle{display:flex; align-items:center; justify-content:center; width:18px; height:18px; padding:0; border:none; background:url(../img/ico_breadcrumb_arrow.svg) no-repeat center center; background-size:contain; cursor:pointer;  transition:transform 0.3s ease-out; flex-shrink:0;}
.btn_toggle.is-active{transform:rotate(180deg);}
.apply_agree_content{display:none; margin-top:10px; padding:20px; background-color:#fff; border-radius:5px;}
.apply_agree_content span{font-size:1rem; font-weight:400; color:#424242; line-height:2.125;}

/* apply_sign (서명) */
.apply_sign_section{display:flex; flex-direction:column; gap:30px;}
.apply_sign_title{font-size:1.25rem; font-weight:600; color:#000; line-height:1.5; text-align: center;}
.apply_sign_title strong{color:var(--point-color-2); font-weight:inherit;}
.apply_sign_date{display:flex; gap:16px; width:100%; list-style:none; margin:0; padding:0;}
.apply_sign_date li{position:relative; flex:1;}
.apply_sign_date .unit{position:absolute; right:20px; top:50%; transform:translateY(-50%); font-size:1rem; font-weight:500; color:#424242;}
.apply_sign_date .val{display:flex; align-items:center; width:100%; height:50px; padding:0 12px; border:1px solid #e0e0e0; border-radius:5px; background-color:#f5f5f5; font-size:1rem; font-weight:500; color:#212121; box-sizing:border-box;}
.apply_sign_info{display:flex; flex-direction:column; gap:8px;}
.apply_sign_info .label{font-size:1.0625rem; font-weight:600; color:#424242;}
.apply_sign_box{width:100%; height:120px; display:flex; align-items:center; justify-content:center; border:1px solid #e0e0e0; border-radius:5px; background-color:#f5f5f5;}
.apply_sign_box span{font-size:1rem; font-weight:400; color:#9e9e9e;}

/* apply_notice_info (하단 안내) */
.apply_notice_info{display:flex; justify-content:center; padding:20px; border:1px dashed #1197d5; border-radius:5px;}
.apply_notice_info ul{display:flex; flex-direction:column; gap:8px; list-style:none; margin:0; padding:0; align-items:center;}
.apply_notice_info ul li{position:relative; padding-left:30px; font-size:1.125rem; font-weight:600; color:#000; line-height:1.5;}
.apply_notice_info ul li::before{position:absolute; left:0; top:50%; transform:translateY(-50%); width:24px; height:24px; border-radius:50%; background-color:#1197d5; content:"";}
.apply_notice_info ul li::after{position:absolute; left:7px; top:50%; transform:translateY(-50%) rotate(45deg); width:6px; height:10px; border-right:2px solid #fff; border-bottom:2px solid #fff; content:""; margin-top:-2px;}
.apply_notice_info ul li strong{color:#0C6B97; text-decoration: underline; font-weight:inherit;}
.btn_submit{gap:8px;}

@media screen and (max-width: 768px){
.apply_agree_list{padding:20px;}
.apply_agree_item label span:last-child{font-size:15px;}
.apply_agree_all span:last-child{font-size:15px;}
.apply_agree_content span{font-size:14px;}
.apply_notice_info ul li{font-size:15px; padding-left:28px;}
}

/* ========================================
   apply_complete (step 3 completion message)
   ======================================== */
.apply_complete{display:flex; flex-direction:column; align-items:center; gap:20px; padding:0;}
.apply_complete_txt{display:flex; flex-direction:column; align-items:center; gap:10px;}
.apply_complete_title{font-family:var(--font); font-size:1.5625rem; color:#212121; text-align:center;}
.apply_complete_title strong{color:var(--point-color-1); font-weight:700;}
.apply_complete_desc{display:flex; align-items:center; gap:5px; font-size:1rem; font-weight:500; color:#424242; text-align:center;}
.apply_complete_desc strong{font-weight:inherit; color:var(--point-color-2); text-decoration: underline;}
.apply_complete_notice{font-size:1rem; font-weight:500; color:#0c6b97; text-align:center;}

/* field_value */
.field_value{display:flex; align-items:center; min-height:50px; padding:0 12px; font-size:1rem; font-weight:500; color:#212121; line-height:1.6; }
.field_value strong{color:#1197d5; font-weight:700; font-size:1.25rem;}

@media screen and (max-width:960px){
.apply_complete_img{width:200px;}
.apply_complete_title{font-size:20px;}
.apply_complete_desc{flex-direction:column; text-align:center;}
.apply_complete_notice{font-size:14px;}
.field_value{min-height:auto; padding:5px 0;}
}

/* ========================================
   refund (환급신청 전용)
   ======================================== */
.refund_highlight{padding:10px 20px; background-color:#e8f4fd; border-radius:5px;}
.refund_youth_check{display:inline-flex; align-items:center; gap:8px; cursor:pointer;}
.refund_youth_check input[type="checkbox"]{position:absolute; width:1px; height:1px; margin:-1px; padding:0; overflow:hidden; clip:rect(0,0,0,0); border:0;}
.refund_youth_check .ico_check{display:inline-block; width:24px; height:24px; border-radius:50%; background-color:#bdbdbd; background-image:url(../img/ic_mark.svg); background-repeat:no-repeat; background-position:center center; background-size:12px; flex-shrink:0;}
.refund_youth_check input[type="checkbox"]:checked + .ico_check{background-color:#1197d5;}
.refund_youth_check span:last-child{font-size:1.0625rem; font-weight:500; color:#424242;}
.refund_category_list{display:flex; flex-direction:column; gap:30px; margin-top:10px;}
.refund_category{display:flex; flex-direction:column; gap:15px;}
.refund_category_tit{display:flex; align-items:center; gap:12px;}
.refund_category_tit .bar{display:block; width:4px; height:22px; border-radius:2px; background-color:var(--point-color-1);}
.refund_category_tit span:last-child{font-size:1.25rem; font-weight:600; color:#212121;}
.refund_category_body{display:flex; flex-direction:column; gap:15px; list-style:none; margin:0; padding:0;}
.refund_entry{display:flex; flex-direction:column; gap:0;}
.refund_inline_row{display:flex; align-items:flex-start; gap:20px;}
.refund_inline_field{display:flex; align-items:center; gap:0;}
.refund_inline_field .field_label{width:100px; min-height:50px; padding:0; font-size:1.0625rem; font-weight:600; color:#424242; display:flex; align-items:center; gap:3px; flex-shrink:0;}
.refund_inline_field .field_label .star{color:#1197d5;}
.refund_inline_field .field_input{flex:1;}
.refund_inline_field .input_group{display:flex; align-items:center; gap:10px; flex-wrap:nowrap;}
.refund_inline_field .input_group input[type="text"]{flex:1; min-width:0;}
.refund_inline_field .field_input input[type="text"]{height:50px; padding:0 15px; border:1px solid #e0e0e0; border-radius:5px; font-size:1rem; color:#212121; background-color:#f5f5f5; width:100%; box-sizing:border-box;}
.refund_inline_field .field_input input[type="text"]::placeholder{color:#9e9e9e;}
.refund_file_field{display:flex; align-items:center; gap:20px;}
.refund_entry_btn{display:flex; gap:15px; align-items:center;}
.refund_entry_btn button{display:flex; align-items:center; justify-content:center; width:30px; height:30px; border:none; border-radius:5px; font-size:0.875rem; font-weight:700; color:#fff; cursor:pointer; transition:all 0.3s ease-out;}
.refund_entry_btn .btn_entry_add{background-color:#424242;}
.refund_entry_btn .btn_entry_add:hover{background-color:#212121;}
.refund_entry_btn .btn_entry_remove{background-color:#fff; border:1px solid #e0e0e0; color:#424242;}
.refund_entry_btn .btn_entry_remove:hover{background-color:#f5f5f5;}

@media screen and (max-width:1440px){
.refund_inline_field .field_label{width:80px;}
.refund_inline_row{gap:10px;}
}
@media screen and (max-width:1200px){
.refund_inline_row{flex-wrap:wrap;}
.refund_inline_field{width:calc(50% - 5px);}
.refund_inline_field .input_date{width:100%;}
.refund_inline_field .input_date .date_wrap{width:100%;}
}
@media screen and (max-width:960px){
.refund_inline_row{flex-wrap:wrap; gap:15px;}
.refund_inline_field{flex:1; min-width:calc(50% - 10px);}
.refund_inline_field .field_label{width:70px; min-height:auto; padding:0 0 5px;}
}
@media screen and (max-width:768px){
.refund_category{position:relative; }
.refund_highlight{padding:8px 15px;}
.refund_inline_row{flex-direction:column; gap:15px; }
.refund_inline_field{min-width:100%; gap:10px;}
.refund_inline_field .field_label{padding:0 0 5px;}
.refund_inline_field .input_group{flex-wrap:nowrap;}
.refund_entry_btn{position:absolute; right:0; top:0; gap:10px;}
.refund_category_tit span:last-child{font-size:16px;}
.refund_entry_btn button{width:28px; height:28px;}
}

/* 숙박 여행자/동반자 정보 */
.refund_traveler_wrap{display:flex; gap:15px; margin-top:15px;}
.refund_traveler_check{display:flex; align-items:flex-start; padding-top:5px; flex-shrink:0; cursor:pointer;}
.refund_traveler_check .ico_check{display:block; width:24px; height:24px; border-radius:50%; background:#bdbdbd; position:relative; transition:all 0.3s ease-out;}
.refund_traveler_check .ico_check::after{content:''; position:absolute; top:50%; left:50%; transform:translate(-50%,-55%) rotate(45deg); width:6px; height:10px; border:solid #fff; border-width:0 2px 2px 0;}
.refund_traveler_check input:checked + .ico_check{background:#1197d5;}
.refund_traveler_check input{display:none;}
.refund_traveler_info{flex:1; border-top:1px solid #000;}
.refund_traveler_info .apply_member_table{width:100%; border-collapse:collapse;}
.refund_traveler_info .apply_member_table th{width:150px; padding:15px 20px; background:#f5f5f5; font-size:1.0625rem; font-weight:600; text-align:left; border-bottom:1px solid #e0e0e0;}
.refund_traveler_info .apply_member_table td{padding:15px 20px; border-bottom:1px solid #e0e0e0;}
.refund_traveler_info .apply_member_table input[type="text"]{width:100%; height:50px; padding:0 15px; border:1px solid #e0e0e0; border-radius:5px; font-size:1rem; box-sizing:border-box;}
/* 여행자 정보 그리드 (div) */
.refund_traveler_grid{display:flex; flex-wrap:wrap;}
.refund_traveler_grid.grid_half .refund_traveler_cell{width:50%;}
.refund_traveler_cell{display:flex; align-items:stretch; width:calc(100% / 3); border-bottom:1px solid #e0e0e0; box-sizing:border-box;}
.refund_traveler_cell .cell_label{display:flex; align-items:center; gap:3px; width:150px; padding:15px 20px; background:#f5f5f5; font-size:1.0625rem; font-weight:600; color:#000; flex-shrink:0; box-sizing:border-box;}
.refund_traveler_cell .cell_label .star{color:#1197d5;}
.refund_traveler_cell .cell_input{flex:1; padding:15px 20px; display:flex; align-items:center; gap:15px; box-sizing:border-box;}
.refund_traveler_cell .cell_input input[type="text"]{width:100%; height:50px; padding:0 15px; border:1px solid #e0e0e0; border-radius:5px; font-size:1rem; box-sizing:border-box;}
.refund_traveler_cell .cell_input .input_group{display:flex; align-items:center; gap:10px; width:100%;}
.refund_traveler_cell .cell_input .input_group input[type="text"]{flex:1; min-width:0;}
.refund_traveler_cell .cell_input .input_date{width:100%;}
.refund_traveler_cell .cell_input .input_date .date_wrap{width:100%;}
.refund_traveler_cell .cell_input .input_file{width:100%;}
.refund_traveler_cell .cell_input select{width:100%; height:50px; padding:0 15px; border:1px solid #e0e0e0; border-radius:5px; font-size:1rem; color:#616161; background:#fff url(../img/ico_breadcrumb_arrow.svg) no-repeat right 15px center; background-size:12px; appearance:none; -webkit-appearance:none; box-sizing:border-box;}
@media screen and (max-width:1200px){
.refund_traveler_cell{width:50%;}
.refund_traveler_grid.grid_half .refund_traveler_cell{width:50%;}
}
@media screen and (max-width:960px){
.refund_traveler_cell{width:100%;}
.refund_traveler_grid.grid_half .refund_traveler_cell{width:100%;}
.refund_traveler_cell .cell_label{width:120px; padding:12px 15px;}
.refund_traveler_cell .cell_input{padding:12px 15px;}
}
.refund_doc_list{display:flex; flex-direction:column; gap:10px; margin-top:15px;}
.refund_doc_row{display:flex; align-items:center; gap:15px;}
.refund_doc_row .field_label{width:160px; font-size:1.0625rem; font-weight:600; color:#000; flex-shrink:0;}
.refund_doc_row .input_file{flex:1; max-width:510px;}
.refund_doc_info{padding:10px 0 0; font-size:0.9375rem; font-weight:500; color:#004e6c; line-height:1.6;}
.refund_file_field .field_label{width:120px; min-height:50px; padding:0; font-size:1.0625rem; font-weight:600; color:#000; display:flex; align-items:center; gap:3px; flex-shrink:0;}

@media screen and (max-width:768px){
.refund_traveler_wrap{flex-direction:column; }
.refund_traveler_info .apply_member_table th,.refund_traveler_info .apply_member_table td{display:block; width:100%; padding:10px;}
.refund_traveler_info .apply_member_table th{background:none; border:none; padding-bottom:0;}
.refund_doc_row{flex-direction:column; align-items:flex-start; gap:5px;}
.refund_doc_row .field_label{width:auto;}
.refund_doc_row .input_file{max-width:100%; width:100%;}
.refund_traveler_cell .cell_label{width:90px; padding:10px;}
}

/* ========================================
   travel_notice / refund_notice (유의사항 Check 공통 오버라이드)
   ======================================== */
.travel_notice .apply_check_con,.refund_notice .apply_check_con{border:none; border-radius:0; text-align:center; padding:50px 40px;}
.travel_notice .apply_check_top,.refund_notice .apply_check_top{justify-content:center;}
.travel_notice .apply_check_desc + .apply_check_desc{margin-top:50px;}
.travel_notice .apply_check_desc .desc_txt{margin-top:10px;}
.travel_notice .apply_check_desc .desc_txt strong{color:#1197d5;}
.travel_notice .apply_check_desc .desc_example{display:block; margin-top:30px; margin-bottom:30px;}
.travel_notice .guide_table_wrap{margin-top:0;}
.refund_notice .apply_check_desc + .apply_check_desc{margin-top:30px;}
.refund_notice .apply_check_desc .desc_tit{color:#424242;}
.refund_notice .apply_check_desc .desc_txt strong{font-weight:700; color:#1197d5;}

@media screen and (max-width:768px){
.travel_notice .apply_check_con,.refund_notice .apply_check_con{padding:25px 20px;}
.travel_notice .apply_check_desc + .apply_check_desc{margin-top:25px;}
.travel_notice .apply_check_desc .desc_example{margin-top:15px; margin-bottom:15px;}
.refund_notice .apply_check_desc + .apply_check_desc{margin-top:15px;}
}

/* ========================================
   confirm (신청확인 목록)
   ======================================== */
.confirm_list{display:flex; flex-direction:column; gap:70px;}
.confirm_section{display:flex; flex-direction:column; gap:20px;}
.confirm_table{overflow-x:auto;}
.confirm_table table{width:100%; border-collapse:collapse; text-align:center;}
.confirm_table thead th{padding:0 30px; height:60px; background-color:#eee; font-size:1.0625rem; font-weight:600; color:#424242; letter-spacing:-0.02em;}
.confirm_table tbody td{padding:0 30px; height:60px; font-size:1rem; font-weight:500; color:#424242; border-bottom:1px solid #bdbdbd;}
.confirm_table tbody tr{cursor:pointer; transition:background-color 0.2s ease-out;}
.confirm_table tbody tr:hover{background-color:#f9f9f9;}
.confirm_tag{display:inline-flex; align-items:center; justify-content:center; height:30px; padding:0 15px; border-radius:2em; font-size:0.9375rem; font-weight:600; letter-spacing:-0.01em;}
.confirm_tag.temp{background-color:#fff3e0; color:#e65100; border:1px solid #ffcc80;}
.confirm_tag.pending{background-color:transparent; color:var(--point-color-2); border:1px solid var(--point-color-2);}
.confirm_tag.reviewing{background-color:#ede7f6; color:#4527a0; border:1px solid #b39ddb;}
.confirm_tag.supplement{background-color:#fff8e1; color:#f57f17; border:1px solid #ffe082;}
.confirm_tag.reviewed{background-color:#e0f2fe; color:#0369a1; border:1px solid #7dd3fc;}
.confirm_tag.approved{background-color:#1197d5; color:#fff;}
.confirm_tag.completed{background-color:#f0fdf4; color:#15803d; border:1px solid #86efac;}
.confirm_tag.cancelled{background-color:#fafafa; color:#999; border:1px solid #e0e0e0;}

@media screen and (max-width:768px){
.confirm_list{gap:40px;}
.confirm_table thead th{padding:0 10px; height:50px; font-size:14px;}
.confirm_table tbody td{padding:0 10px; height:50px; font-size:13px;}
.confirm_tag{height:26px; padding:0 10px; font-size:12px;}
}

/* ========================================
   confirm_view (신청확인 상세)
   ======================================== */
.confirm_view{display:flex; flex-direction:column; gap:40px;}
.confirm_tab ul{display:flex; align-items:center; gap:45px; list-style:none; justify-content: center;}
.confirm_tab ul li{position:relative; min-width:166px;  display:flex; align-items:center; justify-content:center; height:54px; padding:0 15px; font-size:1.125rem; font-weight:500; color:#424242; letter-spacing:-0.02em; cursor:pointer; transition:all 0.3s ease-out; box-sizing:border-box; border:1px solid var(--point-color-1); border-radius:10px;}
.confirm_tab ul li:first-child::before{display:none;}
.confirm_tab ul li::before{position:absolute; left:-36px; top:50%; width:25px; height:1px; background-color:#bdbdbd; display:block; content:"";}
.confirm_tab ul li.is-active{background-color:#1197d5; border-color:#1197d5; color:#fff; font-weight:600;}
.confirm_view_btn{display:flex; justify-content:flex-end;}
.btn_edit{display:flex; align-items:center; justify-content:center; width:80px; height:40px; border:1px solid #0c6b97; border-radius:5px; font-size:1rem; font-weight:500; color:#0c6b97; text-decoration:none; transition:all 0.3s ease-out;}
.btn_edit:hover{background-color:#e8f4fd;}

@media screen and (max-width:1200px){
.confirm_tab ul{flex-wrap:wrap; gap:10px;}
.confirm_tab ul li{min-width:80px; height:40px;}
.confirm_tab ul li:before{display:none;}
}
@media screen and (max-width:768px){
.confirm_view{gap:25px;}
.confirm_tab ul{flex-wrap:wrap; gap:8px;}
.confirm_tab ul li{height:40px; padding:0 12px; font-size:14px;}
.btn_edit{width:70px; height:36px; font-size:14px;}
}

/* ========================================
   login_card (login/verify card layout)
   ======================================== */
.login_card{max-width:800px; margin:0 auto; padding:50px; border:1px solid #e0e0e0; border-radius:50px; background-color:#fff; box-sizing:border-box;}
.login_card_top{display:flex; flex-direction:column; gap:25px; margin-bottom:40px;}
.login_card_tit{padding-bottom:10px; border-bottom:1px solid #bdbdbd; font-family:var(--font-title); font-size:2.5rem; font-weight:700; color:#212121; text-align:center;}
.login_card:not(:has(.login_card_top)) .login_card_tit{margin-bottom:40px;}
.login_card_desc{display:flex; flex-direction:column; gap:10px; align-items:center; text-align:center;}
.login_card_desc .highlight{font-size:1.5625rem; font-weight:600; color:#0c6b97;}
.login_card_desc .sub{font-size:1.0625rem; font-weight:500; color:#616161;}
.login_card_form{display:flex; flex-direction:column; gap:25px;}
.login_card_form .apply_field_row{display:flex; align-items:center;}
.login_card_form .apply_field_row .field_label{width:180px; min-height:auto; padding:0; flex-shrink:0;}
.login_card_form .apply_field_row .field_input{flex:1;}
.login_card_btn{display:flex; flex-direction:column; gap:20px; margin-top:50px;}
.login_card_btn .btn_next{display:flex; align-items:center; justify-content:center; width:100%; height:60px; border-radius:10px; background-color:#1197d5; font-size:1.125rem; font-weight:700; color:#fff; text-decoration:none; transition:all 0.3s ease-out;}
.login_card_btn .btn_next:hover{background-color:var(--point-color-1);}
.login_card_btn .btn_find{display:flex; align-items:center; justify-content:center; gap:5px; width:100%; height:60px; border:1px solid #1197d5; border-radius:10px; font-size:1.0625rem; font-weight:500; color:#424242; text-decoration:none; transition:all 0.3s ease-out;}
.login_card_btn .btn_find:hover{background-color:#e8f4fd;}
.login_card_btn .btn_find strong{font-size:1.125rem; font-weight:500; color:#0c6b97;}

@media screen and (max-width:960px){
.login_card{max-width:100%;}
.login_card_form .apply_field_row{flex-direction:column; align-items:flex-start;}
.login_card_form .apply_field_row .field_label{width:100%; min-height:auto; padding:10px 0;}
.login_card_form .apply_field_row .field_input{width:100%;}
.login_card_form .input_group{flex-direction:row; flex-wrap:wrap;}
}
@media screen and (max-width:768px){
.login_card{padding:30px 20px; border-radius:20px;}
.login_card_tit{font-size:24px; padding-bottom:10px;}
.login_card_desc .highlight{font-size:18px;}
.login_card_desc .sub{font-size:14px;}
.login_card_btn{margin-top:30px;}
.login_card_btn .btn_next{height:50px; font-size:16px;}
.login_card_btn .btn_find{height:50px; font-size:14px;}
.login_card_btn .btn_find strong{font-size:15px;}
}

/* date_picker */
.date_picker_wrap{display:flex; flex-direction:column; gap:40px;}
.date_picker_header{text-align:center;}
.date_picker_header h4{font-family:var(--font); font-size:1.75rem; font-weight:500; color:#212121; line-height:1.4;}
.date_picker_header h4 strong{font-weight:700; color:var(--point-color-2)}
.date_picker_header p{font-size:1.25rem; color:#424242; margin-top:10px;}
.date_picker_calendar{position:relative; display:flex; align-items:center; gap:20px; justify-content:center;}
.cal_nav{position:absolute; top:50%; width:40px; height:40px; cursor:pointer; display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:all 0.3s ease-out; transform:translateY(-50%);}
.cal_prev{left:-80px; background:url(../img/cal_prev.svg) no-repeat center center;}
.cal_next{right:-80px; background:url(../img/cal_next.svg) no-repeat center center;}
.flatpickr-innerContainer{padding:0 20px 20px; width:100%; box-sizing:border-box;}
.flatpickr-rContainer{width:100%; display:block;}
.date_picker_indicator{display:flex; justify-content:center;}
.date_picker_indicator ul{display:flex; gap:8px; list-style:none; margin:0; padding:0;}
.date_picker_indicator li{width:8px; height:8px; border-radius:50%; background:#e0e0e0;}
.date_picker_indicator li.active{width:12px; height:12px; background:#1197d5;}
.date_picker_result{display:flex; gap:30px; justify-content:center; padding:0 0 40px;}
.date_picker_result .result_box{display:flex; flex-direction:column; align-items:center; gap:8px; padding:30px 50px; border:1px solid #1197d5; border-radius:10px; }
.date_picker_result .label{font-size:1rem; font-weight:600; color:#084460;}
.date_picker_result .value{font-size:1.5rem; font-weight:700; color:#1197d5;}

/* Flatpickr 커스터마이징 — 개별 인스턴스 */
.flatpickr-calendar{box-shadow:none !important; border:none !important; font-family:var(--font) !important; width:100% !important; max-width:100% !important;}
.flatpickr-calendar.inline{position:relative !important;}
.flatpickr-prev-month,.flatpickr-next-month{display:none !important;}
/* 재구성된 박스 구조 */
.cal-boxes-wrapper{display:flex; gap:50px; width:100%;}
.cal-box{flex:1; min-width:0; border-radius:10px; overflow:hidden; background:#fff; border: 1px solid #ddd; position:relative;}
.cal-dim-overlay{position:absolute; top:0; left:0; width:100%; height:100%; background:rgba(0,0,0,0.7); display:flex; align-items:center; justify-content:center; z-index:10; border-radius:10px;}
.cal-dim-overlay span{font-size:1.125rem; font-weight:700; color:#999; letter-spacing:-0.02em;}
.cal-box-header{margin:0 20px; padding:15px 0; text-align:center; font-size:1.375rem; font-weight:700; color:#2d2d2d; }
.cal-box .flatpickr-weekdays{background:#F5F5F5 !important; padding:0 5px; height:40px; border-radius:10px;}
.cal-box .flatpickr-weekday{color:#424242 !important; font-weight:600 !important; font-size:0.875rem !important;}
.cal-box .flatpickr-days{padding:5px !important; width:100% !important; }
.cal-box .dayContainer{width:100% !important; max-width:100% !important; min-width:100% !important; display:flex !important; flex-wrap:wrap !important;}
.cal-box .flatpickr-day{border-radius:50%; font-size:0.9375rem; color:#212121; height:40px; line-height:40px; flex-basis:14.2857% !important; max-width:14.2857% !important; width:14.2857% !important;}
.cal-box .flatpickr-day:hover{background-color:#1197d5 !important; color:#3CAADD !important;}
.flatpickr-day.selected,.flatpickr-day.startRange,.flatpickr-day.endRange{background:#1197d5 !important; border-color:#1197d5 !important; color:#fff !important;}
.flatpickr-day.inRange{background:#e8f4fd !important; border-color:#e8f4fd !important; box-shadow:-5px 0 0 #e8f4fd, 5px 0 0 #e8f4fd !important;}
.flatpickr-day.today{border:none; background-color:#E7F5FB; color:#0A5679; border-radius:50%; }
.flatpickr-day:hover{background:#e8f4fd !important; border-color:#e8f4fd !important;}
.flatpickr-day.flatpickr-disabled{color:#bdbdbd !important;}
#datepicker_inline{flex:1; min-width:0;}
.apply_form_btn .btn_next{display:flex; align-items:center; justify-content:center; width:350px; height:60px; border-radius:10px; font-size:1.125rem; font-weight:700; background:#1197d5; color:#fff; border:none; cursor:pointer; transition:all 0.3s ease-out;}
.apply_form_btn .btn_next:disabled{background:#e0e0e0; color:#9e9e9e; cursor:default;}
.apply_form_btn .btn_next:not(:disabled):hover{background:#084460;}
.cal-box .dim_content{display:flex; flex-direction:column; align-items:center; gap:10px; color:#fff;}
.cal-box .dim_content strong{font-size:1.5625rem; color:#fff; font-family: var(--font); font-weight:500;}
.cal-box .dim_content span{font-size:1.0625reem; font-family: var(--font); font-weight:500; color:#fff;}

/* 유의사항 팝업 */
.popup_overlay{position:fixed; top:0; left:0; width:100%; height:100%; background:rgba(33,33,33,0.7); display:flex; align-items:center; justify-content:center; z-index:9999;}
.popup_box{width:800px; max-width:90%; background:#fff; border-radius:50px; overflow:hidden; padding:50px; text-align:center;}
.popup_top{display:flex; flex-direction:column; gap:25px; }
.popup_title{font-size:2.5rem; font-weight:700; color:#212121; text-align:center; padding-bottom:10px; border-bottom:1px solid #bdbdbd; font-family: var(--font);} 
.popup_info{display:flex; flex-direction:column; gap:20px;}
.popup_info_item{display:flex; flex-direction:column; gap:8px;}
.popup_label{font-size:1.5625rem; font-weight:700; color:#187e36;}
.popup_value{font-size:1.25rem; font-weight:600; color:#424242;}
.popup_notice_txt{font-size:1.125rem; font-weight:500; color:#004e6c; line-height:1.6; margin-top:10px;}
.popup_btn{margin-top:40px;}
.popup_confirm{display:flex; align-items:center; justify-content:center; gap:8px; width:100%; height:60px; background:#0e80b5; color:#fff; border:none; border-radius:10px; font-size:1.125rem; font-weight:700; cursor:pointer; transition:all 0.3s ease-out;}
.popup_confirm:hover{background:#084460;}
.popup_confirm .ic_check{display:inline-block; width:24px; height:24px; background:#fff; border-radius:50%; position:relative;}
.popup_confirm .ic_check::after{content:''; position:absolute; top:50%; left:50%; transform:translate(-50%,-55%) rotate(45deg); width:6px; height:10px; border:solid #0e80b5; border-width:0 2px 2px 0;}

/* 유형선택 (apply_select) */
.apply_select{display:flex; flex-direction:column; gap:70px;}
.apply_select_tit{display:flex; flex-direction:column; gap:10px; align-items:center;}
.apply_select_tit h4{font-family:var(--font); font-size:1.875rem; font-weight:400; color:#212121;}
.apply_select_tit h4 strong{font-weight:700; color:var(--point-color-2);}
.apply_select_tit .desc{font-size:1.25rem; font-weight:500; color:#424242;}
.apply_select_list{display:flex; gap:40px; list-style:none; margin:0; padding:0;}
.apply_select_list li{flex:1;}
.apply_select_list li a{position:relative; height:100%; display:flex; flex-direction:column; align-items:center; gap:20px; padding:40px 20px; border-radius:20px; background-color:#fff; text-decoration:none; transition:all 0.3s ease-out; box-sizing:border-box;}
.apply_select_list li a:before{position:absolute; left:0; top:0; width:100%; height:100%; border-radius:20px; border:1px solid #e0e0e0; transition:all 0.3s ease-out; display:block; content:"";}
.apply_select_list li:hover a:before{border:2px solid #1197d5;}
.apply_select_list li .img_area{width:120px; aspect-ratio:1/1;}
.apply_select_list li .img_area img{width:100%; height:100%; object-fit:contain;}
.apply_select_list li .txt{display:flex; flex-direction:column; align-items:center; gap:0; font-family:var(--font); font-size:1.5625rem; font-weight:400; color:#000; text-align:center; line-height:1.4;}
.apply_select_list li .txt .sub{font-size:1.25rem; font-weight:500; color:#000;}
.apply_select_list li .txt .notice{font-size:1.25rem; font-weight:400; color:var(--point-color-2); margin-top:5px;}

@media screen and (max-width: 1660px){
.cal-boxes-wrapper{gap:20px; padding:0 40px;}
.cal_next{right:0;}
.cal_prev{left:0;}
}

@media screen and (max-width: 1200px){
.cal-boxes-wrapper{flex-wrap:wrap;}
.cal-box{min-width:calc(50% - 10px);}
}

@media screen and (max-width: 768px){
.cal-boxes-wrapper{flex-direction:column;}
.cal-box{min-width:100%;}
}

@media screen and (max-width: 1200px){
.date_picker_result{flex-direction:column; align-items:center;}
.date_picker_result .result_box{width:100%; max-width:400px;}
}

@media screen and (max-width: 768px){
.date_picker_header h4{font-size:22px;}
.date_picker_header p{font-size:16px;}
.date_picker_result .result_box{padding:20px 30px;}
.date_picker_result .value{font-size:20px;}
.cal_nav{width:35px; height:35px;}

.apply_form_btn .btn_next{width:100%;}

.popup_box{padding:20px; border-radius:20px;}
.popup_title{font-size:2rem;}
.popup_value,
.popup_label{font-size:1rem;}
.popup_top{gap:10px;}
.popup_btn{margin-top:20px;}
.popup_confirm{height:50px; font-size:16px;}
}

/* 유형선택 반응형 */
@media screen and (max-width: 1200px){
.apply_select_list{flex-wrap:wrap; gap:20px;}
.apply_select_list li{width:calc(50% - 10px); flex:none;}
}
@media screen and (max-width: 768px){
.apply_select{gap:40px;}
.apply_select_tit h4{font-size:22px;}
.apply_select_tit .desc{font-size:16px;}
.apply_select_list{gap:15px;}
.apply_select_list li a{padding:25px 20px; border-radius:15px;}
.apply_select_list li .img_area{width:80px;}
.apply_select_list li .txt{font-size:18px;}
.apply_select_list li .txt .sub{font-size:18px;}
}
@media screen and (max-width: 480px){
.apply_select_list li{width:100%;}
.apply_select_list li .txt{font-size:16px;}
.apply_select_list li .txt .sub{font-size:16px;}
}

.type_box{padding:30px; display:flex; gap:10px; justify-content: center; align-items: center; font-size:1rem; border:1px solid #e0e0e0; border-radius:10px; }
.type_box>div{display:flex; align-items:center; gap:8px;}
.type_box>div:before{width:35px; aspect-ratio: 1/1; flex-shrink: 0; background:url(../img/ic_person.png) no-repeat center center / 100%; display:block; content:"";}
.type_box strong{padding:2px 8px; background-color:#1D9741; display:inline-blkock; color:#fff; border-radius:5px;}
.type_box span{display:flex; align-items:center; gap:8px;}
.type_box span:before{width:24px; aspect-ratio: 1/1 ; background:url(../img/icon_check.svg) no-repeat center center / 100%; display:block; content:"";}