/* 인사말 */
.ceo_message { position: relative; max-width: 1400px; }
.ceo_message .img { position: relative; height: 550px; background: url(../img/bg_ceo_message.jpg) no-repeat 50%; background-size: cover; }
.ceo_message .tit { position: absolute; top: 30px; right: 100px; width: 514px; padding: 70px; background: #000; }
.ceo_message .tit:before { content: ""; display: block; position: absolute; top: -23px; left: 50px; width: 1px; height: 80px; margin: 0; background: #fff; }
.ceo_message .tit h2 { color: #fff; font-size: 32px; font-weight: 500; margin-bottom: 20px; text-align: left; letter-spacing: 3px; }
.ceo_message .tit h5 { position: relative; margin: 0; color: #fff; font-size: 20px; font-weight: 500; opacity: 0.8; line-height: 1.6; word-break: keep-all; box-sizing: border-box; text-align: left; }
.ceo_message .tit h5 span { display: block; font-weight: 600; }
.ceo_message .colum { padding: 50px 20px 70px 20px; max-width: 1100px; margin: 0 auto; }
.ceo_message .colum:after { clear: both; content: ""; display: block; }
.ceo_message .colum .left { float: left; width: 70%; text-align: justify; }
.ceo_message .colum .right { float: right; width: 48%; text-align: justify; }
.ceo_message .sign { text-align: right; font-size: 1.125em; font-weight: bold; color: #222; margin-top: 60px; padding-right: 20px; background-repeat: no-repeat; background-position: right center; line-height: 50px; }
.ceo_message .sign .name { font-size: 24px; }

@media (max-width: 980px) {
  .ceo_message .tit { position: relative; width: 100%; height: auto; padding: 50px; top: 0; right: 0; }
  .ceo_message .tit h2 { font-size: 32px; }
  .ceo_message .img { height: 253px; }
  .ceo_message .img:before { left: 50%; width: 300px; height: 310px; margin-left: -150px; background-size: cover; }
  .ceo_message .colum .left { width: 100%; clear: both; }
  .ceo_message .colum .right { width: 100%; padding-top: 20px; clear: both; }
}
/* 인사말 */


/* 주요업무 */
.major .copy { font-size: 32px; line-height: 1.4; word-break: keep-all; max-width: 550px; font-weight: 500; margin-bottom: 20px; }
.major .sub_copy { font-size: 20px; color: #555; font-weight: 400; line-height: 1.65; word-break: keep-all; }
.major p { font-size: 20px; color: #555; font-weight: 400; line-height: 1.65; word-break: keep-all; }
.major_business { justify-content: space-between; width: 100%; height: auto; max-width: 1400px; flex-wrap: wrap; padding: 0 20px; }
.major_business h2 { font-size: 24px; text-align: left; margin-bottom: 30px; }
.business_box { margin: 0 auto 85px; padding: 50px 45px; background: #f2f5f7; border-top: 2px solid #006; }
.business_box ul { list-style: none; padding: 0; }
.business_box ul li { font-size: 20px; margin-bottom: 15px; line-height: 1.5; position: relative; }
.business_box ul li:before { position: absolute; top: 3px; margin: 8px 0 0 -12px; vertical-align: middle; display: inline-block; width: 4px; height: 4px; background: #3e9ed6; border-radius: 4px; content: ""; }
/* 주요업무 */


/* 연혁 */
.history_area {position: relative;width: 100%;padding-top: 37px;}
.history_area .history_point {position: absolute;left: 50%;top: 0;margin-left: -5px;bottom: 20px;width:8px;background-color: #f6f6f6;overflow: hidden;}
/*.history_area .history_point span {position: absolute;display: block;top: 0;width: 100%;height: 200px; background-color:#039}*/
.history_area dl {width: 50%;padding-right: 94px;padding-left: 20px;box-sizing:border-box;}
.history_area div:nth-child(odd) dl {padding-right: 20px;padding-left: 94px;}
.history_area dt {margin-bottom: 20px;font-size: 46px;line-height:1.3;color: #555;font-weight: bold;}
.history_area dd strong {display: block;padding-bottom: 12px;font-size: 20px;line-height: 1.6;color: #1a1a1a;font-weight: 500;}
.history_area dd p {display: block;}
.history_area dd .img_box {display: block;margin-top: 39px;}
.right {text-align: right;}
.left {text-align: left;}
.fr {float: right;}
.img_box img { max-width: 100%}

@media (max-width: 769px){
	.history_area .history_point {left: 10px;margin-left: 0;}
	.history_area dl {float: none !important;width: 100%;padding-right: 0;padding-left: 50px;text-align: left;}
	.history_area div:nth-child(odd) dl {/* padding-right: 0; */padding-left: 50px;}
	.history_area div + div {margin-top: 40px;}
	.history_area div:nth-child(2) {margin-top: 0;}
	.history_area dt {margin-bottom: 20px;font-size:30px;}
	.history_area dd p br {display: none;}
	.history_area dd .img_box {margin-top: 20px;}	
}
/* 연혁 */


/* 오시는 길 */
.navi_tab { clear: both; width: 100%; height: 100px; padding: 50px 0 200px; clear: both; box-sizing: border-box; }
.navi_tab li { width: 50%; float: left; height: 70px; margin-top: -1px; margin-right: -1px; overflow: hidden; }
.navi_tab_group li { width: 50%; }
.navi_tab li a { text-align: center; color: #808080; line-height: 70px; font-size: 17px; display: block; height: 70px; width: 100%; background-color: #fff; border: 1px solid #ccc; transition: all 0.3s ease; }
.navi_tab li:last-child { border-right: 0; margin-right: 0; }
.navi_tab li a.on { color: #fff; background-color: #297fea; height: 70px; border: 1px solid #297fea; box-shadow: 0 15px 15px rgba(65, 71, 143, 0.2); }

#map_view { margin-top: 100px; }
#map_view h2 { color: #000; }
#map_view p { color: #555; }
.map_info { width: 343px; height: 274px; background: #000; position: absolute; left: 0; top: 0px; padding: 40px 38px; box-sizing: border-box; font-size: 20px; color: #555; letter-spacing: 0; }
.map_info h2 { display: block; font-size: 22px; color: #fff; font-weight: bold; letter-spacing: -0.25px; }
.map_info p { padding-top: 20px; color: #f2f2f2; line-height: 1.4; }
.map_btn { position: absolute; left: 38px; bottom: 40px; }
.map_btn a { display: inline-block; padding: 10px 20px; box-sizing: border-box; border: 1px solid #797979; text-align: center; font-size: 16px; color: #fff; letter-spacing: -0.5px; -webkit-transition: all 0.5s ease; -moz-transition: all 0.5s ease; -o-transition: all 0.5s ease; transition: all 0.5s ease; }
.map_btn a:hover { color: #000; background: #fff; border-color: 333; text-decoration: none; -webkit-transition: all 0.5s ease; -moz-transition: all 0.5s ease; -o-transition: all 0.5s ease; transition: all 0.5s ease; }

.contact_address { width: 100%; height: auto; line-height: 1.7; }
.contact_address ul { max-width: 1240px; clear: both; padding: 0 20px 20px 0px; border-bottom: 1px solid #ddd; }
.contact_address ul li { color: #555; margin-top: 5px; margin-bottom: 5px; font-size: 16px; }
.contact_traffic { max-width: 1600px; margin: 100px auto; padding: 20px; letter-spacing: -0.8px; clear: both; }
.contact_traffic:after { content: " "; visibility: hidden; display: block; height: 0; padding-bottom: 50px; clear: both; }
.contact_traffic ul { border-bottom: 1px solid #ddd; padding-bottom: 25px; }
.contact_traffic .bus { width: 100%; }
.contact_traffic .subway { width: 100%; }
.contact_traffic ul li { color: #555; line-height: 33px; font-size: 16px; }
.contact_traffic h3 { font-size: 20px; font-weight: 400; letter-spacing: -1px; color: #1a1a1a; padding-bottom: 10px; margin-top: 25px; text-align: left; }

@media all and (max-width: 576px) {
  .map_area .txt { position: relative; bottom: auto; left: auto; transform: translateX(0); margin-top: -30px; width: auto; }
  .map_area .txt .logo img { height: 20px; }
  .map_area .txt .contact { font-size: 13px; letter-spacing: 0; line-height: 180%; padding: 20px 0 0; text-align: center; clear: both; }
  .map_area .txt .txt_wrap { border-radius: 0px 0px 20px 0px; margin: 0 15px; padding: 0 0 30px; }
  .map_area .txt .bt { position: static; border-radius: 65px; border-width: 2px; font-size: 15px; margin: 25px auto 0; width: 150px; line-height: 40px; height: 40px; }
  .map_area .txt .logo { position: relative; display: block; top: auto; left: auto; border-right: 0; width: 100%; line-height: 70px; height: 70px; }
}

@media all and (min-width: 577px) and (max-width: 992px) {
  .map_area .txt { position: relative; bottom: auto; left: auto; transform: translateX(0); margin-top: -30px; width: auto; }
  .map_area .txt .logo img { height: 20px; }
  .map_area .txt .contact { font-size: 13px; letter-spacing: 0; line-height: 180%; padding: 20px 0 0; text-align: center; clear: both; }
  .map_area .txt .txt_wrap { border-radius: 0px 0px 20px 0px; margin: 0 15px; padding: 0 0 30px; }
  .map_area .txt .bt { position: static; border-radius: 65px; border-width: 2px; font-size: 15px; margin: 25px auto 0; width: 150px; line-height: 40px; height: 40px; }
  .map_area .txt .logo { position: relative; display: block; top: auto; left: auto; border-right: 0; width: 100%; line-height: 70px; height: 70px; }
}

@media all and (min-width: 993px) and (max-width: 1200px) {
  .map_area .txt { margin-top: -30px; width: 1024px; }
  .map_area .txt .txt_wrap { border-radius: 0px 0px 20px 0px; margin: 0 15px; padding: 0 0 30px; }
  .map_area .txt .logo { display: block; position: relative; top: auto; left: auto; border-right: 0; margin-left: 0; width: 100%; }
  .map_area .txt .logo:before { content: ""; position: absolute; bottom: 0; left: 50%; margin-left: -88px; background-color: #1a7dd3; width: 177px; height: 1px; }
  .map_area .txt .contact { line-height: 180%; padding: 20px 0 0; text-align: center; }
  .map_area .txt .contact .tel { font-weight: 300; }
  .map_area .txt .bt { position: static; border-radius: 65px; margin: 35px auto 0; width: 150px; }
}
/* 오시는 길 */


/* 3단 서브메뉴2 */
.tree_menu02 .box_wrap { width: 100%; display: flex; justify-content: space-between; flex-wrap: wrap; margin-top: 50px; }
.tree_menu02 .box_wrap .photo_box { width: 48%; }
.tree_menu02 .box_wrap .photo01 .txt_wrap h1 { font-size: 32px; font-weight: 500; padding: 0 0; }
.tree_menu02 .box_wrap .photo01 .txt_wrap h2 { font-size: 30px; font-weight: 500; padding: 60px 0 0; }
.tree_menu02 .box_wrap .photo01 .txt_wrap .sub_txt { font-size: 18px; padding: 10px 0 50px 0; font-weight: 300; }
.tree_menu02 .box_wrap .photo01 .txt_wrap p { font-size: 18px; color: #555; font-weight: 300; padding: 50px 0 20px 0; line-height: 1.6; }

.tree_menu02 .sub_box_wrap { width: 100%; display: flex; justify-content: space-between; flex-wrap: wrap; margin-top: 50px; }
.tree_menu02 .sub_box_wrap .small_box { width: 23%; margin: 0 auto 20px auto; }
.tree_menu02 .box_wrap .small_box02 { width: 31.5%; padding-bottom: 30px; }
.tree_menu02 .box_wrap .small_box02 h2 { text-align: center; font-size: 18px; font-weight: 500; padding: 20px 0 0; }

@media screen and (max-width: 960px) {
  .tree_menu02 .box_wrap .photo_box { width: 100%; }
  .tree_menu02 .sub_box_wrap .small_box { width: 48%; margin-bottom: 4%; }
  .tree_menu02 .box_wrap .small_box02 { width: 100%; }
}
/* 3단 서브메뉴2 */


/* 3단 서브메뉴3 */
.tree_menu03 .wrap { width: 100%; display: flex; justify-content: space-between; flex-wrap: wrap; }
.tree_menu03 .wrap .box { width: 49%; }
.tree_menu03 .small_box_wrap { width: 100%; display: flex; justify-content: space-between; flex-wrap: wrap; }
.tree_menu03 .small_box_wrap .small_box { width: 49%; margin-bottom: 2%; }
.tree_menu03 .wrap_clearfix h2 { text-align: center; font-size: 32px; padding: 50px 0 0; margin: 0; }
.tree_menu03 .wrap_clearfix p { text-align: center; padding: 10px 0 50px 0; font-size: 18px; }
.tree_menu03 .wrap .icon { width: 23.9%; padding: 70px 20px 60px 20px; margin: auto 0; border: 1px solid #ddd; }
.tree_menu03 .wrap .icon .clearfix { text-align: center; font-size: 18px; }
.tree_menu03 .wrap .icon i { text-align: center; font-size: 28px; display: block; vertical-align: middle; }
.tree_menu03 .wrap .icon i:before { width: 80px; height: 80px; background-color: #f5f5f5; padding: 20px; border-radius: 50px; }
.tree_menu03 .wrap .icon h2 { padding: 40px 0 10px 0; font-size: 22px; }
.tree_menu03 .wrap .icon p { text-align: center; color: #555; font-size: 18px; line-height: 1.6; }

@media screen and (max-width: 960px) {
  .tree_menu03 .wrap .box { width: 100%; }
  .tree_menu03 .wrap .icon { width: 48%; margin-bottom: 4%; }
}
/* 3단 서브메뉴3 */


/* content01 */
.content01 { width: 100%; }
.content01 .box { display: flex; justify-content: space-between; flex-wrap: wrap; padding: 50px 0; }
.content01 .box .photo { width: 50%; }
.content01 .box .txt_wrap { width: 50%; background: #fff; padding: 50px; }
.content01 .box .txt_wrap .half-round-tit { display: inline-block; margin-bottom: 20px; }
.content01 .box .txt_wrap .half-round-tit strong { color: #1a1a1a; font-size: 22px; font-weight: 500; vertical-align: middle; line-height: 1.6; letter-spacing: 0; }
.content01 .box .txt_wrap .half-round-tit span { display: inline-block; width: 35px; height: 35px; line-height: 35px; text-align: center; border-radius: 50%; vertical-align: middle; color: #fff; font-size: 18px; background: #8abd00; margin-right: 10px; float: left; }
.content01 .box .txt_wrap p { word-break: keep-all; font-size: 18px; line-height: 1.6; color: #555; }

@media screen and (max-width: 992px) {
  .content01 .box { display: flex; flex-direction: row-reverse; justify-content: space-between; }
  .content01 .box .photo { width: 100%; }
  .content01 .box .photo img { width: 100%; }
  .content01 .box .left { width: 100%; }
  .content01 .box .right { width: 100%; }
  .content01 .box .left img { width: 100%; }
  .content01 .box .right img { width: 100%; }
  .content01 .box .txt_wrap { width: 100%; padding: 20px; display: block; position: relative; clear: both; flex: 1; order: 1; }
}
/* content01 */


/* content02 */
.content02 h2 { font-size: 40px; font-weight: bold; }
.content02 h3, .content02 .c2_txt { font-size: 22px; font-weight: 500; color: #555; margin: 20px 0 0px 0; }
.content02 p { font-size: 18px; font-weight: 400; color: #555; padding-top: 5px; margin-bottom: 50px; }
.notice_wrap h3 { font-weight: bold; }
.notice_wrap { font-size: 18px; line-height: 1.75; font-size: 40px; color: #555; }

.content02 ul li { width: 50%; float: left; }
.content02 ul li .profile { float: left; padding-bottom: 50px; width: 48%; }
.content02 ul li .profile img { width: 100%; }
.content02 ul li dl { float: left; padding: 0 40px; width: 52%; }
.content02 ul li dl dt { font-size: 22px; font-weight: bold; text-align: left; padding-bottom: 20px; color: #1a1a1a; letter-spacing: 0; }
.content02 ul li dl dt dd { margin-left: 10px; font-size: 17px; color: #444; line-height: 1.75; letter-spacing: -0.02em; text-align: left; display: block; clear: both; }

@media screen and (max-width: 1210px) {
  .content02 ul li { width: 49%; margin-left: 2%; margin-bottom: 6%; }
  .content02 ul li:nth-child(2n + 1) { margin-left: 0; }
  .content02 ul li .profile { width: 100%; }
  .content02 ul li dl { width: 100%; padding: 0 20px; }
}
@media screen and (max-width: 640px) {
  .content02 ul li { width: 100%; margin-left: 0; }
}
/* content02 */


/* content03 */
.content03 li { width: 31.3333%; margin-right: 3%; min-height: 300px; float: left; text-align: justify; }
.content03 li:nth-child(3n + 3) { margin-right: 0; }
.content03 li .web_icon { width: 100px; height: 100px; margin-bottom: 20px; background-color: #c7c7c7; color: #fff; display: table; margin: 0 auto; }
.content03 li .web_icon i { text-align: center; font-size: 40px; display: table-cell; vertical-align: middle; margin-bottom: 20px; }
.content03 li h2 { font-size: 22px; color: #000; display: block; clear: both; padding-bottom: 10px; margin-top: 30px; letter-spacing: 0; text-align: center; }
.content03 li p { text-align: center; word-break: keep-all; }
.content03 li .icon_img { text-align: center; padding-top: 20px; display: block; }

@media screen and (max-width: 960px) {
  .content03 li { width: 50%; margin-right: 0; }
  .content03 li p { max-width: 300px; margin: 0 auto; }
}

@media screen and (max-width: 640px) {
  .content03 li { width: 100%; margin-right: 0; }
  .content03 li p { max-width: 300px; margin: 0 auto; }
}

.leaflet_printing h2 { font-size: 24px; font-weight: bold; }
.leaflet_printing h3 { font-size: 20px; font-weight: 500; padding: 20px 0 10px 0; }
.leaflet_printing p { font-size: 18px; font-weight: 500; color: #555; line-height: 1.65; }

/* 기본 스타일 */
.icon-container_wrap { max-width: 1600px; display: flex; flex-wrap: nowrap; justify-content: center; gap: 20px; margin: 0 auto; height: auto; align-items: center; }
.icon-container_wrap .icon-container { width: 112px; height: 112px; display: flex; flex-direction: column; align-items: center; justify-content: center; background-color: #f2f2f2; border-radius: 50%; gap: 10px; padding: 20px; }
.icon-container_wrap .icon-container i { font-size: 24px; }
.icon-container_wrap .xi-long-arrow-right { font-size: 24px; }
.icon-container_wrap .icon-container span { font-size: 16px; color: #555; font-weight: 500; text-align: center; }

@media (max-width: 1024px) {
  .icon-container_wrap { flex-wrap: wrap; justify-content: space-around; }
  .icon-container_wrap .icon-container { margin-bottom: 20px; margin-top: 20px; }
}

@media (max-width: 768px) {
  .icon-container_wrap { flex-direction: column; }
  .icon-container_wrap .icon-container { width: 80vw; height: 80vw; max-width: 263px; max-height: 263px; margin-bottom: 20px; }
  .icon-container_wrap .xi-long-arrow-right { display: none; }
}

.recruit_wrap { width: 100%; margin-top: 80px; }
.recruit_wrap ul li { width: 23.5%; float: left; text-align: center; margin-right: 2%; position: relative; }
.recruit_wrap ul li:before { content: ""; width: 34px; height: 15px; position: absolute; top: 50%; transform: translateY(-50%); right: -10%; }
.recruit_wrap ul li:last-child:before { background: none; }
.recruit_wrap ul li > .recruit_bg {}
.recruit_wrap ul li > .recruit_bg img { width: 80%; }
.recruit_wrap ul li > .recruit_txt { margin-top: 5px; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); z-index: 1; }
.recruit_wrap ul li > .recruit_txt strong { font-size: 2rem; color: #333; display: block; }
.recruit_wrap ul li > .recruit_txt span { display: block; font-size: 1.6rem; font-weight: bold; color: #333; }
.recruit_wrap ul li:last-child { margin-right: 0px; }

.recruit_list { width: 100%; border-top: 2px solid #000; margin-top: 50px; }
.recruit_list dl { width: 100%; position: relative; padding: 55px 20px; border-bottom: 1px solid #ddd; }
.recruit_list dl:last-child { border-bottom: none; }
.recruit_list dl:after { content: ""; display: block; clear: both; }
.recruit_list dl dt { width: 350px; font-weight: bold; font-size: 22px; padding: 0; float: left; }
.recruit_list dl dt .num { color: #f9a11b; display: inline-block; margin-right: 20px; }
.recruit_list dl dd { font-size: 18px; float: left; color: #555; font-weight: 400; padding-top: 20px; line-height: 1.65; clear: both; }

@media (max-width: 1200px) {
  .recruit_wrap { width: 100%; }
  .recruit_wrap ul li { width: 48%; float: left; margin-bottom: 5%; }
  .recruit_wrap ul li > .recruit_bg img { width: 70%; }
}

@media (max-width: 1024px) {
  .recruit_wrap ul li > .recruit_bg img { width: 65%; }
  .recruit_list dl dt { width: 250px; }
}
/* content03 */


/* content_area04,05 */
.container { max-width: 1400px; margin: 0 auto; height: auto; }
.overview-txt { font-size: 22px; font-weight: 600; color: #000; line-height: 1.75; margin-bottom: 20px; }
.list ul li { font-size: 18px; color: #555; font-weight: 500; line-height: 1.65; }

.sub-titlearea h3 { font-size: 25px; color: #000; font-weight: bold; margin: 20px 0; }
ul.box-list { overflow: hidden; display: flex; flex-wrap: wrap; align-items: stretch; justify-content: space-between; flex-direction: row; gap: 3%; }
ul.box-list li.box-item { position: relative; width: 31.333%; margin-bottom: 2rem; background: #fff; border: 1px solid #ddd; box-sizing: border-box; }
ul.box-list .box-item dl { padding: 4rem; }
ul.box-list .box-item dl dt {}
ul.box-list .box-item dl dd { margin-top: 3.5rem; }
ul.box-list .box-item dl dd span { font-size: 1.5rem; font-weight: 700; }
ul.box-list .box-item dl dd p { margin-top: 1rem; word-break: keep-all; font-size: 18px; color: #555; font-weight: 400; line-height: 1.75; }
ul.box-list .box-item i { font-size: 36px; }

ul.number-list { position: relative; background: #f5f5f5; padding: 3.5rem; }
ul.number-list li { display: flex; flex-wrap: wrap; align-items: stretch; justify-content: space-between; flex-direction: row; font-size: 1.095rem; margin-bottom: 0.75rem; }
ul.number-list li:last-child { margin-bottom: 0; }
ul.number-list li span { font-weight: 800; flex-basis: 60px; }
ul.number-list li p { flex: 1 0 0; }

@media screen and (max-width: 1640px) {
  ul.box-list { gap: 2%; }
  ul.box-list .box-item dl { padding: 2.75rem; }
  ul.box-list .box-item dl dd { margin-top: 3rem; }
  ul.box-list .box-item dl dd span { font-size: 1.25rem; }
  ul.box-list .box-item dl dd p { margin-top: 0.75rem; }
}
@media screen and (max-width: 1280px) {
  .esg article { flex-direction: column; gap: 0; }
  .esg article .sub-titlearea { flex-basis: 100%; width: 100%; }
  .esg article .content { flex: auto; flex-basis: 100%; width: 100%; }
}

@media screen and (max-width: 1024px) {
  .esg .open-area .thumb { height: 520px; }
  .esg article .content > p { font-size: 1rem; }
  ul.box-list li.box-item { width: 48%; }
  ul.box-list .box-item dl { padding: 2.5rem; }
  ul.number-list { padding: 3rem; }
  ul.number-list li { font-size: 1.05rem; margin-bottom: 0.5rem; }
  ul.number-list li span { flex-basis: 50px; }
}
@media screen and (max-width: 768px) {
  .list ul li { margin-bottom: 20px; }
  .esg .open-area .thumb { height: 460px; }
  .esg article .content > p br { display: none; }
  ul.box-list { gap: 0; flex-direction: column; }
  ul.box-list li.box-item { width: 100%; margin-bottom: 1.5rem; }
  ul.box-list .box-item dl { padding: 2rem; display: flex; flex-direction: row; flex-wrap: nowrap; justify-content: space-between; align-items: flex-start; gap: 1rem; }
  ul.box-list .box-item dl dt { flex-basis: 60px; }
  ul.box-list .box-item dl dd { flex: 1 0 0; margin-top: 0; }
  ul.box-list .box-item dl dd p { margin-top: 0.5rem; }
  ul.number-list { padding: 2.5rem 2rem; }
}
@media screen and (max-width: 480px) {
  .esg .open-area .thumb { height: 300px; }
  ul.box-list li.box-item { margin-bottom: 1rem; }
  ul.box-list .box-item dl { padding: 1.5rem 2rem; }
  ul.box-list .box-item dl dt { flex-basis: 52px; }
}
@media screen and (max-width: 768px) {
  .company .title { font-size: 24px; padding-left: 0; }
  .company .companybg { height: 300px; margin-top: 0px; }
}
/* content_area04,05 */


/* 폼메일 */
.formmail input { height: 50px; line-height: 40px; background: #fff;border: 1px solid #ccc;font-size: 14px;box-sizing: border-box;transition: all 1s;}
.formmail h2 { width: 200px; float: left; font-size: 18px; font-weight: 500;color: #555; padding: 5px 10px 5px 0;}
.formmail .clearfix {  padding:30px 0}
.formmail .left { width:15%; float:left}
.formmail .left h2 { font-size:20px; font-weight:bold; color:#000}
.formmail .left p { font-size:18px; color:#555}
.formmail .right { width:80%; margin-bottom:50px; float:left; text-align:left}
.formmail p {font-size: 16px; color: #555;}
.formmail textarea { width: 900px; height: 130px; line-height: 1.5; padding: 5px;border: 1px solid #bbb; box-sizing: border-box;resize: none;}
.formmail label { font-size:18px; color:#555}
.formmail .radio { width: 20px;height: 20px; border: 1px solid #ddd; background-color: #fff; margin:0 3px; color:#555}
.formmail .btn_submit{ width: 180px; height: 55px;line-height: 55px; border: 0; color: #fff;font-size: 18px; text-align: center; background: #3a8afd;}
.formmail .form-radio {margin-right: 10px; line-height: 28px;}
.formmail #co_email_mx_select {width: 200px; height: 50px; line-height: 40px;}
.formmail .checkbox { padding: 10px;line-height: 0; margin-top: 9px; width: 20px; height: 20px;}
.formmail #confirm {margin:3px; width: 20px; height: 20px;}
.formmail #file1 {width: 400px;}

@media all and (max-width: 640px) { 
  .formmail h2 { width:100%}
  .formmail .left { width:100%}
  .formmail .right { width:100%}
  .formmail label {font-size: 16px;}
  .formmail .company .text,
  .formmail #file1 { width:100%}
  .formmail #email1,
  .formmail #email2 { width:45%}
  .formmail  .textarea { width:100%}
  .formmail .frm_input {width: 100%;}
}
/* 폼메일 */


#footer {background-color: #000}
#footer .inner {padding: 100px 20px 150px 20px}
#footer .top  {width: 100%;  display: flex; justify-content: space-between; flex-wrap: wrap; margin-bottom: 80px; clear: both}
#footer .top .left { width: 50%}
#footer .top .right { width: 50%}
#footer .top .txt h3 {font-size: 20px; color: #fff; font-weight: 800; padding-bottom: 20px}
#footer .top .txt ul {padding: 0; list-style: none;}
#footer .top .txt ul li {font-size: 17px; color: #fff; padding: 8px 0; display: flex; justify-content: flex-start; align-items: center;}
#footer .top .txt ul li h2 { font-weight: 800; color: #fff; font-size: 18px}
#footer .top .txt ul li span {font-size: 18px; color: #838383; font-weight: 500; padding-left: 20px}

#footer .bottom  {width: 100%; margin-top: 50px}
#footer .bottom ul {width: 100%; max-width: 300px;  display: flex; justify-content: space-between; flex-wrap: wrap; color: #fff;}
#footer .bottom ul li a { font-size: 17px; padding: 0 20px; color: #fff; font-weight: 800}
#footer .bottom ul li span { color: #d50000}
#footer .copy { font-size: 15px; padding: 0; color: #fff; opacity: 0.8; font-weight: 400; }
#footer .sns_box {  margin-top: 1rem; display: flex;gap: 1.5rem;}
#footer .sns_box .sns a { display: block; width: 4.0rem; height: 4.0rem; border: 1px solid rgba(255,255,255,0.2); font-size: 0; background: url(../img/facebook.png) no-repeat center / 1rem;}
#footer .sns_box .sns.n2 a {background-image: url(../img/insta.png); background-size: 2rem;}
#footer .sns_box .sns.n3 a { background-image: url(../img/naver.png); background-size: 1.8rem;}

@media (max-width: 768px) {
  #footer .top .left { width: 100%}
  #footer .top .right { width: 100%}
}
