@import url('//fonts.googleapis.com/earlyaccess/notosanskr.css');@import url('https://fonts.googleapis.com/css2?family=Nanum+Myeongjo&display=swap');
/* Reset & Base */
html, body { margin: 0; padding: 0; box-sizing: border-box; font-family: 'Noto Sans KR', 'Apple SD Gothic Neo', Arial, sans-serif; color: #222; background: #f5f5f5; font-size: 16px; line-height: 1.6; } 
*, *:before, *:after { box-sizing: inherit; } 
ul, ol { list-style: none; margin: 0; padding: 0; } 
a { color: inherit; text-decoration: none; } 
img { max-width: 100%; display: block; border: 0; } 
em, i { font-style: normal; } 
strong, b { font-weight: 700; } 

#m_container { margin: 0 auto; max-width: 768px; } 

/* Section Card - 공통 */
.lic_intro,
.lic_intro_define,
.lic_cu,
.lic_process,
.lic_qna { border-radius: 14px; background-color: #fff; box-shadow: 0 5px 20px rgba(0, 0, 0, 0.03); margin: 24px 16px 0 16px; padding: 1.5rem; position: relative; } 
.lic_teacher,
.lic_information { padding: 0 1rem; } 
.lic_event { overflow: hidden; border-radius: 14px; box-shadow: 0 5px 20px rgba(0, 0, 0, 0.03); } 

/* intro */
.lic_intro { background-size: cover; background-position: center; min-height: 180px; padding: 1rem; display: flex; align-items: end; justify-content: flex-start; position: relative; overflow: hidden; text-align: right; } 
.lic_intro::before { content: ''; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: rgba(255, 255, 255, 0.4); z-index: 1; box-shadow: 0 5px 20px rgba(0, 0, 0, 0.03); } 
@keyframes show_text { 
 0% { filter:blur(5px); transform: translateY(20px); } 
 100% { filter:blur(0px); transform: translateY(0px); } 
 }
.lic_intro-wrap { position: relative; z-index: 2; width: 100%; animation: show_text 1.2s ease-in-out; } 
.lic_intro-summary { font-size: 0.95rem; color: #1976d2; font-weight: 600; margin-bottom: 8px; letter-spacing: -0.5px; text-shadow: 0 0 5px rgba(255, 255, 255, 0.8); } 
.lic_intro-title,
.lic_intro-wrap h1 { font-size: 2.1rem; font-weight: 900; color: #555; margin: 0 0 8px 0; letter-spacing: -1px; line-height: 1.2; } 
.lic_intro-wrap h1 { font-size: 2.2rem !important; font-weight: 800; color: #444; } 
.lic_intro-wrap a { font-size: 1.08rem; color: #374151; margin-bottom: 6px; display: block; } 

.lic_intro_define { border-radius: 12px; margin: 24px 16px 0 16px; padding: 22px 18px; display: flex; align-items: center; justify-content: flex-start; } 
.lic_intro_define_inner { display: flex; align-items: flex-start; gap: 18px; } 
.lic_intro_define_tit { font-size: 1.2rem; font-weight: 700; text-align: center; color: #1976d2; margin-bottom: 10px; letter-spacing: -0.5px; } 
.lic_intro_define span,
.lic_intro_define_desc { font-size: 1.02rem; color: #333; line-height: 1.7; word-break: keep-all; } 

/* Section Titles */
.lic_cu h2,
.lic_teacher h2,
.lic_information > p,
.lic_process h2,
.lic_qna h2 { font-size: 1.5rem; font-weight: 800; text-align: center; color: #1a237e; margin-bottom: 14px; letter-spacing: -0.5px; } 

/* Go Buttons */
.lic_go { display: flex; gap: 12px; justify-content: center; margin: 24px 16px 0 16px; } 
.lic_go_bottom { font-size: 1.4rem; font-weight: bold; color: #fff; display: flex; gap: 12px; justify-content: center; margin: 24px 16px 0 16px; background: #f22; border-radius: 1rem; padding: 1rem 0; } 
.lic_go_apply, .lic_go_consult, .lic_btn_study, .lic_btn_consult, .lic_btn_inquiry { flex: 1; background: #1976d2; color: #fff; font-size: 1.3rem; font-weight: 700; border-radius: 8px; padding: 0.7rem 0; text-align: center; box-shadow: 0 5px 20px rgba(0, 0, 0, 0.03); transition: background 0.2s, box-shadow 0.2s; border: none; cursor: pointer; } 
.lic_btn_consult { background: #43b581; } 
.lic_go_apply:hover, .lic_go_consult:hover, .lic_btn_study:hover, .lic_btn_consult:hover, .lic_btn_inquiry:hover { filter: brightness(0.95); box-shadow: 0 5px 20px rgba(0, 0, 0, 0.03); } 
.lic_btn_inquiry { background: linear-gradient(90deg, #fbbc05 60%, #ffd600 100%); color: #222; font-weight: 800; margin-top: 10px; } 

/* Content Boxes */
.lic_cu { overflow: hidden; } 
.lic_cu::before { content: ""; position: absolute; top: 0; left: 0; right: 0; bottom: 0; z-index: 1; pointer-events: none; } 
.lic_career_txt,
.lic_use_txt { position: relative; z-index: 2; } 
.lic_career_txt span,
.lic_use span { display: block; margin-bottom: 6px; color: #374151; font-size: 0.95rem; } 

/* Curri list */

.lic_curri h2 { font-size: 1.5rem; font-weight: 800; text-align: center; color: #1a237e; margin-bottom: 14px; letter-spacing: -0.5px; } 

.curri_tit { flex-flow: column wrap; } 

.lic_table { width: 100%; border-collapse: separate; border-spacing: 0; background: #f7fafd; box-shadow: 0 5px 20px rgba(0, 0, 0, 0.03); margin: 0 auto 24px auto; font-size: 1.01rem; overflow: hidden; } 
.lic_table tr { height: 50px; border: 1px solid #c5cae9; border-collapse: collapse; } 
.lic_table th,
.lic_table td { padding: 12px 8px; text-align: center; vertical-align: middle; font-size: 1.0rem; } 

.lic_table .week_tit { background: #1976d2; color: #fff; font-weight: 800; font-size: 1.08rem; letter-spacing: -0.5px; padding: 16px 0; } 


.lic_table .week_tit .test_video { top: 50%; transform: translateY(-50%); } 

.lic_table_tit td { background: #e3f2fd; color: #1976d2; font-weight: 700; font-size: 1.05rem; border-bottom: 1px solid #c5cae9; } 
.lic_table_class { background: #f0f4ff; color: #1976d2; font-weight: 700; border-radius: 6px; width: 70px; } 
.lic_table_desc { text-align: left; color: #374151; background: #fff; border-radius: 6px; padding-left: 12px; font-weight: 500; } 
.lic_table_test { background: #fffde7; color: #e53935; font-weight: 700; border-radius: 0 0 12px 12px; font-size: 0.95rem !important; letter-spacing: -0.5px; border-top: 1px solid #ffe082; } 

/* Teacher */
.lic_teacher { margin: 24px 0; } 
.lic_tc_wrap { display: flex; flex-flow: column wrap; align-items: flex-start; gap: 10px; margin-top: 12px; } 
.lic_tc_name { width: 100%; display: flex; flex-direction: column; align-items: center; min-width: 90px; gap: 5px; } 
.lic_tc_imgbox { position: relative; display: flex; flex-flow: row wrap; width: 100%; aspect-ratio: 2/1; border-radius: 2px; object-fit: cover; margin-bottom: 8px; overflow: hidden; box-shadow: 0 5px 20px rgba(0, 0, 0, 0.06); background: linear-gradient(90deg,#bbb 0%, #fff 36%, #fff 100%); /* background: linear-gradient(90deg,#bbb 0%, #fff 12%, #fff 36%, #bbb 100%); */}
.lic_tc_stc { font-family: "Nanum Myeongjo", serif; font-weight: bold; display: flex; align-items: center; text-align: center; width: 50%; transform: translateX(10%); padding: 1rem; z-index: 1; } 
.lic_tc_img { max-width: 50%; width: 50%; transform: scale(1.3) translateY(10%); } 
.lic_tc_profile { flex: 1; font-size: 0.85rem; color: #444; margin-top: 2px; padding: 0.5rem 1rem; } 
.lic_tc_profile li { margin-bottom: 4px; padding-left: 10px; position: relative; } 
.lic_tc_profile li:before { content: '·'; color: #1976d2; position: absolute; left: 0; font-size: 1.1em; top: 0; } 

/* Information */
.lic_information ul { margin-bottom: 10px; } 
.lic_information li { font-size: 1.01rem; margin-bottom: 5px; display: flex; justify-content: space-between; align-items: center; } 
.lic_information strong { color: #1976d2; font-weight: 700; } 
.lic_information em { font-style: normal; color: #333; } 

/* Payment Info */
.lic_info_4 ul, .lic_info_4 li { margin: 0; padding: 0; } 
.lic_info_4 li { margin-bottom: 10px; } 
.lic_info_4 strong { color: #e53935; } 
.lic_info_4 a, .lic_info_4 span { font-size: 1.01rem; color: #333; } 
.lic_red { color: #e53935 !important; font-weight: 700; } 

/* Process */
.lic_process_wrap img { width: 100%; border-radius: 10px; margin-top: 10px; box-shadow: 0 1px 8px rgba(30, 64, 175, 0.06); } 

.lic_process { width: 100%; max-width: 1200px; margin: 0px auto; display: flex; flex-flow: column wrap; gap: 0; background: #f7fafd; border-radius: 20px; box-shadow: 0 8px 32px rgba(30, 64, 175, 0.08); padding: 1.5rem 0; } 

.lic_process_steps { margin-top: 1.5rem; display: flex; justify-content: space-around; } 

.step { flex: 1 1 180px; max-width: 140px; background: linear-gradient(160deg, #4f8cff 0%, #1976d2 100%); color: #fff; text-align: center; padding: 1rem; border-radius: 18px; display: flex; flex-direction: column; justify-content: center; align-items: center; position: relative; box-shadow: 0 4px 16px rgba(30, 64, 175, 0.10); transition: transform 0.18s, box-shadow 0.18s; } 
.step-icon { width: 48px; height: 48px; margin-bottom: 18px; display: flex; align-items: center; justify-content: center; background: rgba(255,255,255,0.13); border-radius: 50%; box-shadow: 0 2px 8px rgba(30, 64, 175, 0.08); } 
.step-title { font-weight: 800; font-size: 1.0rem; line-height: 1.5; letter-spacing: -0.5px; color: #fff; margin-top: 2px; word-break: keep-all; } 

.step-arrow { display: flex; align-items: center; justify-content: center; font-size: 2.2rem; color: #b0b8c1; margin: 0 0.2rem; font-weight: 900; user-select: none; } 


/* Spec */
.lic_spec_list { display: flex; flex-flow: row wrap; gap: 14px; margin-top: 10px; } 
.lic_spec_list li { background: #f0f4ff; border-radius: 10px; flex: 1 1 45%; padding: 14px 10px; display: flex; align-items: center; box-shadow: 0 1px 4px rgba(30, 64, 175, 0.04); transition: box-shadow 0.2s; } 
.lic_spec_list li:hover { box-shadow: 0 4px 16px rgba(30, 64, 175, 0.10); } 
.lic_spec_list li img { width: 200px; border-radius: 8px; background: #fff; box-shadow: 0 1px 4px rgba(30, 64, 175, 0.06); } 
.lic_spec_list li div { padding-left: 24px; flex: 1; } 
.lic_spec_list span { margin-right: 8px; font-weight: 800; color: #1976d2; } 
.lic_spec_list em { font-size: 0.96rem; color: #666; display: block; margin-top: 2px; } 
.lic_spec_list p { font-size: 1.5rem; font-weight: 700; color: #1a237e; margin-bottom: 10px; letter-spacing: -0.5px; } 
.lic_spec_04 { background: #e3f2fd; } 

/* QnA */
.lic_qna_list { display: flex; flex-direction: column; gap: 16px; margin-top: 14px; } 
.lic_qna_item { background: #f7fafd; border-radius: 10px; box-shadow: 0 1px 6px rgba(26,115,232,0.07); padding: 18px 16px; transition: box-shadow 0.2s; } 
.lic_qna_item:hover { box-shadow: 0 4px 16px rgba(26,115,232,0.13); } 
.lic_qna_q { font-weight: 800; color: #1976d2; font-size: 1.09rem; margin-bottom: 7px; display: flex; align-items: center; } 
.lic_qna_q strong { background: #1976d2; color: #fff; border-radius: 50%; width: 25px; height: 25px; display: inline-flex; align-items: center; justify-content: center; margin-right: 10px; font-size: 0.8rem; font-weight: 900; } 
.lic_qna_a { color: #333; font-size: 1.01rem; line-height: 1.7; padding-left: 36px; } 
.lic_qna_a em { color: #e53935; font-style: normal; font-weight: 600; } 

.lic_mobile img { border-radius: 10px; margin: 18px auto 0 auto; box-shadow: 0 1px 8px rgba(30, 64, 175, 0.06); } 

.lic_info_cards { display: flex; flex-wrap: wrap; gap: 20px; margin: 0; padding: 0; } 
.lic_info_card { border-radius: 12px; flex: 1 1 320px; min-width: 260px; margin: 0; display: flex; flex-direction: column; position: relative; } 
.lic_info_card_head { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; } 
.lic_info_card_title { font-size: 1.2rem; font-weight: 800; text-indent: 5px; color: #1976d2; margin: 0; letter-spacing: -0.5px; } 
.lic_info_card ul { margin: 0 0 4px 0; padding: 0; } 
.lic_info_card ul li { width: 100%; display: flex; flex-flow: column wrap; justify-content: space-between; align-items: flex-start; font-size: 1.01rem; margin-bottom: 15px; border-bottom: 1px dashed #e3eafc; } 
.lic_info_card ul li:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; } 
.lic_info_card ul li>span { width: 100%; background-color: #c5cae9; color: #374151; font-weight: 600; min-width: 90px; display: inline-block; font-size: 0.98rem; padding: 4px 8px; } 
.lic_info_card ul li em { width: 100%; color: #222; font-style: normal; font-weight: 400; text-align: left; flex: 1; font-size: 0.98rem; word-break: keep-all; padding: 4px 8px; } 
.lic_info_card ul li .lic_red { color: #e53935; font-weight: 700; } 
.lic_info_card ul { display: flex; flex-flow: row wrap; } 
.lic_info_3 ul li { width: 50%; } 
.lic_info_3 ul li:nth-child(2n-1) span { border-right: 1px dashed #e3eafc; } 
.lic_info_3 ul li:nth-child(2n-1) em { border-right: 1px dashed #c5cae9; } 
.lic_info_4 { margin-top: 2rem; } 
.lic_info_btns { display: flex; gap: 8px; margin-top: 8px; } 
.lic_info_notice { background: #e3f2fd; color: #1976d2; font-size: 0.97rem; border-radius: 7px; padding: 10px 12px; margin-top: 8px; line-height: 1.6; word-break: keep-all; } 

/* connect lic */
.lic_connect_box { display: flex; flex-flow: row wrap; justify-content: space-between; margin: 40px 16px 0 16px; padding: 2rem 1.5rem; border-radius: 20px; position: relative; overflow: hidden; } 
.lic_connect_box > p { width: 100%; margin: 0 0 2rem 0; font-family: 'Noto Sans KR', sans-serif; font-size: 1.5rem; font-weight: 700; color: #1e293b; text-align: center; position: relative; z-index: 2; } 

.lic_connect_box > p > span { color: #1976d2; font-weight: 800; background: linear-gradient(135deg, #1976d2, #1565c0); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; } 

/* 카드 컨테이너 */
.lic_connects-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.5rem; margin-top: 1rem; } 

/* 개별 카드 스타일 */
.lic_connect { width: 30%; background: #ffffff; border-radius: 16px; overflow: hidden; box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1); transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); position: relative; border-top: 4px solid transparent; } 

.lic_connect:hover { transform: translateY(-8px); box-shadow: 0 12px 32px rgba(0, 0, 0, 0.15); } 

/* 카드 */
.lic_connect>div { display: flex; flex-direction: column; text-decoration: none; color: inherit; height: 100%; padding: 1.5rem; position: relative; } 

/* 이미지 컨테이너 */
.lic_connect img { width: 100%; height: 160px; object-fit: cover; border-radius: 12px; margin-bottom: 1rem; transition: transform 0.3s ease; } 

.lic_connect:hover img { transform: scale(1.05); } 

/* 카테고리 태그 */
.lic_connect>div p { margin: 0 0 0.5rem 0; font-size: 0.85rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; opacity: 0.7; } 

.lic_connect_1 p span { color: #1976d2; } 

.lic_connect_2 p span { color: #43b581; } 

.lic_connect_3 p span { color: #fbbc05; } 

/* 제목 */
.lic_connect h2 { font-family: 'Noto Sans KR', sans-serif; font-size: 1.2rem !important; font-weight: 700; line-height: 1.4; color: #1e293b; margin: 0; flex-grow: 1; letter-spacing: -0.3px; } 


/* fix icon */
@keyframes bounce { 0%, 100% { transform: translateY(0); } 
 50% { transform: translateY(-7px); } 
 }
.fix_icon { z-index: 9999; position: fixed; bottom: 11%; right: 2%; } 
.c-free { animation: bounce 1.3s ease-in-out infinite; } 

.c-free img { width: 80px; height: 80px; } 

.c-kakao { padding: 0.6rem; background: #fee500; /* 카카오*/
 border-radius: 50px; } 
.c-kakao img { width: 48px; height: 48px; } 

/* 롤바 개선 */
::-webkit-scrollbar { width: 8px; background: #f0f4ff; } 
::-webkit-scrollbar-thumb { background: #c5cae9; border-radius: 4px; } 

@media screen and (min-width: 1200px) { html, body { background: #fff; } 

 #m_container { display: flex; flex-flow : row wrap; justify-content: space-between; gap: 15px 1%; max-width: 1200px; } 

 .lic_intro, .lic_intro_define, .lic_cu, .lic_process, .lic_qna { margin: 0; } 

 .lic_intro { order: 1; width: 100%; min-height: 425px; } 
 .lic_intro_define { position: absolute; top: 50%; left: 2%; transform: translateY(-50%); width: 48%; text-align: left; background-color: transparent; padding: 2rem; } 
 .lic_career { order: 2; width: 49%; } 
 .lic_use { order: 3; width: 49%; } 
 .lic_event { order: 4; margin: 0 auto; } 
 .lic_teacher { order: 5; width: 49%; display:flex; flex-flow: row wrap; } 
 .lic_curri { order: 6; width: 49%; } 
 .lic_information { order: 7; display: flex; gap: 1%; } 
 .lic_qna { order: 8; width: 100%; } 
 .lic_process { order: 9; margin: 0 auto; } 
 /* .lic_mobile { order: 9; width: 60%; margin: 0 auto; } */
 .lic_spec { order: 10; width: 100%; margin: 0 auto; } 
 .lic_connect_box { order: 11; width: 100% !important; flex-flow: row wrap; } 
 .lic_go_bottom { order: 12; width: 50% !important; margin: 0 auto 30px auto; } 

 .lic_intro-summary { font-size: 1.3rem; } 
 .lic_intro-wrap h1 { font-size: 3.5rem !important; font-weight: 700; color: #333; } 

 .lic_intro_define::after { width: 100%; height: 100%; content: ''; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: rgba(255, 255, 255, 0.8); filter: blur(10px); z-index: -1; border-radius: 50px; } 

 .lic_curri, .lic_teacher { margin: 0; } 

 .lic_curri h2 { width: 100%; } 

 .lic_table th, .lic_table td { padding: 0; font-size: 0.9rem; } 

 .lic_table td.lic_table_desc { padding-left: 10px; text-align: left; } 
 
 .lic_teacher h2 { font-size: 1.5rem; } 

 .lic_tc_wrap { margin-top: 25px; } 

 .lic_tc_profile li:before { content: "-"; } 

 .lic_information .lic_info_card { width: 48%; margin: 0; } 
 .lic_information .lic_info_card em a { color: #1976d2; } 
 .lic_information .lic_info_card .lic_info_btns a { font-size: 1.3rem; } 

 .lic_go { display: none; } 

 .lic_mobile img { margin: 0; width: 100%; } 

 .fix_icon { display: none; } 

 .quick_right { position: fixed; right: 0; top: 50%; transform: translateY(-50%); z-index: 9999; } 
 }