@charset "utf-8"; .fa-solid,
.fas,
.fa-regular,
.fa-handshake,
.fa-brands,
.far,
.fab { font-family: 'Font Awesome 5 Free' !important; font-weight: 900; font-size: 24px; } 

.fa-regular,
.far { font-weight: 400; } 

/* CSS 변수 (Root Variables) */
:root { --sub-section-font-family: "Times New Roman", Times, serif; --main_color: #0b204d; --sub_color: #004494; --text-primary: #333333; --text-secondary: #666666; --text-tertiary: #999999; --text-white: #ffffff; /* --- Background Colors --- */
 --bg-white: #ffffff; --bg-light-gray: #f9f9f9; --bg-medium-gray: #f2f2f2; --bg-dark: #333333; --bg-overlay: rgba(0, 0, 0, 0.81); --bg-popup: rgba(0, 0, 0, 0.8); /* --- Border & Line Colors --- */
 --border-color: #dddddd; --border-light: #e5e5e5; --divider-color: #9baac9; /* --- Font Sizes & Weights --- */
 --font-size-h1: 46px; --font-size-h2: 38px; --font-size-h3: 32px; --font-size-h4: 26px; --font-size-h5: 20px; --font-size-body: 16px; --font-size-large: 18px; --font-size-small: 14px; --line-height-default: 1.3; --font-weight-light: 300; --font-weight-regular: 400; --font-weight-medium: 500; --font-weight-bold: 700; /* --- Spacing & Layout --- */
 --content-width: 1452px; --section-padding: 100px 0; --border-radius-small: 5px; --border-radius-medium: 8px; --border-radius-large: 10px; --border-radius-xlarge: 20px; /* --- Shadows --- */
 --box-shadow-default: 0px 4px 6px rgba(0, 0, 0, 0.1), 0px 1px 3px rgba(0, 0, 0, 0.06); --box-shadow-hover: 0px 8px 12px rgba(0, 0, 0, 0.2), 0px 4px 6px rgba(0, 0, 0, 0.1); --box-shadow-light: 0 5px 15px rgba(0, 0, 0, 0.05); } 

/* =========================================
 2. 레이아웃 및 공통 스타일
 ========================================= */

 header.pc_ver {
     display: block;
 }

 header.mobile_ver {
     display: none;
 }

.hamburger_menu {
    display: none;
}

/* 기본 레이아웃 구조 */
#container { width: 100%; min-height: 100%; display: flex; flex-direction: column; position: relative; background-color: #ffffff; } 

section { width: 100%; padding: 100px 0; } 

.main_page_wrapper { width: 100%; max-width: 100%; margin: 0; padding: 0; overflow-x: hidden; } 

.section_inner { position: relative; width: 100%; max-width: 1400px; height: auto; margin: 0 auto; } 

.section_contents { position: relative; display: flex; justify-content: space-between; gap: 20px; } 

.inner_con { position: relative; max-width: var(--content-width); margin: 0 auto; padding: 0 24px; } 

/* 유틸리티 클래스 */
.text_center { text-align: center; } 

.bg_light { background-color: var(--bg-light-gray); } 

.bg_gray { background-color: #f9f9f9; } 

.bg_white { background-color: #ffffff !important; } 

.white-space { white-space: nowrap; } 

.img_cover { object-fit: cover; width: 100%; height: 100%; } 

.img_contain { object-fit: contain; width: 100%; height: 100%; } 

.divider { height: 1px; background-color: #9baac9; margin: 6px 0; } 

/* 공통 섹션 헤더 */
.section_header { margin-bottom: 70px; } 

.section_title { font-family: var(--sub-section-font-family); font-size: var(--font-size-h2); font-weight: var(--font-weight-bold); margin-bottom: 5px; color: var(--text-primary); letter-spacing: -0.02em; } 

.section_subtitle { font-family: var(--sub-section-font-family); font-size: var(--font-size-h5); color: var(--text-secondary); font-weight: var(--font-weight-medium); } 

/* 공통 버튼 스타일 */
.btn_text { display: inline-flex; align-items: center; justify-content: center; gap: 12px; padding: 16px 45px; min-width: 220px; background-color: #ffffff; color: #0b204d !important; border: 1px solid #004494; font-size: 16px; font-weight: 500; text-decoration: none; border-radius: 4px; letter-spacing: -0.02em; transition: all 0.3s ease; box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); } 

.btn_text:hover { background-color: var(--main_color); color: var(--text-white) !important; border-color: var(--main_color); transform: translateY(-3px); box-shadow: 0 8px 15px rgba(11, 32, 77, 0.15); } 

.btn_text i { transition: transform 0.3s ease; font-size: 14px; } 

.mr-2 { margin-right: 0.5rem; } 

.mt-2 { margin-top: 0.5rem; } 

.mt-4 { margin-top: 1rem; } 

.btn_text:hover i { transform: translateX(5px); } 

.more_button { text-align: center; margin-top: 40px; } 

.more_button .btn { display: inline-block; padding: 13px 20px; background-color: transparent; color: #05213f; border-radius: 30px; border: 1px solid #05213f; transition: background-color 0.3s ease; } 

.more_button .btn:hover { background-color: #0056b3; color: #ffffff } 

.btn_white { background: var(--bg-white); color: var(--main_color); padding: 18px 40px; border-radius: var(--border-radius-large); font-weight: 700; text-decoration: none; font-size: 18px; transition: all 0.3s ease; display: inline-block; } 

.btn_white:hover { transform: translateY(-3px); box-shadow: 0 10px 20px rgba(0, 0, 0, 0.2); } 

.btn_program { color: #000; text-decoration: none; font-weight: 500; } 


/* =========================================
 3. 메인 비주얼 (Main Visual)
 ========================================= */
.main_visual { background: url(/images/main_visual/main_visual_bg.jpg) no-repeat top; width: 100%; height: 80vh; position: relative; overflow: hidden; background-size: cover; background-position: top; animation: zoomInEffect 4s ease-out forwards; } 

/* @keyframes zoomInEffect { 
 from { background-size: 110%; background-position: center center; } 

 to { background-size: 100%; background-position: top; } 
 }*/

.main_visual_wrap { position: absolute; top: 30%; left: 16%; color: #fff; } 

.main_visual_title { background-color: transparent; } 

.main_visual_title h2 {
    font-size: var(--font-size-h2);
    /* margin-bottom: 40px; */
    font-weight: bold;
    line-height: 55px;
    letter-spacing: -0.5px;
}
.main_visual_title h3 { font-size: var(--font-size-h3); margin-bottom: 5px; font-weight: 300; letter-spacing: -0.5px; } 

 .main_visual_title h4 {
      font-size: var(--font-size-h4);
     margin-bottom: 0;
     font-weight: var(--font-weight-light);
     line-height: 55px;
     letter-spacing: -0.5px;
 }

/* join member btn */

.main_visual_title .btn_area {
    margin-top: 20px;
    /* 텍스트와 간격 */
}

/* 버튼 스타일 */
.btn_visual_join {
    display: inline-block;
    padding: 15px 30px;
    border: 2px solid #fff;
    border-radius: 50px;
    color: #fff;
    font-size: 18px;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.3s ease;
    background-color: rgba(255, 255, 255, 0.1);
}

/* 호버 효과 (마우스 올렸을 때) */
.btn_visual_join:hover {
    background-color: #fff;
    color: #0b204d;
    border-color: #fff;
    transform: translateY(-3px);
}


/* --- 멤버/의사 소개 (Doctors & Members) --- */

.swiper-container { position: relative; width: 100%; height: 440px; overflow: hidden; } 

.swiper-container .swiper-wrapper { height: 600px; } 

.swiper-slide { border-radius: 10px; } 

.swiper-container .swiper-slide { background-color: #f2f2f2; text-align: center; font-size: 18px; height: 420px !important; line-height: 1; border-radius: 10px; box-shadow: 5px 4px 8px 0px #ddd; } 


.profile_card { width: 100%; height: 100%; border-radius: 10px; overflow: hidden; display: flex; flex-direction: column; background-color: #fff; } 

.photo_section { position: relative; height: 100%; width: 100%; overflow: hidden; } 

.doctor_bg { width: 100%; height: 100%; object-fit: cover; } 

.overlay_text { display: flex; align-items: center; gap: 8px; justify-content: start; border-radius: 5px; } 

.overlay_text .doctor_name { color: #0b204d; font-size: 18px; font-weight: bold; margin: 0; } 

.d_flag_icon { width: 24px; height: 16px; object-fit: cover; border-radius: 2px; } 

.profile_info_section { position: absolute; text-align: left; bottom: 0; padding: 12px 15px; background: rgba(242, 242, 242, 0.2); display: flex; flex-direction: column; justify-content: flex-start; overflow-y: auto; width: 100%; } 

.hospital_name { font-size: 16px; color: #000000; font-weight: 500; margin-bottom: 6px; text-align: left; } 

.profile_bio { font-size: 14px; color: #444; line-height: 1.2; text-align: left; } 

/* --- 아카데미 (Academy) --- */
.academy_grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; } 

.academy_card { text-align: center; padding: 50px 30px; border: 1px solid var(--border-light); border-radius: var(--border-radius-xlarge); transition: all 0.3s ease; } 

.academy_card:hover { border-color: var(--main_color); box-shadow: var(--box-shadow-hover); } 

.academy_icon { width: 90px; height: 90px; background: #f0f6ff; color: var(--main_color); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 36px; margin: 0 auto 25px; } 

.academy_card h4 { font-size: 24px; font-weight: 700; margin-bottom: 15px; } 

.academy_card p { color: var(--text-secondary); line-height: 1.6; } 


/* =========================================
 MAIN PAGE SCHEDULE SLIDER (Exclusive)
========================================= */

/* 슬라이더 영역 */
.main_schedule_swiper { width: 100%; padding: 20px 0 60px; } 

/* 개별 카드 스타일 */
.main_sch_item { position: relative; width: 100%; height: 480px; /* 메인은 조금 더 크게 강조 */
 border-radius: var(--border-radius-xlarge); overflow: hidden; background-size: cover; background-position: center; background-repeat: no-repeat; cursor: pointer; transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1), box-shadow 0.3s ease; box-shadow: var(--box-shadow-default); } 

.main_sch_item:hover { transform: translateY(-12px); box-shadow: var(--box-shadow-hover); } 

.main_sch_overlay { position: absolute; inset: 0; 
    /* background: linear-gradient(to top, rgba(11, 32, 77, 0.9) 0%, rgba(0, 0, 0, 0.3) 50%, rgba(0, 0, 0, 0) 100%);  */
    
    display: flex; flex-direction: column; justify-content: flex-end; padding: 35px 25px; box-sizing: border-box; transition: background 0.3s ease; } 

.main_sch_item:hover .main_sch_overlay { background: linear-gradient(to top, rgba(11, 32, 77, 1) 0%, rgba(11, 32, 77, 0.4) 60%, rgba(0, 0, 0, 0) 100%); } 

/* 정보 텍스트 스타일 */
.main_sch_info { color: var(--text-white); text-align: left; } 

.main_sch_title { font-size: 24px; font-weight: 700; margin-bottom: 15px; line-height: 1.3; letter-spacing: -0.02em; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; } 

.main_sch_date,
.main_sch_location { font-size: 15px; margin: 5px 0; opacity: 0.85; display: flex; align-items: center; gap: 10px; } 

.main_sch_date::before { content: '\f133'; font-family: 'Font Awesome 5 Free'; font-weight: 400; color: #fff; } 

.main_sch_location::before { content: '\f3c5'; font-family: 'Font Awesome 5 Free'; font-weight: 900; color: #fff; } 

/* 버튼 디자인 */
.main_sch_btn_area { margin-top: 25px; } 

.main_sch_btn { display: block; width: 100%; padding: 14px 0; text-align: center; background: rgba(255, 255, 255, 0.15); color: #fff; font-weight: 600; border-radius: var(--border-radius-medium); border: 1px solid rgba(255, 255, 255, 0.4); backdrop-filter: blur(8px); transition: all 0.3s ease; } 

.main_sch_item:hover .main_sch_btn { background: #fff; color: var(--main_color); border-color: #fff; } 

.main_sch_btn.disabled { opacity: 0.5; cursor: not-allowed; } 

/* --- 협력사 (Partners) --- */
#partners { background-color: #ffffff; } 

.partners_section { padding: 50px 0; text-align: center; } 

.partners_section h2 { font-size: 34px; font-weight: bold; text-align: center; margin-bottom: 20px; color: #333; } 

.partners_section .section_contents { display: flex; justify-content: center; align-items: center; flex-direction: column; } 

.partners_section .swiper-container { width: 100%; max-width: 1200px; margin: 0 auto; } 

.partner_slide { background: transparent; } 

.partner_slide img {
    width: 100%;
    height: auto;
    transition: filter 0.3s ease;
}

.swiper-container2 { position: relative; width: 100%; max-width: 1400px; margin: 0 auto; overflow: hidden; } 

.swiper-container2 .swiper-wrapper { height: auto; } 

.partners_grid { display: flex; flex-wrap: wrap; justify-content: start; column-gap: 50px; row-gap: 40px; column-gap: 90px; } 

.partner_logo { width: 18%; max-width: 150px; text-align: center; } 

.partner_logo img { width: 100%; height: auto; } 

.swiper-pagination2 { position: absolute; bottom: 10px; left: 0; right: 0; text-align: center; } 

.swiper-pagination2 .swiper-pagination-bullet { width: 12px; height: 12px; background-color: #ccc; border-radius: 50%; margin: 0 5px; transition: background-color 0.3s ease; } 

.swiper-pagination2 .swiper-pagination-bullet-active { background-color: var(--main_color); } 

.swiper-button-next2,
.swiper-button-prev2 { position: absolute; top: 50%; transform: translateY(-50%); width: 40px; height: 40px; background-color: rgba(0, 0, 0, 0.5); color: #fff; border-radius: 50%; display: flex; justify-content: center; align-items: center; cursor: pointer; transition: background-color 0.3s ease; z-index: 10; } 

.swiper-button-next2:hover,
.swiper-button-prev2:hover { background-color: var(--main_color); } 

.swiper-button-next2 { right: 10px; } 

.swiper-button-prev2 { left: 10px; } 

/* --- CTA 공통 세션) --- */
.section_faculty_banner { padding: 0 0 120px; } 

.faculty_banner_wrap { background: url('/images/sub/comm_topbg/faculty_bg.png') no-repeat center center / cover; border-radius: var(--border-radius-xlarge); padding: 80px; display: flex; align-items: center; justify-content: space-between; position: relative; overflow: hidden; color: var(--text-white); } 

.faculty_banner_wrap::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(90deg, rgb(0 18 37 / 90%), rgba(0, 30, 80, 0.8)); z-index: 1; } 

.fb_text,
.fb_btn { position: relative; z-index: 2; } 

.fb_text h3 { font-size: 42px; font-weight: 800; margin-bottom: 15px; } 

.fb_text p { font-size: 20px; opacity: 0.9; } 

.waas_banner { width: 100%; color: #fff; } 

.waas_banner_inner { display: flex; align-items: center; justify-content: space-between; max-width: 1400px; margin: 0 auto; height: 300px; overflow: hidden; } 

.waas_banner_text { padding: 40px; width: 30%; } 

.waas_banner_text h1 { font-size: 36px; margin-bottom: 10px; } 

.waas_banner_text .location { font-size: 20px; margin-bottom: 5px; } 

.waas_banner_text .date { font-size: 18px; } 

.section_cta { padding: 50px 0 100px 0; } 

.cta_banner { display: flex; align-items: center; justify-content: space-between; background: linear-gradient(35deg, #001831, var(--sub_color)); padding: 64px 80px; border-radius: var(--border-radius-xlarge); color: var(--text-white); box-shadow: 0 20px 50px rgba(0, 86, 179, 0.25); position: relative; overflow: hidden; } 

.cta_banner::after { content: ''; position: absolute; right: -10%; top: -50%; width: 500px; height: 500px; background: radial-gradient(circle, rgba(255, 255, 255, 0.1) 0%, rgba(255, 255, 255, 0) 70%); pointer-events: none; } 

.cta_text h3 { font-size: var(--font-size-h3); font-weight: var(--font-weight-bold); margin-bottom: 16px; color: var(--text-white); } 

.cta_text p { font-size: var(--font-size-h5); opacity: 0.9; color: var(--text-white);} 

.btn_cta { display: inline-flex; align-items: center; padding: 20px 48px; background: var(--bg-white); color: var(--main_color); font-size: var(--font-size-large); font-weight: var(--font-weight-bold); text-decoration: none; border-radius: var(--border-radius-large); transition: all 0.3s ease; } 

.btn_cta i { margin-left: 12px; transition: transform 0.3s ease; } 

.btn_cta:hover { transform: translateY(-3px); box-shadow: var(--box-shadow-default); } 

.btn_cta:hover i { transform: translateX(4px); } 

/* 기타 유틸리티 */

  .main_sch_desc {
      font-size: 15px;
      color: #ffffff;
      margin-bottom: 15px;
      line-height: 1.2;
      display: -webkit-box;
      -webkit-line-clamp: 5;
      -webkit-box-orient: vertical;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: normal;
  }

.text_white { color: var(--text-white) !important; }



.bullet_list { list-style: none; padding: 0; margin-top: 12px; } 

.bullet_list li { position: relative; padding-left: 16px; margin-bottom: 6px; } 

.bullet_list li::before { content: ''; position: absolute; left: 0; top: 7px; width: 6px; height: 6px; background: var(--main_color); border-radius: 50%; } 

.step_card.final_step { background: linear-gradient(35deg, #032d5a, var(--sub_color)); color: var(--text-white); } 

.step_card.final_step .step_number { color: rgba(255, 255, 255, 0.15); } 

.step_card.final_step h4,
.step_card.final_step strong,
.step_card.final_step p { color: var(--text-white); } 

.icon_wrapper { flex-shrink: 0; width: 64px; height: 64px; display: flex; align-items: center; justify-content: center; background: #f0f6ff; color: var(--main_color); border-radius: var(--border-radius-xlarge); margin-right: 24px; font-size: 28px; transition: all 0.3s ease; } 

.benefit_card:hover .icon_wrapper { background: var(--main_color); color: var(--text-white); } 

.text_wrapper h4 { font-size: var(--font-size-h5); font-weight: var(--font-weight-bold); margin-bottom: 12px; } 

.text_wrapper p { font-size: var(--font-size-body); color: var(--text-secondary); margin: 0; } 


/* =========================================
 6. 공통 컴포넌트 (Popup, Top Button)
 ========================================= */

/* --- 팝업 (Popup) --- */
.event_popup { display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.8); z-index: 9999; } 

.popup_content,
.popup_content1,
.popup_content2 { display: flex; justify-content: center; width: 700px; height: auto; background-color: transparent; margin: 50px auto; position: relative; padding: 0; border-radius: 8px; } 

.popup_content img,
.popup_content1 img,
.popup_content2 img { max-width: 700px; height: auto; } 

.popup_close { position: absolute; top: 0; right: -10px; font-size: 30px; background: none; border: none; cursor: pointer; color: #ffffff; width: 0px; height: 0px; font-size: 60px; } 

.main_fixed_popup { position: fixed; top: 60px; right: 20px; width: 100%; height: 100%; display: flex; justify-content: end; align-items: center; z-index: 9999; } 

.main_popup_content { flex-direction: column; background: white; padding: 0; border-radius: 3px; box-shadow: rgba(134, 134, 134, 0.4) 3px 4px 5px, rgba(134, 134, 134, 0.25) -2px -1px 4px; position: relative; } 

.main_popup_content img { display: block; max-width: 550px; height: 600px; border-radius: 3px; } 

.popup_bottom_bar { display: flex; justify-content: space-between; align-items: center; padding: 10px; background: #f8f8f8; border-top: 1px solid #ddd; border-bottom-right-radius: 3px; border-bottom-left-radius: 3px; } 

.checkbox_area { display: flex; align-items: center; } 

.checkbox_area label { cursor: pointer; margin-left: 5px; font-size: 14px; } 

.close_popup_btn { padding: 5px 10px; cursor: pointer; border: 1px solid #ccc; background-color: #fff; font-size: 14px; } 

/* --- 탑 버튼 (Top Button) --- */
#topButton { position: fixed; bottom: 40px; right: 40px; z-index: 9999; opacity: 0; visibility: hidden; transition: all 0.4s ease; transform: translateY(20px); } 

#topButton.show { opacity: 1; visibility: visible; transform: translateY(0); } 

#topButton button { width: 55px; height: 55px; background-color: var(--main_color); color: #ffffff; border: none; border-radius: 50%; cursor: pointer; box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3); display: flex; justify-content: center; align-items: center; font-size: 20px; transition: all 0.3s ease; } 

#topButton button:hover { background-color: var(--sub_color); transform: translateY(-5px); box-shadow: 0 8px 20px rgba(0, 0, 0, 0.4); } 


/* =========================================
 7. 푸터 (Footer)
 ========================================= */
#footer { border-top: 1px solid var(--border-light); padding: 40px 0; text-align: center; font-size: 14px; color: #fff; width: 100%; } 

.footer_inner { max-width: 1400px; margin: 0 auto; padding: 0 20px; display: flex; justify-content: start; align-items: center; } 

.footer_logo { flex-basis: 36%; text-align: left; } 

.footer_logo img { max-width: 80%; filter: contrast(0); } 

.footer_info { display: flex; flex-direction: column; flex-basis: 75%; color: #ccc; text-align: left; gap: 5px; } 

.footer_info p { font-size: 15px; color: var(--text-secondary); font-weight: 400; } 

.footer_social { flex-basis: 20%; margin-top: 5px; display: flex; gap: 10px; flex-direction: row-reverse; } 

.footer_social i { color: #8a8a8a; font-size: 28px; transition: color 0.3s; cursor: pointer; } 

.footer_social i:hover { color: #120127; } 


#mobileMembershipBtn {
        right: 40px;
            bottom: 110px;
}


