@charset "utf-8";
/* Font */
@import url(font.css);

/* Guide
----------------------------------------------------------------------------------------------------------------------------------------------------------
	▶사이즈
	pc : 1160px
	tablet : 980px ~
	mobile : 768px ~ 320px

	▶미디어쿼리는 (주석으로 구분 되어있는)파트마다 각각 작성함.

*/


/* Reset
---------------------------------------------------------------------------------------------------------------------------------------------------------- */
	body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,code,form,fieldset,legend,textarea,p,blockquote,th,td,input,select,textarea,button{margin:0; padding:0;}
	body,th,td,input,select,textarea,button{font-family:'NotoSansKR', sans-serif; letter-spacing:-1px; font-weight:300; font-size:16px; color:#555;}
	dl,ul,ol,menu,li {list-style:none;}
	*, *:before, *:after{-webkit-box-sizing:border-box; -moz-box-sizing:border-box; box-sizing:border-box;}
	:focus{outline:0 !important;}
	iframe{border:none; width:100%;}
	a{color:inherit; -webkit-transition:all .2s ease-out; -moz-transition:all .2s ease-out; transition:all .2s ease-out;}
	a:hover, a:focus ,a:active{text-decoration:none; color:#4664e1;}
	img{max-width:100%;}
	textarea{max-width:100%; resize:none;}

	@media only screen and (max-width: 768px){
		body,th,td,input,select,textarea,button{font-size:14px;}
	}
	@media only screen and (min-width: 320px){
		body{overflow-x:hidden;}
	}

	.hidden{font-size:0; line-height:0; text-indent:-9999em; overflow:hidden;}


/* Parallax
---------------------------------------------------------------------------------------------------------------------------------------------------------- */
	.parallax{background-position:0 0; background-repeat:no-repeat; background-size:100% auto; width:100%; background-size:cover; background-attachment:fixed;}


/* Preloader
---------------------------------------------------------------------------------------------------------------------------------------------------------- */
	.animationload{position: fixed; top:0; left:0; right:0; bottom:0; background-color:#fff; z-index:999999;}
	.loader {width:200px; height:200px; font-size: 24px; text-align: center; position:absolute; left:50%; top:50%; background-image:url(/images/basic_resp/img/preloader.gif); background-repeat:no-repeat; background-position:center; margin:-100px 0 0 -100px;}


/* Back to top (탑 버튼)
---------------------------------------------------------------------------------------------------------------------------------------------------------- */
	.back-to-top{width:40px; height:40px; position:fixed; bottom:10px; right:20px; display:none; text-align: center; z-index: 10000; -webkit-border-radius: 50%; -moz-border-radius: 50%; border-radius:50%; background:#6A6A82;}
	.back-to-top i{color: #fff; font-size: 15px; display: block; line-height: 33px;}


/* Layoyt (레이아웃)
---------------------------------------------------------------------------------------------------------------------------------------------------------- */
	#wrapper{position:relative; width:100%; min-width:320px; height:100%;}


/* Header
---------------------------------------------------------------------------------------------------------------------------------------------------------- */
	#header{position:relative; height:100px; background:#fff; border-bottom:1px solid #ddd;}
	
	#header h1{float:left; padding-left:30px; line-height:0; font-size:0;}
	#header h1 a{display:block; line-height:100px; vertical-align:middle;}
	
	.nav-btn{z-index:999; position:absolute; top:35px; right:32px; width:35px; height:29px; cursor:pointer;}
	.nav-btn span{position:absolute; left:50%; display:inline-block; margin-left:-17.5px; width:35px; height:3px; background:#4664E1; -webkit-transition:all .3s ease-out; -moz-transition:all .3s ease-out; transition:all .3s ease-out;}
	.nav-btn span:nth-child(1){top:0;}
	.nav-btn span:nth-child(2){top:13px;}
	.nav-btn span:nth-child(3){top:26px;}

	.nav-btn.nav-close span:nth-child(1){top:50%; transform:rotate(45deg);}
	.nav-btn.nav-close span:nth-child(2){margin-left:0; width:0;}
	.nav-btn.nav-close span:nth-child(3){top:50%; transform:rotate(-45deg);}

	@media only screen and (min-width: 981px){
		#header{height:100px;}

		.nav-bg{z-index:777; display:none; position:absolute; top:100px; width:100%; height:132px; background:rgba(256,256,256,0.9); border-bottom:2px solid #2A163C;}

		#nav{z-index:888; float:right; margin-right:99px;}
		
		.login-menu{float:right; font-size:0; line-height:0;}
		.login-menu li{display:inline-block; margin-left:20px; line-height:99px;}
		
		.navigation{float:right; margin-top:9px;}
		.navigation > li{position:relative; float:left; width:130px; text-align:center;}

.navigation .main-menu{display:block; margin-bottom:38px; width:100%; font-weight:400; font-size:18px; color:#4664E1; align:center;}
		.navigation .main-menu:hover{color:#4664E1;}
		.navigation > li:hover .main-menu{color:#4664E1;}

		.navigation .sub-menu{z-index:888; display:none; position:absolute; top:63px; left:50%; margin-left:-65px; padding:20px 0; width:100%; text-align:center;}
		.navigation .sub-menu a{line-height:30px; font-size:16px; color:#777;}
		.navigation .sub-menu a:hover{text-decoration:underline; color:#4664E1;}
	}
	@media only screen and (min-width: 981px) and (max-width: 1200px){
		#header h1{padding-left:20px;}

		.nav-btn{right:20px;}

		#nav{margin-right:75px}
		.login-menu li:first-child{margin-left:0;}
		.navigation > li{width:120px;}
		.navigation .sub-menu{margin-left:-60px;}
	}
	@media only screen and (max-width: 980px){
		#header{height:65px;}
		#header h1{padding-left:20px;}
		#header h1 a{line-height:65px;}

		.nav-btn{top:18px; right:20px;}
		.nav-btn.nav-close{position:fixed;}
		.nav-bg{z-index:777; display:none; position:fixed; top:0; left:0; width:100%; height:100%; background:rgba(0,0,0,0.8);}

		#nav{z-index:888; position:fixed; right:-260px; padding-top:75px; width:260px; height:100%; background:#fff;}

		.login-menu{margin-bottom:40px; padding:0 20px; text-align:center; line-height:0; font-size:0;}
		.login-menu li{display:inline-block;}
		.login-menu li:first-child{margin-right:25px;}

		.navigation .main-menu{display:block; margin-top:20px; text-align:center; padding:0 20px; width:100%; font-weight:400; font-size:18px; color:#000;}
		.navigation > li:first-child .main-menu{margin-top:0;}
		.navigation .active .main-menu{font-weight:400; text-decoration:underline; color:#4664E1;}

		.navigation .sub-menu{display:none; padding:10px 0;}
		.navigation .sub-menu a{display:block; text-align:center; line-height:30px; font-size:16px; color:#777;}
	}
	@media only screen and (max-width: 768px){
		#header h1{padding-left:10px;}
		#header h1 img{width:200px;}

		.nav-btn{top:20px; right:10px; width:30px; height:25px}
		.nav-btn span{margin-left:-15px; width:30px; height:3px;}
		.nav-btn span:nth-child(1){top:0;}
		.nav-btn span:nth-child(2){top:11px;}
		.nav-btn span:nth-child(3){top:22px;}
	}

/* 기본은 닫힘 */
@media (max-width:980px){
  #nav{ right:-260px; transition:right .3s ease; }
  .nav-bg{ display:none; pointer-events:none; }

  /* 열림 */
  #nav.is-open{ right:0; }
  .nav-bg.is-open{ display:block; pointer-events:auto; }

  /* 버튼이 항상 위에 오도록 (덮임 방지) */
  #header{ position:relative; z-index:1000; }
  .nav-btn{ z-index:1100; }
  #nav{ z-index:1080; }
  .nav-bg{ z-index:1050; }
}

/* Button (공통 버튼)
---------------------------------------------------------------------------------------------------------------------------------------------------------- */
	.btn{text-transform:uppercase; border-radius:0; line-height:24px;}
	.btn:focus, .btn:active{outline:none; color:#fff;}

	.btn-custom{border-radius:3px; padding:0.8em 1.8em; -webkit-transition:all .2s ease-out; -moz-transition:all .2s ease-out; transition:all .2s ease-out; text-transform:uppercase; background-color:#4664e1; border-color: #e65b43; color:#fff;}
	.btn-custom:hover, .btn-custom:focus{background-color: #00208e; border-color: #00208e; color:#fff;}

	.btn-custom-outline{border-radius:3px; padding:0.8em 1.8em; color:#fff; -webkit-transition:all .2s ease-out; transition:all .2s ease-out; text-transform:uppercase; background-color:transparent; border-color:#fff;}
	.btn-custom-outline:hover, .btn-custom-outline:focus{color:#fff; background-color:rgba(255,255,255,.5);}
	.btn-bar a{margin-right:10px;}

	.form-control{box-shadow:none; -webkit-box-shadow:none; border-radius:3px; height:38px;}
	.form-control:focus{outline:none; box-shadow:none; -webkit-box-shadow:none; border-color: #445da8;}

	@media only screen and (max-width: 980px) {

	}


/* Footer (하단메시지)
---------------------------------------------------------------------------------------------------------------------------------------------------------- */
	#footer{padding:50px 20px; width:100%; box-sizing:border-box; text-align:center; background:#24242b; color:#8e8e91;}
	
	.foot_logo{margin-bottom:40px;}

    .footer-menu{margin-top:25px; margin-bottom:15px; font-size:0; line-height:0;}
	.footer-menu li{display:inline-block; margin-left:10px;	padding-left:10px; line-height:8px;	border-left:1px solid #8e8e91; color:#8e8e91;}
	.footer-menu li:first-child{margin-left:0; padding-left:0; border-left:0;}
	.footer-menu li a{line-height:8px; letter-spacing:0; font-weight:400; font-size:14px; color:#8e8e91;}

	.footer-info{margin:0 auto; width:980px; letter-spacing:0; font-size:14px; color:#8e8e91;}
	.footer-info span{color:#6b6b6b;}
	.footer-info > p{margin-top:10px;}

	@media only screen and (max-width:980px) {
		.footer-info{width:100%;}
	}
	@media only screen and (max-width:768px) {
		#footer{padding:35px 10px;}
		.foot_logo{margin-bottom:30px;}
		.foot_logo img{width:200px;}
	}
	@media only screen and (max-width:480px) {
		.footer-menu li{margin-left:6px; padding-left:6px;}
		.footer-menu li a{font-size:13px;}
		.footer-info{font-size:13px;}
	}


/* Main Visual (메인이미지)
---------------------------------------------------------------------------------------------------------------------------------------------------------- */
    .main-visual{z-index:666; width:100%; height:750px; background:url('/images/kor15r-18-0402/main/main_banner_virtual.png') no-repeat 55% bottom/cover;}
	.main-visual > div{padding-top:120px; margin:0 auto; width:1200px;}
	
	.main-visual p{line-height:1.2; color:#FFFFFF; word-break:keep-all;}
	.main-visual p strong{color:#fff;}
	.main-visual p br{display:none;}
    .main-visual .intro-copy{font-size:32px; font-weight:400; margin-bottom:10px;}
	.main-visual .main-copy{margin-bottom:20px; font-family:'Raleway', sans-serif; font-size:60px; font-weight:400;}
	.main-visual .main-copy strong{font-weight:700;}
	.main-visual .sub-copy{font-size:22px;}
	.main-visual .sub-copy strong{font-weight:500;}
    .main-visual .line1{display: flex; align-items: center; flex-wrap: wrap; gap: 8px;}

	@media only screen and (max-width:1200px) {
		.main-visual > div{padding:120px 20px 0; width:100%;}
	}
	@media only screen and (max-width:980px) {
		.main-visual{height:400px;}
		.main-visual > div{padding-top:40px;}

        .main-visual .intro-copy{font-size:23px; margin-bottom:10px;}
		.main-visual .sub-copy{font-size:40px;}
        .main-visual .main-copy{margin-bottom:20px; font-family:'Raleway', sans-serif; font-size:55px; font-weight:400;}
	    .main-visual .main-copy strong{font-weight:2000;}
	}
	@media only screen and (max-width:768px) {
		.main-visual{background-position:65% bottom;}

		.main-visual .intro-copy{font-size:30px; margin-bottom:10px;}
		.main-visual .main-copy{margin-bottom:10px; font-size:43px;}
		.main-visual .sub-copy{font-size:25px;}
        .main-visual .main-copy strong{font-weight:700;}
        .main-visual .main-copy img {height: 40px !important; bottom: 4px !important;}
	}
	@media only screen and (max-width:480px) {
		.main-visual{background-position:75% top;}
		.main-visual > div{padding:25px 10px 0;}

		.main-visual p{text-align:center;}
		.main-visual .intro-copy{font-size:25px;}
		.main-visual .main-copy{margin-bottom:5px; font-size:33px;}
		.main-visual .sub-copy{font-size:20px;}
        .main-visual .main-copy img {height: 30px !important; bottom: 2px !important;}
	}



/* Main Contents (메인 컨텐츠)
---------------------------------------------------------------------------------------------------------------------------------------------------------- */
	.main-contents{background:#f3f3f3;}
	
	/* 퀵배너 3개 */
	.quick-banner{position:relative; top:-70px; margin:0 auto; width:1000px; line-height:0; font-size:0;}
	.quick-banner ul{margin:0 -7.5px;}
	.quick-banner li{position:relative; display:inline-block; margin:0 7.5px; padding-bottom:calc(33.33% - 15px); width:calc(33.33% - 15px); overflow:hidden; text-align:center; background:#fff; border-radius: 20px; box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);}
	.quick-banner li:nth-child(1){background:#fff url('/images/kor15r-18-0402/main/main_icon_1.png') no-repeat center 24%; background-size: 120px auto;}
	.quick-banner li:nth-child(2){background:#fff url('/images/kor15r-18-0402/main/main_icon_2.png') no-repeat center 24%; background-size: 120px auto;}
	.quick-banner li:nth-child(3){background:#fff url('/images/kor15r-18-0402/main/main_icon_3.png') no-repeat center 24%; background-size: 120px auto;}
    .quick-banner .icon-wrapper img {height: 40px; margin-top: 20px;}

	.quick-banner li > div{position:absolute; top:60%; left:0; width:100%; height:40%; border-radius: 16px;}
	.quick-banner .go-link{position:absolute; top:0; left:0; display:block; width:100%; height:100%; text-indent:-9999em; overflow:hidden;}
	.quick-banner .go-link:before{position:absolute; top:0; left:0; content:""; display:block; width:0; height:0; -webkit-transition:all .3s ease-out; -moz-transition:all .3s ease-out; transition:all .3s ease-out;}
	.quick-banner .go-link:after{position:absolute; bottom:0; right:0; content:""; display:block; width:0; height:0; -webkit-transition:all .3s ease-out; -moz-transition:all .3s ease-out; transition:all .3s ease-out;}
	.quick-banner .go-link:hover:before{width:calc(100% + 2px); height:calc(100% + 2px); border-left:5px solid #4664E1; border-top:5px solid #4664E1; border-radius: 20px;}
	.quick-banner .go-link:hover:after{width:calc(100% + 2px); height:calc(100% + 2px); border-right:5px solid #4664E1; border-bottom:5px solid #4664E1; border-radius: 20px;}

	.quick-banner h3{margin-bottom:20px; font-weight:400; font-size:25px; line-height:1; color:#4664E1;}
	.quick-banner p{font-size:17px; line-height:1.4; color:#4664E1;}

	@media only screen and (max-width:1200px) {
		.quick-banner{width:calc(100% - 40px);}

		.quick-banner li:nth-child(1),
		.quick-banner li:nth-child(2),
		.quick-banner li:nth-child(3){background-size:45%;}
	}
	@media only screen and (max-width:980px) {
		.quick-banner h3{margin-bottom:15px; font-size:20px;}
		.quick-banner p{font-size:15px;}
	}
	@media only screen and (max-width:768px) {
		.quick-banner{top:-30px; width:calc(100% - 20px);}
		.quick-banner ul{margin:0 -5px;}
		.quick-banner li{margin:0 5px; padding-bottom:calc(33.33% - 10px); width:calc(33.33% - 10px);}

		.quick-banner h3{margin-bottom:10px; font-size:18px;}
		.quick-banner p{font-size:13px;}
	}
	@media only screen and (max-width:512px) {
		.quick-banner{top:0;}
		.quick-banner ul{margin:0; padding:5px 0;}
		.quick-banner li{margin:5px 0; padding-bottom:100%; width:100%;}

		.quick-banner h3{margin-bottom:20px; font-size:25px;}
		.quick-banner p{font-size:17px;}
	}

	/* Contact Us */
	.contact-us{padding:360px 0; width:100%; background:url('/images/kor15r-18-0402/main/main_contact_bg.png') no-repeat center center/cover;}
	.contact-us h2{text-align:center; font-weight:400; line-height:1; font-size:40px; color:#fff;}
	.contact-us h2 + p{margin:10px 0 50px; text-align:center; font-size:17px; color:#d5d4d6;}
	
	@media only screen and (min-width:1200px) {
		.contact-us > div{margin:0 auto; width:1200px;}
	}
	@media only screen and (max-width:1200px) {
		.contact-us{padding:40px 30px;}
		.contact-us h2{font-size:30px;}
		.contact-us h2 + p{margin:5px 0 30px; font-size:14px;}
	}

/* sns (sns외부링크)
---------------------------------------------------------------------------------------------------------------------------------------------------------- */
 .sns__group {
    display: flex;
    justify-content: flex-end; /* 오른쪽 정렬 */
    gap: 40.5px; /* 아이콘 간격 더 넓게 */
    max-width: 1160px;   /* 고객센터 메뉴와 동일한 콘텐츠 폭 맞춤 */
    margin-top: 10px;
    padding-right: 33px;
  }
  .sns__group a {
    color: var(--gray400, #b0b8c1);
    transition: color 0.1s linear;
  }
  .sns__group a:hover {
    color: var(--secondary, #4664E1);
  }

@media only screen and (max-width:768px) {
		.sns__group {display: flex;
                                 gap: 35px; /* 아이콘 간격 더 넓게 */
                                 max-width: 1160px;   /* 고객센터 메뉴와 동일한 콘텐츠 폭 맞춤 */
                                 margin-top: 10px; margin-bottom: 20px; padding-right: 33px;
  }
}


/* process__buttons (과정신청버튼)
---------------------------------------------------------------------------------------------------------------------------------------------------------- */
.process__button {
  display: flex;
  justify-content: center; /* 가운데 정렬 */
  margin-top: 89px;
}

.process__button a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 342px;
  padding: 12px 40px;
  border-radius: 90px;
  background: var(--primary, #4664E1);
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  transition: background 0.3s;
}

.process__button a:hover {
  background: #2f4fc4;
}

.process__button_2 {
  display: flex;
  justify-content: center; /* 가운데 정렬 */
  margin-top: 89px;
}

.process__button_2 a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 342px;
  padding: 12px 40px;
  border-radius: 90px;
  background: var(--primary, #4664E1);
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  transition: background 0.3s;
}

.process__button_2 a:hover {
  background: #2f4fc4;
}
/* supports (하단바로가기)
---------------------------------------------------------------------------------------------------------------------------------------------------------- */
#supports {
/*background: var(--white, #ffffff);*/
}
#supports .section__inner {
  padding: 32px 32px 56px;
}
.supports__logos {
  display: flex;
  justify-content: center;
  gap: 12px;
}
.supports__logos .logo {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 160px;
  height: 64px;
  padding: 18px 28px;
  background: var(--white, #ffffff);
  border-radius: 6px;
  border: 1px solid var(--gray200, #e5e8eb);
}
.supports__logos .logo img.hover {
  display: none;
}

@media (min-width: 800px) {
  #supports .section__inner {
    padding: 56px 85px 120px;
  }
  .supports__logos {
    gap: 24px;
  }
  .supports__logos .logo {
    position: relative;
    width: 320px;
    height: 128px;
    padding: 40px 72px;
    border-radius: 12px;
  }
  .supports__logos .logo img {
    position: absolute;
    width: 176px;
  }
}
@media (min-width: 1200px) {
  #supports .section__inner {
    padding: 56px 60px 120px;
  }
  .supports__logos .logo img {
    opacity: 1;
  }
  .supports__logos .logo img.hover {
    display: block;
  }
  .supports__logos .logo:hover img {
    opacity: 0;
  }
  .supports__logos .logo:hover img.hover {
    opacity: 1;
  }
}

/* banner (메인배너)
---------------------------------------------------------------------------------------------------------------------------------------------------------- */
.swiper {
  width: 100%;
  height: 300px;
}
.swiper-slide {
  text-align: center;
  font-size: 18px;
  background: #eee;
  display: flex;
  justify-content: center;
  align-items: center;
}
.swiper-slide img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

/* map (지도)
---------------------------------------------------------------------------------------------------------------------------------------------------------- */

.responsive-map {
  width: 100%;
  height: auto;
  display: block;
  max-width: 100%;
}

/* equipment (장비소개)
---------------------------------------------------------------------------------------------------------------------------------------------------------- */

.benefits__group {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px;
}
.benefits__group .benefits__card {
  flex: 1;
  flex-basis: calc(50% - 12px);
  padding: 80px 20px;
  background: #eef2ff;
  border-radius: 20px;
  text-align: center;
}
.benefits__card .icon {
  width: 160px;
  margin: 0 auto;
  margin-bottom: 16px;
}
.benefits__card .text {
  font-size: 16px;
  font-weight: 500;
  line-height: 1.4;
  color: var(--gray800, #333d4b);
}
.benefits__card .text_info {
  font-size: 14px;
  font-weight: 500;
  line-height: 1.4;
  margin-top: 24px;
  color: var(--gray800, #333d4b);
  }
}
@media (min-width: 800px) {
  #benefitsAndRecruitmentGuide .section__inner {
    padding: 160px 48px 180px;
  }
  .benefits__text {
    margin-bottom: 32px;
    font-size: 24px;
  }
  .benefits__group {
    gap: 16px;
  }
  .benefits__group .benefits__card {
    flex: none;
    flex-basis: 235px;
    padding: 56px 28px;
    border-radius: 24px;
  }
  .benefits__card .icon {
    width: 160px;
    margin-bottom: 24px;
  }
  .benefits__card .text {
    font-size: 18px;
    line-height: 1.5;
  }
.benefits__card .text_info {
  font-size: 14px;
  font-weight: 500;
  line-height: 1.4;
  color: var(--gray800, #333d4b);
  }
}
@media (min-width: 1200px) {
  #benefitsAndRecruitmentGuide .section__inner {
    padding: 200px 60px 220px;
  }
  .benefits__text {
    margin-bottom: 48px;
  }
  .benefits__group {
    gap: 24px;
  }
  .benefits__group .benefits__card {
    flex-basis: 280px;
    padding: 80px 20px;
  }
}

/* curriculum (교육과정소개)
---------------------------------------------------------------------------------------------------------------------------------------------------------- */

.curriculum__group {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px;
}
.curriculum__group .curriculum__card {
  flex: 1;
  flex-basis: calc(50% - 12px);
  padding: 80px 20px;
  background: #ffffff;
  border-radius: 40px;
  text-align: center;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
}
.curriculum__card .icon {
  width: 1160px;
  margin: -10px auto;
  margin-bottom: 15px;
  border-radius: 20px;
}
.curriculum__card .text {
  font-size: 16px;
  font-weight: 500;
  line-height: 1.4;
  color: var(--gray800, #333d4b);
}
.curriculum__card .text_info {
  font-size: 14px;
  font-weight: 500;
  line-height: 1.4;
  margin-top: 24px;
  color: var(--gray800, #333d4b);
  }
}
@media (min-width: 800px) {
  #curriculumAndRecruitmentGuide .section__inner {
    padding: 160px 48px 180px;
  }
  .curriculum__text {
    margin-bottom: 32px;
    font-size: 24px;
  }
  .curriculum__group {
    gap: 16px;
  }
  .curriculum__group .curriculum__card {
    flex: none;
    flex-basis: 235px;
    padding: 56px 28px;
    border-radius: 24px;
  }
  .curriculum__card .icon {
    width: 160px;
    margin-bottom: 24px;
  }
  .curriculum__card .text {
    font-size: 18px;
    line-height: 1.5;
  }
.curriculum__card .text_info {
  font-size: 14px;
  font-weight: 500;
  line-height: 1.4;
  color: var(--gray800, #333d4b);
  }
}
@media (min-width: 1200px) {
  #curriculumAndRecruitmentGuide .section__inner {
    padding: 200px 60px 220px;
  }
  .curriculum__text {
    margin-bottom: 48px;
  }
  .curriculum__group {
    gap: 24px;
  }
  .curriculum__group .curriculum__card {
    flex-basis: 280px;
    padding: 33px 20px;
    padding-bottom: 210px;
  }

  .curriculum__card .intro-copy{font-size:32px; font-weight:400; margin-bottom:10px;}
.curriculum__card .main-copy{margin-bottom:20px; font-family:'Raleway', sans-serif; font-size:24px; font-weight:700; text-align:left;}
	.curriculum__card .main-copy strong{font-weight:700;}
	.curriculum__card .sub-copy{font-size:18px; text-align:left; font-weight:500;}
	.curriculum__card .sub-copy strong{font-size:20px; text-align:left; font-weight:700;}
    .curriculum__card .line1{display: flex; align-items: center; flex-wrap: wrap; gap: 8px;}
}

/* 교육 내용 및 일정
---------------------------------------------------------------------------------------------------------------------------------------------------------- */
#trainingContentsAndSchedule {
  background: var(--white, #ffffff);
}
#trainingContentsAndSchedule .section__inner {
  padding: 80px 24px 88px;
}
#trainingContentsAndSchedule .sec__title {
  margin-bottom: 32px;
}
#trainingContentsAndSchedule .sec__contents {
  position: relative;
}
.training__select--button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 14px 20px 14px 28px;
  margin-bottom: 24px;
  gap: 32px;
  border-radius: 90px;
  background: var(--primary, #4664e1);
}
.training__select--button p {
  text-align: left;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.4;
  color: var(--white, #ffffff);
}
.training__select--button.active {
  background: var(--primaryDark, #4664e1);
}
.training__select--button.active .arrow {
  transform: rotate(180deg);
}
.training__select--button.active + .training__tabs {
  display: block;
}
.training__tabs {
  display: none;
  position: absolute;
  width: 100%;
  margin-top: -12px;
  border-radius: 20px;
  background: var(--white, #ffffff);
  box-shadow: 2px 4px 16px 0px rgba(0, 0, 0, 0.15);
}
.training__tab {
  padding: 16px 28px;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.4;
  color: var(--gray600, #6b7684);
}
.training__tab br {
  display: block;
}
.training__tab:not(:last-child) {
  border-bottom: 1px solid var(--gray200, #e5e8eb);
}
.training__tab.active {
  background: var(--primary, #4664e1);
  font-weight: 700;
  color: var(--white, #ffffff);
}
.training__tab__contents {
  display: none;
}
.training__tab__contents.active {
  display: block;
}
.training__cards {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 16px;
}
.curriculum__card {
  padding: 32px 24px;
  border-radius: 20px;
  background: var(--purple100, #edeeef);
}
.curriculum__card .card__title {
  margin-bottom: 24px;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.4;
  color: var(--primary, #4664e1);
}
.curriculum__card .info:not(:last-child) {
  margin-bottom: 24px;
}
.curriculum__card .info__title {
  margin-bottom: 8px;
  font-size: 16px;
  font-weight: 500;
}
.curriculum__card .info__contents {
  font-size: 14px;
  font-weight: 500;
  color: var(--gray700, #4e5968);
}
.curriculum__card .info__contents li::before {
  content: "·";
}
.curriculum__card .tool {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 4px;
  background: var(--secondary, #8f83ff);
  font-size: 14px;
  font-weight: 500;
  color: var(--white, #ffffff);
}

@media (min-width: 800px) {
  #trainingContentsAndSchedule .section__inner {
    padding: 160px 48px 180px;
  }
  #trainingContentsAndSchedule .sec__title {
    margin-bottom: 56px;
  }
  .training__select--button {
    padding: 30px 40px;
    margin-bottom: 40px;
    gap: 40px;
  }
  .training__select--button p {
    font-size: 20px;
  }
  .training__tabs {
    margin-top: -24px;
  }
  .training__tab {
    padding: 24px 40px;
    font-size: 16px;
  }
  .training__tab br {
    display: none;
  }
  .training__cards {
    gap: 24px;
    margin-top: 16px;
  }
  .curriculum__card {
    padding: 40px;
    border-radius: 24px;
  }
  .curriculum__card .card__title {
    margin-bottom: 32px;
    font-size: 22px;
  }
  .curriculum__card .info__title {
    font-size: 18px;
  }
  .curriculum__card .info__contents {
    font-size: 16px;
  }
  .curriculum__card .tool {
    margin-top: 16px;
    font-size: 16px;
  }
}
@media (min-width: 1200px) {
  #trainingContentsAndSchedule .section__inner {
    padding: 8px 60px 220px;
  }
  .training__select--button {
    display: none;
  }
  .training__select--button.active + .training__tabs {
    display: flex;
  }
  .training__tabs {
    display: flex;
    position: relative;
    min-height: 120px;
    gap: 10px;
    margin-top: 0;
    margin-bottom: 40px;
    padding: 8px;
    border-radius: 999px;
    background: var(--gray100, #f2f4f6);
    box-shadow: none;
  }
  .training__tab {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 8px 16px;
    border-radius: 999px;
    text-align: center;
    font-size: 20px;
    font-weight: 500;
    background: var(--gray100, #f2f4f6);
    color: var(--gray500, #8b95a1);
    cursor: pointer;
    transition: background 0.3s, color 0.3s;
  }
  .training__tab br {
    display: block;
  }
  .training__tab:not(:last-child) {
    border-bottom: none;
  }
  .training__tab.active {
    display: flex;
    background: var(--primary, #4664e1);
    font-weight: 700;
    color: var(--white, #ffffff);
    box-shadow: 2px 2px 15px 0px rgba(0, 0, 0, 0.2);
  }
  .training__tab:not(.active):hover {
    background: var(--gray50, #f9fafb);
  }
  .training__cards {
    flex-direction: row;
    gap: 16px;
    margin-top: 16px;
  }
  .curriculum__card {
    flex: 1;
  }
}

/* banner (배너)
---------------------------------------------------------------------------------------------------------------------------------------------------------- */

#mainBanner {
  padding-top: 0px;
  background: var(--primary, #000);
}
#mainBanner .section__inner {
  position: relative;
  width: 100%;
  height: 399px;
}
.banner__swiper {
  width: 100%;
  height: 100%;
  max-width: 1920px;
  margin: 0 auto;
}
.banner__swiper .swiper-slide {
  position: relative;
  color: var(--white, #ffffff);
}
.banner__swiper .swiper-slide .slide__contents {
  width: 100%;
  height: 100%;
  padding: 72px 32px;
  margin: 0 auto;
}
.banner__swiper .slide__title {
  margin-bottom: 12px;
  font-size: 32px;
  font-weight: 700;
  line-height: 1.3;
}
.banner__swiper .slide__title .line1 {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}
.banner__swiper .slide__title img {
  display: inline-block;
  width: 80px;
}
.banner__swiper .slide__text {
  margin-bottom: 24px;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.4;
}
.banner__swiper .slide__link__btn {
  display: inline-block;
  padding: 10.5px 28px;
  border-radius: 999px;
  border: 1.5px solid var(--white, #ffffff);
  font-size: 16px;
  font-weight: 700;
}

.banner__swiper .slide__01 {
  background-image: url("../images/home/loop3.gif");
  background-size: calc(100% - 28px) auto;
  background-repeat: no-repeat;
  background-position: center calc(100% - 42px);import!
}

.banner__swiper .slide__02 {
  background-image: url("../images/home/loop2.gif");
  background-size: calc(100% - 28px) auto;
  background-repeat: no-repeat;
  background-position: center calc(100% - 42px);
}

.banner__swiper .slide__03 {
  /* background-image: url("../images/home/main_banner_03.png"); */
  background-size: calc(100% - 28px) auto;
  background-repeat: no-repeat;
  background-position: center calc(100% - 42px);
}

.swiper {
  height: 100%;
}
.pagination__bullets {
  position: absolute;
  left: auto !important;
  right: 32px !important;
  bottom: 330px !important;
  width: auto !important;
  display: flex;
  align-items: center;
  gap: 8px;
  text-align: left;
}
.pagination__bullets > .bullet {
  width: 6px;
  height: 6px;
  margin: 0 !important;
  background: rgba(255, 255, 255, 0.4);
}
.pagination__bullets > .bullet.swiper-pagination-bullet {
  background: var(--white, #ffffff) !important;
}
.banner__swiper .swiper-slide .slide__contents{
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  padding: 72px 50px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.banner__swiper .slide__text{
  font-size: 17px;
}
.banner-video{
  height: 100%;
  object-fit: cover;
}

/* 기본: 모바일/태블릿에서는 화살표 숨김 */
.banner__btn {
  display: none !important;
}

@media (min-width: 600px) {
  .banner__swiper .slide__01 {
    background-size: 520px auto;
    background-position: calc(100% - 48px) bottom;
  }
  .banner__swiper .slide__02 {
    background-size: 520px auto;
    background-position: calc(100% - 48px) calc(100% - 56px);
  }
}
@media (min-width: 800px) {
  #mainBanner {
    padding-top: 0px;
  }
  #mainBanner .section__inner {
    height: 400px;
  }
  .banner__swiper .swiper-slide .slide__contents {
    padding: 80px 48px;
  }
  .banner__swiper .slide__title {
    margin-bottom: 20px;
    font-size: 50px;
  }
  .banner__swiper .slide__title .line1 {
    gap: 16px;
  }
  .banner__swiper .slide__title img {
    width: 136px;
  }
  .banner__swiper .slide__text {
    margin-bottom: 40px;
    font-size: 20px;
  }
  .banner__swiper .slide__link__btn {
    margin-bottom: 50px;
    padding: 14px 40px;
    font-size: 18px;
  }

  .pagination__bullets {
    left: 48px !important;
    right: auto !important;
    bottom: 310px !important;
  }
  .banner__swiper .swiper-slide .slide__contents{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  .banner-video{
    height: 100%;
    object-fit: cover;
  }
}
@media (min-width: 1200px) {
  #mainBanner {
    padding-top: 0;
  }
  #mainBanner .section__inner {
    height: 750px;
  }
  .banner__swiper .swiper-slide {
    padding: 0;
  }
  .banner__swiper .swiper-slide .slide__contents {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    max-width: 1440px;
    padding: 0 60px;
  }
  .banner__swiper .swiper-slide .slide__contents{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  .banner-video{
    height: 101%;
    object-fit: cover;
  }
  
  .banner__swiper .slide__title {
    font-size: 56px;
  }
  .banner__swiper .slide__title .line1 {
    gap: 12px;
  }
  .banner__swiper .slide__title img {
    width: 148px;
  }
  .banner__swiper .slide__text {
    font-size: 22px;
  }
  .banner__swiper .slide__link__btn {
    transition: background 0.3s, color 0.3s;
  }
  .banner__swiper .slide__link__btn:hover {
    background: var(--white, #ffffff);
    color: var(--primary);
  }
  .banner__swiper .slide__link__btn:focus,
  .banner__swiper .slide__link__btn:active {
    background: var(--purple300, #eee8ff);
    color: var(--primary, #6706d3);
  }
  .banner__swiper .slide__01 {
    background-size: 840px auto;
    background-position: calc(50% + 340px) bottom;
  }
  .banner__swiper .slide__02 {
    background-size: 840px auto;
    background-position: calc(50% + 340px) calc(100% - 106px);
  }

  .pagination__bullets {
    left: 60px !important;
    bottom: 130px !important;
  }

  /*

/* 모집 개요 */
#recruitmentOverview {
  background: var(--purple200, #f5f4ff);
}
#recruitmentOverview .section__inner {
  padding: 80px 24px 88px;
}
#recruitmentOverview .sec__title {
  margin-bottom: 28px;
}
.recruit__group {
  display: flex;
  flex-direction: column;
  gap: 24px;
  margin-bottom: 84px;
}
.recruit__group .recruit__card {
  padding: 32px 24px;
  border-radius: 20px;
  background: var(--white, #ffffff);
  box-shadow: 8px 10px 14px 0px #e9e7f7;
}
.recruit__card .recruit__card__title {
  font-family: "MBC NEW", sans-serif;
  letter-spacing: -0.02em;
  margin-bottom: 20px;
}
.recruit__card__title .icon {
  width: 40px;
  margin-bottom: 12px;
}
.recruit__card__title p {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.4;
  color: var(--gray900, #191f28);
}
.recruit__card__body li {
  position: relative;
  padding-left: 12px;
  font-size: 16px;
  line-height: 1.4;
  color: var(--gray700, #4e5968);
  word-break: keep-all;
}
.recruit__card__body li:before {
  content: "";
  position: absolute;
  top: 10px;
  left: 0;
  width: 4px;
  height: 4px;
  border-radius: 999px;
  background: var(--gray700, #4e5968);
}
.recruit__card__body li:not(:last-child) {
  margin-bottom: 16px;
}
.recruit__card__body li span.text__sm {
  font-size: 13px;
  color: var(--gray500, #8b95a1);
}

.edu-swiper {
  overflow: hidden;
}
.edu-swiper__thumbs {
  margin-bottom: 16px;
}
.edu-swiper__thumbs .edu-swiper__tab {
  width: auto;
  padding: 6px 16px;
  border-radius: 90px;
  border: 1px solid var(--gray200, #e5e8eb);
  background: var(--white, #ffffff);
  font-family: "MBC NEW", sans-serif;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: -0.02em;
  color: var(--gray600, #6b7684);
  white-space: nowrap;
}
.edu-swiper__thumbs .edu-swiper__tab.swiper-slide-thumb-active {
  border-color: var(--primary, #6706d3);
  background: var(--primary, #6706d3);
  font-weight: 700;
  color: var(--white, #ffffff);
}

.edu-swiper__contents .text__chat {
  display: flex;
  align-items: center;
  margin-bottom: 20px;
  padding: 7.5px 12px;
  border-radius: 6px;
  border: 1px solid var(--purple400, #e2d8fe);
  background: var(--purple300, #eee8ff);
  word-break: keep-all;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.5;
  color: var(--primary, #6706d3);
}

.edu__info:not(:last-child) {
  margin-bottom: 24px;
  text-align: center;
}
.edu__info .info__label_2 {
  margin-bottom: 6px;
  font-family: "MBC NEW", sans-serif;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: -0.02em;
  text-align: center;!important;
}
.edu__info .info__label {
  margin-top: 10px;
  margin-bottom: 4px;
  font-family: "MBC NEW", sans-serif;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: -0.02em;
  text-align: left;
}
.edu__info .info__label_schedule {
  margin-top: 20px;
  margin-bottom: 20px;
  font-family: "MBC NEW", sans-serif;
  font-size: 20px;
  font-weight: 700;
  text-align: center;
  line-height: 1.4;
  letter-spacing: -0.02em;
  color: var(--primary, #6706d3);
}
.edu__info .info__intro {
  margin-top: 15px;
  margin-bottom: 10px;
  font-family: "MBC NEW", sans-serif;
  font-size: 22px;!important;
  font-weight: 600;
  text-align: center;
  line-height: 1.3;
  letter-spacing: -0.02em;
  color: var(--primary, #6706d3);
}
.edu__info .info__intro_small {
  margin-top: 2px;
  margin-bottom: 10px;
  font-family: "MBC NEW", sans-serif;
  font-size: 12px;!important;
  font-weight: 600;
  text-align: center;
  line-height: 1.3;
  letter-spacing: -0.02em;
  color: var(--primary, #6706d3);
}
.edu__info .info__contents {
  font-size: 16px;
  font-weight: 500;
  line-height: 1.4;
  color: var(--gray700, #4e5968);
  text-align: left;
}
.edu__info .info__contents_2 {
  font-size: 16px;
  font-weight: 500;
  line-height: 1.4;
  text-align: center;
  color: var(--gray700, #4e5968);
}

.recruit__benefits__title {
  margin-bottom: 24px;
  font-size: 24px;
  font-weight: 500;
  line-height: 1.4;
  text-align: center;
  color: var(--gray900, #191f28);
}
.recruit__benefits__list {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 12px;
}
.recruit__benefits__list .card {
  padding: 28px 20px;
  border-radius: 20px;
  background: linear-gradient(180deg, #9036ea 0%, #6706d3 100%);
  text-align: center;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.4;
  color: var(--white, #ffffff);
}
.recruit__benefits__list .card p.text__sm {
  margin-top: 4px;
  font-family: "SUIT", sans-serif;
  font-size: 13px;
  font-weight: 500;
  color: var(--gray200, #e5e8eb);
}
@media (min-width: 800px) {
  #recruitmentOverview .section__inner {
    padding: 160px 48px 180px;
  }
  #recruitmentOverview .sec__title {
    margin-bottom: 56px;
  }
  .recruit__group {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    gap: 16px;
    margin-bottom: 120px;
  }
  .recruit__group .recruit__card {
    width: calc(50% - 10px);
    max-width: 480px;
    padding: 40px 24px;
    border-radius: 24px;
  }
  .recruit__card__body li {
    font-size: 18px;
  }
  .recruit__card__body li span.text__sm {
    font-size: 14px;
  }
  .edu-swiper__contents .text__chat {
    padding: 4px 12px;
    font-size: 16px;
  }
  .edu__info:not(:last-child) {
    margin-bottom: 20px;
  }
  .edu__info .info__label {
    margin-bottom: 4px;
  }
  .edu__info .info__contents {
    font-size: 18px;
  }
  .recruit__benefits__title {
    margin-bottom: 40px;
    font-size: 32px;
    line-height: 1.3;
  }
  .recruit__benefits__list {
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }
  .recruit__benefits__list .card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 128px;
    border-radius: 24px;
    font-size: 20px;
  }
  .recruit__benefits__list .card p.text__sm {
    margin-top: 4px;
    font-size: 16px;
  }
}
@media (min-width: 1200px) {
  #recruitmentOverview .section__inner {
    padding: 200px 60px 220px;
  }
  .recruit__group {
    column-gap: 24px;
    row-gap: 20px;
  }
  .recruit__group .recruit__card {
    width: calc(50% - 12px);
    padding: 40px 32px;
  }
  .edu-swiper__thumbs {
    margin-bottom: 18px;
  }
  .recruit__benefits {
    display: flex;
    justify-content: space-between;
    gap: 24px;
  }
  .recruit__benefits__title {
    margin-bottom: 0;
    text-align: left;
  }
  .recruit__benefits__list {
    width: 100%;
    max-width: 976px;
  }
  .edu-swiper__thumbs .edu-swiper__tab:hover {
    border: 1px solid var(--gray600, #6b7684);
    cursor: pointer;
  }
}


		