/*인사말*/
.greeting{position:relative; font-size:15px; max-width:1200px}
.greeting .img{position:relative; height:324px; margin-top:110px; background:url(../img/bg_greeting.jpg) no-repeat 50%; background-size:cover;}
.greeting .img:before{content:''; display:block; position:absolute; bottom:0; left:135px; width:400px; height:400px; background:url(../img/bg_chairman.png) no-repeat;display: none;}
.greeting .tit{position:absolute; top:30px; right:100px; width:514px; height:314px; background:#4168ad}
.greeting .tit h3{position:relative; margin:0; padding:119px 0 0 50px; color:#fff; font-size:22px; font-weight:100;  line-height:1.6; word-break:keep-all; box-sizing:border-box; text-align:left; letter-spacing:-3px}
.greeting .tit h3:before{content:''; display:block; position:absolute; top:-23px; left:50px; width:1px; height:144px; margin:0; background:#fff;}
.greeting .tit h3 span{display:block; font-weight:600;}
.greeting .colum { padding:50px 20px 70px 20px;  max-width:1100px; margin:0 auto}
.greeting .colum:after{clear:both; content:""; display:block;}
.greeting .colum .left{float:left; width:48%; line-height:1.95em;  text-align:justify; color:#333 }
.greeting .colum .right{float:right; width:48%; line-height:1.95em; text-align:justify; color:#333 }
.greeting .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;}
.greeting .sign .name { font-size:24px}
/*인사말*/



/*그룹소개*/
.company_info  { width:100%; height:auto; margin-top:110px }
.company_info .img_page { width:100%; height:550px; background-image:url(../img/company_info_bg_company.jpg); background-position:center; background-repeat:no-repeat;} 
.company_info .txt_page { max-width:1200px; margin:0 auto; padding:20px}
.company_info .txt_page h2 { font-size: 42px; line-height: 1; font-weight: 600; margin-bottom: 44px; padding-top:100px; display: block; }
.company_info .txt_page p { font-size:15px; word-break:keep-all; line-height:1.6; color:#666; padding-bottom:15px}

.company_info .Ideology { width:100%; padding-bottom:100px;}
.company_info .Ideology .inner { max-width:1240px; margin:auto; clear:both;}
.company_info .Ideology .inner h2 {font-size: 36px;font-weight: bold;color: #000; letter-spacing:5px; text-align:center; padding:95px 0 50px 0}
.company_info .Ideology .inner .point{color: #06F;}
.company_info .Ideology .inner h2:after { content: " ";display: block; margin:20px auto; width:40px; height: 2px; background-color:#000; clear: both;}
.company_info .Ideology dl { float:left; width:33.3333%; padding: 0 20px 0 20px; border-right:1px solid #ddd}
.company_info .Ideology dl:last-child { border:0}
.company_info .Ideology dl .web_icon { padding:0 0 20px 0; text-align:center; color:#ff4200}
.company_info .Ideology dl dt { font-size:20px; height:60px; font-weight:bold; letter-spacing:5px; text-align:center} 
.company_info .Ideology dd { line-height:2.2; text-align:center; font-size:15px}


.company_info .work_page { width:100%; height:auto; padding:50px 0; clear:both; background-color:#ECECEC}
.company_info .work_page ul { max-width:1200px; margin:0 auto}
.company_info .work_page ul li { float:left; width:23%; margin: 0 1% 0 1%; padding:100px 20px; background-color:#fff; text-align:center; display:block}
.company_info .work_page ul li:last-child { margin-right:0}
.company_info .work_page ul li:hover {background-color: #001e3a;color: #FFF;cursor: pointer;opacity: 1;transition: all 0.5s;}
.company_info .work_page ul li i { font-size:35px; padding-bottom:20px}
.company_info .work_page ul li .title {font-size:20px; font-weight:bold; padding-bottom:20px; display:block}
.company_info .work_page ul li .txt {font-size:15px; line-height:1.5;} 
/*그룹소개*/







/*연혁*/
.history_area {
  background: url('/theme/sample09/img/his_img2.png') center;
  position: relative;
  margin-top: 71px;
}
.history_area::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(255,255,255,0.6); /* 흰색 반투명 */
  z-index: 0;
}
.history_area > * {
  position: relative;
  z-index: 1;
}
/* 중앙 세로 라인 */
.history_area .history_point {
  position: absolute;
  left: 50%;
  top: 0;
  margin-left: -1px;
  bottom: 20px;
  width: 2px;
  background-color: #d1c8c8;
}
/* 각 항목 공통 dot */
.history_area .clearfix {
  position: relative;
}


/* 왼쪽 항목(dot 오른쪽에 붙음) */
.history_area div:nth-child(odd)::before {
    content: "";
    position: absolute;
    top: 28px;                /* even과 동일하게 맞춤 */
    left: 50%;                /* 중앙 라인 기준 */
    margin-left: -7px;
    width: 58px;              /* dot + 라인 전체 영역 */
    height: 14px;
    z-index: 5;

    /* dot + 오른쪽 라인 */
    background:
      radial-gradient(circle, #c90000 6px, transparent 7px) left center no-repeat, /* dot */
      linear-gradient(to right, #c90000 100%, transparent 0) right center no-repeat; /* 라인 */
    background-size: 14px 14px, 45px 2px;  /* dot 크기 / 라인 길이 */
}


.history_area div:nth-child(even)::before {
    content: "";
    position: absolute;
    top: 28px;
    left: 46.5%;
    margin-left: -7px;
    width: 94px;
    height: 14px;
    z-index: 5;
    background: radial-gradient(circle, #c90000 6px, transparent 7px) right center no-repeat, /* dot */ linear-gradient(to left, #c90000 100%, transparent 0) left center no-repeat;
    background-size: 93px 42px, 44px 2px;
}


/* 첫 번째 항목은 dot/라인 제거 */
.history_area div:nth-child(-n+2)::before {
  content: none;
}
/* 공통 */

.history_area dd .inline-left {
  display: flex;
  align-items: baseline;
  gap: 8px;
}
.history_area dd strong {
  font-size: 18px;
  font-weight: 600;
  white-space: nowrap;
}
.history_area dd p {
  margin: 0;
  font-size: 16px;
  line-height: 1.6;
}

/* 왼쪽 아이템 (글 왼쪽 정렬) */
.history_area dd .inline-left {
  justify-content: flex-start;
  text-align: left;
}

.history_area dd .inline-right {
  display: flex;
  justify-content: flex-end;   /* 오른쪽 정렬 */
  align-items: center;
  gap: 8px;
  width: 100%;
  text-align: right;
  align-items: baseline;
}
.history_area dd .inline-right p { order: 1; margin: 0; }
.history_area dd .inline-right strong { order: 2; white-space: nowrap; }


@media screen and (max-width: 768px) {
  /* 모든 inline을 한 줄 왼쪽 정렬 */
  .history_area dd .inline-left,
  .history_area dd .inline-right {
    display: flex;
    flex-direction: row !important;   /* 순서를 원래대로 */
    justify-content: flex-start !important; 
    text-align: left !important;
    gap: 6px;
  }

  .history_area dd .inline-right p,
  .history_area dd .inline-right strong {
    order: unset !important;   /* order 초기화 */
    font-size: 14px;
  }

   /* dot 위치 조정: 중앙 → 왼쪽 */
  .history_area div:nth-child(odd)::before,
  .history_area div:nth-child(even)::before {
    left: 4px;
    margin-left: 0;
    width: 14px;
    height: 14px;
    background: radial-gradient(circle, #c90000 6px, transparent 7px) center no-repeat;
    background-size: 14px 14px;
  }
}


/*.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: #d15858;font-weight: 500;}
.history_area dd p {display: block;font-size: 16px;line-height: 1.6;color: #555;}
.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%}
/*연혁*/



/*오시는 길*/
.contact_address {width:100%;height:auto;line-height:1.7;}
.contact_address ul {max-width:1240px;clear: both;padding:0 10px 20px 0px;border-bottom:1px solid #ddd;}
.contact_address ul li {color: #333;margin-top: 5px;margin-bottom: 5px; font-size:15px}
.contact_traffic { max-width:1240px; padding:20px 10px 0 0px; letter-spacing:-0.8px;  clear:both;}
.contact_traffic:after {content: " ";visibility: hidden;display: block;height: 0;padding-bottom:50px;clear: both;}
.contact_traffic .bus {width:100%;padding:0;}
.contact_traffic .subway {width:100%; padding:0;}
.contact_traffic ul li {color: #555; line-height:33px; font-size:15px}
.contact_traffic h3 { font-size:20px; font-weight:300; letter-spacing:-1px; color:#000; padding-bottom:10px; margin-top:15px; text-align:left}/* 푸터팝업*/

.map_info{width:283px;height:214px;background:#19cd61;position:absolute;right:0;top:0px;padding: 30px 28px;font-size:15px;color:#f8969a;letter-spacing:0;}
.map_info span{display:block;font-size:20px;color:#fff; font-weight:bold; letter-spacing:-.25px;}
.map_info p { padding-top:20px; color:#f2f2f2; line-height:1.4;}
.map_btn{position:absolute;left:30px;bottom:30px;}
.map_btn a{display:inline-block; padding:7px 10px; height:41px;border:1px solid #f2f2f2;text-align:center; 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:#c2131a;background:#fff;border-color:#fff; 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;
}
.map_btn a:first-child{margin-right:5px;}
/*오시는 길*/







/* business01 */
.business_area { max-width:1200px; padding:20px; margin-top:110px}
.business_area .box { position: relative; padding-bottom:80px; display:block;}
.business_area .box .img_right { float:right}
.business_area .box .txt_wrap { position: absolute; right: 0; top:45px; background: #fff; padding:20px; width: 60%;}
.business_area .box .txt_wrap .half-round-tit {padding:50px 0 20px 50px}
.business_area .box .txt_wrap .half-round-tit strong {color:#333;  font-size:20px; font-weight: 500;  vertical-align: middle;  margin-left: .7rem; line-height:1.6}
.business_area .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;}
.business_area .box .txt_wrap .half-round-tit span {background:#8abd00; float:left}
.business_area .box .txt_wrap .txt {padding-left:1rem; font-size:15px; color: #555; font-weight: 300; padding:50px; line-height: 1.8; text-align: justify;}
.business_area .box .txt_wrap02 { position: absolute; left: 0; top:45px; background: #fff; width: 60%;}
/* business01 */






/* business02 */
.business_area .left { width:50%; float:left}
.business_area .right { width:50%; float:right}
.business_area .profile { float:left; padding-bottom:50px; max-width:221px}
.business_area .profile img { width:100%}
.business_area .list_wrap { float:left}
.business_area .list_wrap h2 { font-size:24px; font-weight:bold; padding:0 0 10px 35px; text-align:left;}
.business_area .list_wrap ul { padding:0 35px 50px 10px}
.business_area .list_wrap ul li { display:block; clear:both; padding:5px 0; font-size:15px;  background-image: url(../images/icon_dot.gif);  background-repeat: no-repeat; background-position: left 16px;  padding-left: 15px; margin-left: 10px; text-align:left; color:#333}
.business_area .list_wrap .enterprise { margin-top:50px}
.business_area .list_wrap .enterprise li { float:left; display:block; padding:10px 20px; clear:none; background-image:none; margin-left:0}
/* business02 */




/* business03 */
.business_area03 { padding-top:110px}
.business_area03:after {content: " ";visibility: hidden;display: block; height: 0; clear: both;}
.business_area03 ul li {width:31.3333%; margin-right:3%; min-height:300px;  float:left; text-align:justify;}
.business_area03 ul li:nth-child(3n+3){margin-right:0}
.business_area03 ul li .web_icon { width:100px; height:100px; margin-bottom:20px; background-color:#ddd; border-radius:50%; color:#fff; display:table;  margin:0 auto}
.business_area03 ul li .web_icon .material-icons { text-align:center; font-size:40px; display:table-cell; vertical-align:middle; margin-bottom:20px}
.business_area03 ul li span {font-size:20px;color:#000;display:block;clear:both;padding-bottom:10px; margin-top:30px; text-align:center}
.business_area03 ul li p { font-size:15px; text-align:center; line-height:1.6; word-break:keep-all}
.business_area03 ul li .icon_img {text-align:center;padding-top:20px;display:block;}
/* business03 */




/*R&D01*/
.rnd_area { width:100%; margin-top:110px; clear:both}
.rnd_area .point { padding:0 20px 0 0px}
.rnd_area .point p { font-size:22px; font-weight:bold; padding:0 0 20px 30px; color:#000; background-image:url(../img/title_icon.png); background-repeat:no-repeat; background-position:left 6px}
.rnd_area .point h2 { font-size:28px; font-weight:100; color:#f66120; padding:10px 0 20px 0; letter-spacing:-1px; line-height:1.6}
.rnd_area .colum { max-width:1200px;  margin:0 auto; padding: 0 20px 50px 0px; font-size:15px }
.rnd_area .colum .left { width:50%; float:left; border-right:1px solid #ddd; padding-right:50px;  line-height:1.8}
.rnd_area .colum .left h2 { font-size:20px; color:#000; letter-spacing:0; padding-bottom:20px; font-weight:bold}
.rnd_area .colum .right { width:50%;  float:left; padding-left:50px; line-height:1.8; text-align:left}
.rnd_area .colum .right h2 { font-size:20px; color:#000; letter-spacing:0; padding-bottom:20px; font-weight:bold}
.rnd_area .img img { width:100%}
.rnd_area .content_sub_title { margin:0 auto; padding:60px 20px 0 20px}
.rnd_area .content_sub_title:after { content: " ";visibility: hidden;display: block; height: 0; padding-bottom:50px; clear: both;}
.rnd_area .content_sub_title .sub_title{float:left; display: block; line-height:1.5; width:25%; color:#000; font-size:22px; letter-spacing:0; font-weight:bold;  padding:0 0 20px 30px; color:#000; background-image:url(../img/title_icon.png); background-repeat:no-repeat; background-position:left 8px; box-sizing:border-box}
.rnd_area .content_sub_title .sub_txt {float:right; width:75%; line-height:2.1; font-size:15px; word-break:keep-all}
.rnd_area .content_sub_title .sub_txt .h2 { font-size:20px; }
.rnd_area .content_sub_title .img { float:left; text-align:right; width:450px }
/*R&D01*/





/*R&D02*/
.rnd_area .box { padding-bottom:50px; clear:both}
.rnd_area .box .img { max-width:50%; float:left; display:block}
.rnd_area .box .img img { width:100%; min-height:375px}
.rnd_area .box .txt { max-width:50%; min-height:375px; float:left; padding:50px; background-color:#f9f9f9; display:block}
.rnd_area .box .txt h2 { font-size:24px; padding-top:50px; font-weight:bold}
.rnd_area .box .txt p { font-size:15px; line-height:1.6; padding-top:30px; word-break:keep-all}
/*R&D02*/


/*R&D03*/
.rnd03_area { max-width:1200px; margin:110px auto 0 auto; padding:0px}
.rnd03_area .box {width:31.3333%; margin-right:3%; display:block; float:left; }
.rnd03_area .box:last-child { margin:0} 
.rnd03_area .box .img { width:100%; min-height:300px; background-repeat:no-repeat; background-size:cover; clear:both; overflow:hidden; position:relative}
.rnd03_area .img01 { background-image: url(../img/business04_img.jpg); }
.rnd03_area .img02 { background-image: url(../img/business04_img1.jpg); }
.rnd03_area .img03 { background-image: url(../img/business04_img2.jpg); }
.rnd03_area .box .txt { width:100%; text-align:left; clear:both}
.rnd03_area .box .txt h2 { font-size:20px; padding-top:30px; text-align:center; font-weight:bold}
.rnd03_area .box .txt p { font-size:15px; padding:20px 0; color:#555; text-align:center; line-height:1.6 }
/*R&D03*/





/*product01*/
.product_area { max-width:1200px; margin-top:110px; font-size:15px; padding:0px; clear:both}
.product_area .box { width:100%; padding-bottom:50px; clear:both}
.product_area .box p { clear:both; font-size:15px; line-height:1.6}
.product_area .box ul li { clear:both; padding-bottom:30px}
.product_area .box ul li h2 { font-size:18px; font-weight:bold; padding-bottom:10px; letter-spacing:0; display:block}
.product_area .box ul li p { font-size:15px; line-height:1.6}
.product_area .txt { width:50%; padding-right:40px; float:left;}
.product_area .txt h2 { font-size:40px; padding-bottom:50px; letter-spacing:-2px; word-break:keep-all; font-weight:bold;}
.product_area .txt h2 span { color:#F60}
.product_area .img { width:50%; height:500px; background-image:url(../img/product_area_thumb.jpg); background-repeat:no-repeat; background-size:cover; float:right}
/*product01*/





@media screen and (max-width: 1020px) {
.business_area { padding:0}
.business_area .profile { max-width:1200px; margin:0 2% 0 2%}
}


@media screen and (max-width: 960px) {
	
	.greeting .tit{position:relative; width:100%; height:auto; padding:0 50px 50px 0px; top:0; right:0;}
	.greeting .tit h3{font-size:22px; line-height:1.6em;}
	.greeting .tit h3 br{display:none;}
	.greeting .img:before{left:50%; width:300px; height:274px; margin-left:-150px; background-size:cover;}
	.greeting .colum .left { width:100%; clear:both}
	.greeting .colum .right { width:100%; padding-top:20px; clear:both}

	.company_info .work_page ul li { width:47%; margin-bottom:20px; margin-right: 0; margin-left: 2%;}
	.company_info .work_page ul li:last-child { margin-right:0}
	.company_info .work_page ul li:nth-child(2n+2) {margin-right:0;}
	.company_info .Ideology dl { width:100%; padding-bottom:30px; clear:both}
	
	

	.business_area .box .img { text-align:center; display:block; float:none; clear:both}
	.business_area .box .img img { width:100%}
	.business_area .box .txt_wrap { width:100%; display:block; position:relative; clear:both}
	.business_area .colum .left .box .img img { width:100%}
	.business_area .list_wrap h2{ padding-left:0}
	.business_area .list_wrap ul { padding-left:0; margin-left:0}
	.business_area .list_wrap ul li { padding-left:0; margin-left:0}
	.business_area03 ul li { width:50%; margin-right:0}
	.business_area03 ul li p { max-width:300px; margin:0 auto}
	
	.rnd_area .colum .left { width:100%; border:0; float:none; padding:0; clear:both}
	.rnd_area .colum .right { width:100%; padding:20px 0 0  }
	.rnd_area .content_sub_title .sub_title { width:100%; clear:both}
	.rnd_area .content_sub_title .sub_txt { float:left; width:100%}
	
	.rnd_area .box .img { max-width:100%; display:block}
	.rnd_area .box .img img { width:100%; min-height:inherit}
	.rnd_area .box .txt { max-width:100%;}
	.rnd_area .box .txt h2 { font-size:24px; font-weight:bold}
	.rnd_area .box .txt p {line-height:1.6; word-break:keep-all}
	
	.rnd03_area .box { width:100%; clear:both; float:none}
	.product_area .txt{ width:100%; padding-bottom:20px}
    .product_area .img { width:100%; clear:both}
} 

	

@media screen and (max-width: 640px) {
	.business_area .box .txt_wrap .txt { padding:0 0 50px }
	.business_area .box .txt_wrap .half-round-tit { padding:0 0 50px 0}
	.business_area .left { width:100%; float:none; margin:0; clear:both}
	.business_area .profile { max-width:100%; margin:0; clear:both; float:none}
	.business_area .list_wrap { float:none; width:100%; padding-left:20px}
	.business_area .right { width:100%; float:none; clear:both}
	.business_area03 ul li { width:100%; margin-right:0}
	.business_area03 ul li p { max-width:300px; margin:0 auto}
	.company_info .img_page  { background-size:cover; height:300px}
    .company_info .work_page ul li { width:100%; float:none; margin-left:0; clear:both}
	.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 strong {font-size:15px;padding-bottom: 10px;}
	.history_area dd p br {display: none;}
	.history_area dd .img_box {margin-top: 20px;}	
}
	