<meta charset="utf-8">


/*인사말*/
.greeting{position:relative; 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;}
.greeting .tit{position:absolute; top:370px; right:100px; width:514px; height:314px; background:#4168ad}
.greeting .tit h3{position:relative; margin:0; padding:140px 20px 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:-1px}
.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%; text-align:justify; }
.greeting .colum .right{float:right; width:48%; text-align:justify; }
.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}

@media (max-width: 980px){
   	.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 { height:253px}
	.greeting .img:before{left:50%; width:300px; height:310px; 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  { width:100%; height:auto;  }
.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 .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: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:16px; font-weight:400; letter-spacing:-0.02em; color:#555}

.tl_title_box_wrap {width:100%; height:auto; padding:150px 20px; clear:both; background-image:url(../img/work_page_bg.jpg); background-position:center; background-repeat:no-repeat; background-size:cover}
.tl_title_box_wrap li {position:relative; width:23.5%; min-height:400px; background-color:#fff; margin-left:2%; float:left; cursor:pointer;  -webkit-transition: all 0.4s; transition: all 0.4s; background-position:center; background-size:cover; background-repeat:no-repeat}
.tl_title_box_wrap li .bg { background-color:#2c3856; color:#fff; opacity:0; position:absolute; width:100%; height:100%; top:0;left:0; z-index:1}
.tl_title_box_wrap li:hover .bg {opacity: 1; -webkit-transition:all .2s ease-out;-moz-transition:all .2s ease-out;-ms-transition:all .2s ease-out;-o-transition:all .2s ease-out;transition:all .2s ease-out; }
.tl_title_box_wrap li:hover {-webkit-box-shadow:4px 4px 9px 0 rgba(0,0,0,.15);-ms-box-shadow:4px 4px 9px 0 rgba(0,0,0,.15);box-shadow:4px 4px 9px 0 rgba(0,0,0,.15);-webkit-transform:translateY(-25px);transform:translateY(-25px)}
.tl_title_box_wrap li .txt_wrap{width:100%;height:100%; position:absolute; top:0; left:0; box-sizing:border-box;overflow:hidden;padding:40px;color:#fff;-webkit-transition:all .2s ease-out;-moz-transition:all .2s ease-out;-ms-transition:all .2s ease-out;-o-transition:all .2s ease-out;transition:all .2s ease-out; opacity:1; display:table; z-index:2;}
.tl_title_box_wrap li:hover .txt_wrap { opacity:1; color:#fff}
.tl_title_box_wrap li:hover .txt_wrap .cell I { color:#FFF}
.tl_title_box_wrap li:hover .txt_wrap .cell h2 { color:#FFF}
.tl_title_box_wrap li:hover .txt_wrap .cell p { color:#fff}
.tl_title_box_wrap li .txt_wrap .cell { text-align:center;width:100%;display: table-cell; vertical-align: middle;}
.tl_title_box_wrap li .txt_wrap .cell i { font-size:35px; padding-bottom:20px; color:#1a1a1a}
.tl_title_box_wrap li .txt_wrap .cell h2 { font-size:24px; color:#1a1a1a; margin:0; font-weight:bold;}
.tl_title_box_wrap li .txt_wrap .cell p { padding-top:50px;}
.tl_title_box_wrap li:nth-child(4n+1) { margin-left:0}

@media (max-width: 960px){
	.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}
}
@media (max-width: 640px){
	.company_info .img_page  { background-size:cover; height:300px}
	.company_info .tl_title_box_wrap li { width:100%; margin-left:0; margin-bottom:3%;}
}
/*그룹소개*/





/*연혁*/
.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: bold;}
.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: 960px){
	.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;}	
}
/*연혁*/






/*오시는 길*/
.location_area .contact_address {width:100%;height:auto; line-height:1.7;}
.location_area .contact_address ul {padding:0 20px 20px 0px;border-bottom:1px solid #ddd;}
.location_area ul li {color: #555; line-height:2.1;}
.contact_traffic .bus {width:100%;padding:0;}
.contact_traffic .subway {width:100%; padding-bottom:20px;}
.contact_traffic h3 { font-size:20px; font-weight:400; letter-spacing:-1px; color:#1a1a1a; padding-bottom:10px; margin-top:25px; 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:#000;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;}

/*오시는 길*/








/* content01 */
.content01 .box { position: relative; padding-bottom:80px; display:block;}
.content01 .box .img_right { float:right}
.content01 .box .txt_wrap { position: absolute; right: 0; top:45px; background: #fff; padding:50px;  width: 60%;}
.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; float:left}
.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:16px}
.content01 .box .txt_wrap .half-round-tit span {background:#8abd00; margin-right:10px; float:left}
.content01 .box .txt_wrap p {text-align: justify;}
.content01 .box .txt_wrap02 { position: absolute; left: 0; top:45px; background: #fff; width: 60%;}

.img1-3 {
  display: grid;
  grid-template-columns: 1fr 3fr; /* 1:3 비율 유지 */
  gap: 20px;
  align-items: start;              /* 이미지가 p 높이에 끌려 늘어나지 않게 */
  margin:50px 0 0 0;
}

.img1-3 img {
  width: 100%;
  height: auto;                    /* 기본은 원본 비율 */
  max-height: clamp(360px, 43vh, 700px); /* 데스크톱에서만 적당히 제한 */
  object-fit: cover;               /* 넘치는 부분은 자연스럽게 크롭 */
  display: block;
  align-self: start;               /* 개별 아이템도 상단 정렬 */
}

.img1-3 p {
  background: #eee;
  padding: 30px;
  box-sizing: border-box;
  line-height: 1.75;
  font-size:15px;
}
.img1-3 p span {float:right; clear:both;}

@media screen and (max-width: 960px) {
	.content01 .box .img { text-align:center; display:block; float:none; clear:both}
	.content01 .box .img img { width:100%}
	.content01 .box .txt_wrap { width:100%; padding:20px; display:block; position:relative; clear:both}
	.img1-3 {
    grid-template-columns: 1fr;
  }
  .img1-3 img {
    max-height: none;   /* 모바일에선 자연 높이 */
    object-fit: contain;
  }
}
/* content01 */

:root{
  --tbl-bg: #fff;
  --tbl-head-bg: #111;    /* 헤더 배경 */
  --tbl-head-fg: #fff;    /* 헤더 글자 */
  --tbl-border: #e6e6e6;
  --tbl-zebra: #fafafa;
  --tbl-hover: #f2f5ff;
  --tbl-radius: 14px;
  --tbl-shadow: 0 6px 20px rgba(0,0,0,.06);
  --tbl-pad-y: 14px;
  --tbl-pad-x: 16px;
  --tbl-font: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans KR", "Apple SD Gothic Neo", "Malgun Gothic", sans-serif;
}

.table-wrap{
  overflow-x:auto;
  -webkit-overflow-scrolling: touch;
}

.board-table{
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: var(--tbl-bg);
  font-family: var(--tbl-font);
  border: 1px solid var(--tbl-border);
  border-radius: var(--tbl-radius);
  box-shadow: var(--tbl-shadow);
  overflow: hidden; /* radius 유지 */
  font-size:16px;
  margin:20px  0 0 0;
}

/* 캡션은 화면 낭독용 (시각적으로 숨김) */
.board-table caption{
  position:absolute;
  width:1px;height:1px;
  margin:-1px;border:0;padding:0;
  clip:rect(0 0 0 0);clip-path: inset(50%);
  overflow:hidden;white-space:nowrap;
}

.board-table thead th{
  background: var(--tbl-head-bg);
  color: var(--tbl-head-fg);
  font-weight: 700;
  text-align: left;
  padding: calc(var(--tbl-pad-y) + 2px) var(--tbl-pad-x);
  position: sticky; /* 긴 목록에서 상단 고정 */
  top: 0;
  z-index: 1;
}

.board-table tbody td{
  padding: var(--tbl-pad-y) var(--tbl-pad-x);
  vertical-align: top;
  border-top: 1px solid var(--tbl-border);
  line-height: 1.6;
  color:#222;
}

.board-table tbody tr:nth-child(odd){
  background: var(--tbl-zebra);
}

.board-table tbody tr:hover{
  background: var(--tbl-hover);
  transition: background .2s ease;
}

/* 주요경력 칸은 가독성 위해 줄바꿈 허용 */
.board-table td:nth-child(3){
  word-break: keep-all;    /* 한국어 단어 단위 유지 */
  overflow-wrap: anywhere; /* 긴 영문/기관명 보호 */
}

/* 모바일(카드형) */
@media (max-width: 640px){
  .board-table thead{
    display:none; /* 헤더 감추고 data-label로 대체 */
  }
  .board-table,
  .board-table tbody,
  .board-table tr,
  .board-table td{
    display:block;
    width:100%;
  }
  .board-table{
    border:0;
    box-shadow:none;
  }
  .board-table tbody tr{
    background:#fff;
    border:1px solid var(--tbl-border);
    border-radius: 12px;
    box-shadow: var(--tbl-shadow);
    margin: 14px 0;
    overflow: hidden;
  }
  .board-table tbody td{
    border:0;
    border-top:1px solid var(--tbl-border);
    padding: 12px 14px;
    position: relative;
  }
  .board-table tbody td:first-child{
    border-top:0;
    padding-top: 14px;
  }
  /* data-label을 왼쪽 레이블로 표시 */
  .board-table tbody td::before{
    content: attr(data-label);
    display:block;
    font-size: .82rem;
    color:#666;
    margin-bottom: 6px;
    letter-spacing:.02em;
  }
}



/* 접근성용 스크린리더 전용 제목 */
.sr-only{
  position:absolute; width:1px; height:1px; margin:-1px; border:0; padding:0;
  clip:rect(0 0 0 0); clip-path: inset(50%); overflow:hidden; white-space:nowrap;
}

/* 그리드 */
.people-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr); /* 기본 4열 */
  gap: 24px;
  margin:30px 0 80px 0;
}

/* 카드 */
.person-card{
  background:#fff;
  border-radius:16px;
  overflow:hidden;
  border:1px solid #e9eaee;
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
  transition: transform .18s ease, box-shadow .18s ease;
}
.person-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 10px 26px rgba(0,0,0,.10);
}

/* 이미지: 일정 비율로 크롭 */
.person-card img{
  width:100%;
  aspect-ratio: 3 / 4;     /* 세로가 약간 긴 비율 */
  object-fit: cover;
  display:block;
}

/* 이름 */
.person-name{
  text-align:center;
  padding:14px 12px 18px;
  font: 600 1rem/1.2 "Nanum Myeongjo", serif; /* 원하시면 나눔명조 */
  color:#111;
  letter-spacing:.02em;
}

/* 반응형 브레이크포인트 */
@media (max-width: 1200px){
  .people-grid{ grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 900px){
  .people-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px){
  .people-grid{ grid-template-columns: 1fr; }
}






.founder-box{
  display: grid;
  grid-template-columns: 1fr 2fr; /* 좌측 이미지, 우측 텍스트 */
  gap: 24px;
  align-items: start;
  margin:50px 0 0 0;
}

.founder-box figure{
  margin:0;
}

.founder-box img{
  width:100%;
  aspect-ratio: 3/4; /* 세로가 긴 비율 */
  object-fit: cover;
  display:block;
  border-radius: 10px;
}

.founder-caption{
  margin-top: 8px;
  font-family: 'Nanum Myeongjo', serif;
  font-weight: 600;
  text-align: center;
  font-size: .95rem;
  color:#444;
}

.founder-box p{
  background:#f5f5f5;
  padding:28px;
  line-height:1.65;
  font-size: 0.95rem;
  color:#222;
  border-radius: 10px;
  box-sizing:border-box;
}

/* 모바일 대응 */
@media (max-width: 768px){
  .founder-box{
    grid-template-columns: 1fr;
  }
  .founder-box img{
    aspect-ratio:auto;
  }
  .founder-box p{
    padding:20px;
  }
}




/* sub1-5 */
/* ===== Tokens ===== */
:root{
  --bg: #fff;
  --fg: #111;
  --muted: #6b7280;
  --head-bg: #6b6f75;          /* 스테이지 헤더 */
  --head-fg: #fff;
  --pill-bg: #dfeeff;          /* 라이트 블루 */
  --pill-bd: #b9d5fb;
  --pill-fg: #2b3a55;
  --radius-lg: 14px;
  --radius-md: 12px;
  --shadow: 0 8px 24px rgba(0,0,0,.08);
  --gap: 18px;
  --font: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans KR", "Apple SD Gothic Neo", "Malgun Gothic", sans-serif;
}

/* ===== Layout ===== */
.canaan-roadmap{
  display: grid;
  gap: 28px;
  padding: 8px 0;
  font-family: var(--font);
  color: var(--fg);
}

/* 각 단계 박스 */
.stage{
  display: grid;
  gap: 16px;
}

/* 헤더 (그레이 캡슐) */
.stage-head{
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: max-content 1fr;
  align-items: center;
  gap: 12px;
  background: var(--head-bg);
  color: var(--head-fg);
  padding: 12px 16px;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
}
.stage-badge{
  display:inline-block;
  background: rgba(255,255,255,.14);
  color:#fff;
  font-weight: 700;
  padding: 6px 12px;
  border-radius: 999px;
  letter-spacing:.02em;
  white-space: nowrap;
}
.stage-title{
  margin:0;
  font-size: 1.05rem;
  font-weight: 700;
}

/* 2+3단계 맞배치 */
.stage-head.duo{
  grid-auto-flow: initial;
  grid-template-columns: 1fr auto 1fr;
  align-items: stretch;
}
.duo-left,.duo-right{
  display:flex;
  align-items:center;
  gap:12px;
}
.duo-plus{
  display:flex; align-items:center; justify-content:center;
  padding: 0 10px;
  font-size: 1.2rem;
  font-weight: 800;
  color:#fff;
}

/* 내용 버블들 */
.stage-items{
  display:flex;
  gap: var(--gap);
  flex-wrap: wrap;
}
.stage-items.two-col{
  display: grid;
  grid-template-columns: 1fr auto 1fr; /* 좌, +, 우 */
  align-items: center;
}
.stage-items.two-col .col{
  display: flex;
  flex-direction: column;
      gap: 18px;
}
.col-plus{
  font-size: 1.5rem;
  font-weight: 800;
  text-align: center;
  color: var(--roadmap-fg);
}

/* 라이트블루 pill */
.pill{
  display:inline-block;
  background: var(--pill-bg);
  border:1px solid var(--pill-bd);
  color: var(--pill-fg);
  padding: 14px 18px;
  border-radius: 16px;
  box-shadow: var(--shadow);
  line-height: 1.45;
  text-align: center;
  font-weight: 600;
  min-width: 240px;
}

.stage-items.three-up{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}

.stage-items.three-up .pill{
  width: 100%;
  min-width: 0;
  justify-self: stretch;
  text-align: center;
  
}
.pill {font-size:15px;}

/* 반응형 */
@media (max-width: 1024px){
  .stage-items.two-col{
    grid-template-columns: 1fr;
  }
  .stage-items.three-up{
    grid-template-columns: repeat(2, 1fr);
    gap: var(--gap); /* 동일한 간격 유지 */
  }
  .col-plus{
    margin: 8px 0;
  }
}
@media (max-width: 720px){
  .stage-head{
    grid-auto-flow: row;
    grid-auto-columns: initial;
    text-align:center;
    gap:8px;
  }
  .stage-head.duo{
    grid-template-columns: 1fr;
  }
  .duo-plus{ 
    display: block;  /* 항상 표시 */
    margin: 8px 0;   /* 위아래 간격 */
    text-align: center;
  }
  .pill{ min-width: unset; width: 100%; }
  .stage-items.three-up{
    grid-template-columns: 1fr;
    gap: var(--gap); /* 동일한 간격 유지 */
  }
}


/* 색/폰트 토큰 (기존 파일의 --tbl-font 재사용) */
:root{
  --tab-accent: #1ea1f2;          /* 활성 탭 밑줄 색 */
  --tab-fg: #222;                 /* 탭 글자 */
  --tab-muted: #9aa0a6;           /* 비활성 글자 */
  --tab-border: #e6e6e6;          /* 탭 하단 선 */
  --panel-border: #e6e6e6;        /* 제목 하단 구분선 */
}

.canaan-tabs{
  font-family: var(--tbl-font, ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans KR", "Apple SD Gothic Neo", "Malgun Gothic", sans-serif);
  color:#111; margin:100px 0 ;
}

/* 탭 헤더 */
.canaan-tabs .tabs{
  display: flex;
  gap: 8px;
  border-bottom: 1px solid var(--tab-border);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.canaan-tabs .tab{
  position: relative;
  appearance: none;
  border: 0;
  background: transparent;
  padding: 12px 14px;
  font-weight: 600;
  color: var(--tab-muted);
  cursor: pointer;
  white-space: nowrap;
}
.canaan-tabs .tab:hover{ color: var(--tab-fg); }

/* 활성 탭 스타일 (밑줄 바) */
.canaan-tabs .tab.is-active{
  color: var(--tab-fg);
}
.canaan-tabs .tab.is-active::after{
  content:"";
  position:absolute; left:0px; right:0px; bottom:-1px;
  height:3px; border-radius:3px;
  background: var(--tab-accent);
}

/* 패널 공통 */
.canaan-tabs .panels{ margin-top: 18px; }
.canaan-tabs .panel{ display:none; }
.canaan-tabs .panel.is-active{ display:block; }

.panel-title{
  margin:0 0 10px 0;
  font-size: 1.25rem;
  font-weight: 700;
}
.panel-desc{
  margin:0 0 14px 0;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--panel-border);
  line-height: 1.7;
  color:#333;
}

/* 이미지 2열 그리드 (반응형) */
.media-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
.media{
  margin: 0;                /* figure 기본 여백 제거 */
  display: flex;
  flex-direction: column;
}
.media img{
  width: 100%;
  display: block;
  aspect-ratio: 3 / 4;      /* 필요 시 3/4, 1/1 등으로 변경 */
  object-fit: cover;
  border-radius: 8px;
}
/* 캡션 텍스트 */
.media-caption{
  margin-top: 8px;
  font-size: .92rem;
  color: #555;
  text-align: center;
  line-height: 1.5;
}

/* 모바일 */
@media (max-width: 720px){
  .media-grid{ grid-template-columns: 1fr; }
}


/* sub1-5 */


/* sub1-6 */
/* 가로 타임라인 기본 */
.history-horizontal{
  position: relative;
  font-family: var(--tbl-font, ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans KR", "Apple SD Gothic Neo", "Malgun Gothic", sans-serif);
  color:#111;
  padding: 10px 0 28px;
}

/* 상단 네비 */
.era-nav{
  display:flex; gap:8px; overflow:auto; padding:0 46px 10px; /* 화살표 영역 고려 */
  border-bottom:1px solid #e6e6e6;
  -webkit-overflow-scrolling: touch;
}
.era-nav-btn{
  appearance:none; border:0; background:transparent;
  padding:10px 12px; font-weight:600; color:#777; cursor:pointer; white-space:nowrap;
  position:relative;
}
.era-nav-btn:hover{ color:#111; }
.era-nav-btn.is-active{ color:#111; }
.era-nav-btn.is-active::after{
  content:""; position:absolute; left:10px; right:10px; bottom:-11px; height:3px;
  background:#1ea1f2; border-radius:3px;
}

/* 화살표 */
.history-horizontal .arrow{
  position:absolute; top:52px; /* 네비 아래 라인 기준 */
  transform: translateY(-50%);
  width:36px; height:36px; border-radius:999px; border:1px solid #e6e6e6;
  background:#fff; box-shadow:0 4px 14px rgba(0,0,0,.08);
  display:flex; align-items:center; justify-content:center;
  font-size:20px; font-weight:700; color:#333; cursor:pointer; z-index:2;
}
.history-horizontal .arrow.left{ left:4px; }
.history-horizontal .arrow.right{ right:4px; }
.history-horizontal .arrow:disabled{ opacity:.45; cursor:default }

/* 가로 스크롤 트랙 (세로 스크롤 허용) */
.era-track{
  margin-top:16px;
  display:grid;
  grid-auto-flow: column;
  grid-auto-columns: min(100%, 920px);
  gap: 20px;

  overflow-x:auto;
  overflow-y:auto;        /* ✅ y스크롤 활성 */
  max-height:480px;       /* ✅ 높이 제한 */

 
  scroll-padding: 24px;
  padding: 0 24px;
  -webkit-overflow-scrolling: touch;
}

/* 각 시대 카드 */
.era{
  scroll-snap-align: start;
  background:#fff; border:1px solid #e6e6e6; border-radius:14px;
  box-shadow: 0 8px 24px rgba(0,0,0,.06);
  padding: 18px;
  min-height: 240px;
}
.era-title{
  margin:0 0 10px 0; font-size:1.2rem; font-weight:700; color:#111;
}
.era-events{ list-style:none; margin:0; padding:0; }
.era-events li{
  line-height:1.7; color:#333; padding:6px 0; border-top:1px dashed #eee;
  display:flex; align-items:flex-start;
}
.era-events li:first-child{ border-top:0; }
.era-events .y{
  flex-shrink:0;
  width:95px;                 /* 연도 영역 고정 폭 */
  font-weight:700;
  color:#1ea1f2;
  display:inline-block;
}
.era-events li span + *{
  flex:1;                      /* 텍스트는 남은 공간 차지 */
}

/* 모바일 최적화 */
@media (max-width:640px){
  .history-horizontal .arrow{ display:none; }
  .era-track{ grid-auto-columns: 92%; padding: 0 16px; gap:16px; }
  .era{ min-height:200px; }
  .era-events .y{ width:80px; }
}
/* sub1-6 */




/* sub1-8 */
/* 접근성용 숨김 제목 */
.sr-only{
  position:absolute; width:1px; height:1px; margin:-1px; border:0; padding:0;
  clip:rect(0 0 0 0); clip-path: inset(50%); overflow:hidden; white-space:nowrap;
}

/* 컨테이너 */
.visit-info{
  font-family: var(--tbl-font, ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans KR", "Apple SD Gothic Neo", "Malgun Gothic", sans-serif);
  color:#111; margin-top:50px;
}

/* 그리드 */
.visit-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
}
.info-card.span-2{ grid-column: 1 / -1; }

/* 카드 */
.info-card{
  background:#fff;
  border:1px solid #e6e6e6;
  border-radius:16px;
  box-shadow: 0 8px 24px rgba(0,0,0,.06);
  padding:18px 18px 20px;
}

/* 헤더 */
.info-head{
  display:flex; align-items:center; gap:10px;
  margin-bottom:10px;
}
.num-badge{
  display:inline-flex; align-items:center; justify-content:center;
  width:28px; height:28px; border-radius:999px;
  background:#1a4fd6; color:#fff; font-weight:800; font-size:.9rem;
  box-shadow: 0 6px 16px rgba(26,79,214,.25);
}
.info-head h3{
  margin:0; font-size:1.15rem; font-weight:800;
}

/* 소제목/강조 */
.subhead{ margin:10px 0 6px; font-size:1rem; font-weight:700; }
.lead{ margin:0 0 8px; color:#333; }
.em{ font-weight:700; }

/* 단계 리스트 */
.steps{
  counter-reset: step;
  list-style:none; margin:0 0 12px; padding:0 2px;
}
.steps li{
  position:relative;
  padding:8px 0 8px 0;
  border-top:1px dashed #eee;
  line-height:1.7; color:#333;
}
.steps li:first-child{ border-top:0; }

.bus-badge{
  display:inline-block;
  min-width:34px; padding:4px 8px;
  border-radius:999px;
  background:#eef5ff; border:1px solid #b9d5fb;
  color:#1a4fd6; font-weight:800; text-align:center;
  margin-right:6px;
}
.or{
  display:inline-block; margin:8px 0; padding:2px 8px;
  background:#f5f7fa; border:1px dashed #e5e7eb; border-radius:999px;
  font-size:.85rem; color:#555;
}

/* 안내 경고 */
.note{
  margin-top:10px;
  background:#fff7ed;
  border:1px solid #fed7aa;
  color:#7c2d12;
  padding:12px 14px;
  border-radius:12px;
  line-height:1.6;
}

/* 주소 및 연락처 리스트 */
.contact-list{
  list-style:none; margin:0; padding:0;
}
.contact-list li{
  padding:6px 0;
  border-bottom:1px dashed #eee;
  line-height:1.6;
  color:#333;
}
.contact-list li:last-child{ border-bottom:0; }
.contact-list strong{ font-weight:700; margin-right:6px; color:#111; }
.contact-list a{ color:#1a4fd6; text-decoration:underline; text-underline-offset:2px; }

/* 반응형 */
@media (max-width: 900px){
  .visit-grid{ grid-template-columns: 1fr; }
  .contact{ grid-template-columns: 1fr; }
}
/* 1-8 */



/* 1-9 */
.tour-map{
  font-family: var(--tbl-font, ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans KR", "Apple SD Gothic Neo", "Malgun Gothic", sans-serif);
}
.map-wrap{ position: relative; display:block; max-width:1100px; margin:0 auto; }
.map-img{ width:100%; height:auto; display:block; border-radius:12px; box-shadow:0 10px 26px rgba(0,0,0,.08); }

/* 핫스팟 점 */
.hotspot{
  --x:50%; --y:50%;
  position:absolute; left:var(--x); top:var(--y); transform:translate(-50%,-50%);
  width:18px; height:18px; border-radius:999px; border:2px solid #fff;
  background:#1a4fd6; box-shadow:0 6px 16px rgba(26,79,214,.35), 0 0 0 4px rgba(26,79,214,.18);
  cursor:pointer;
  z-index: 2;
}
.hotspot:focus-visible{ outline:3px solid #111; outline-offset:2px; }

/* 툴팁(텍스트 기본) */
.hotspot .tip{
  position:absolute; left:50%; bottom:140%; transform:translateX(-50%); 
  white-space:nowrap; background:rgba(17,17,17,.92); color:#fff;
  padding:6px 10px; border-radius:8px; font-size:.9rem; line-height:1;
  box-shadow:0 8px 20px rgba(0,0,0,.25); opacity:0; pointer-events:none;
  transition:opacity .15s ease, transform .15s ease;
  z-index: 3;
}
.hotspot .tip::after{
  content:""; position:absolute; left:50%; top:100%; transform:translateX(-50%);
  border:6px solid transparent; border-top-color:rgba(17,17,17,.92);
}
.hotspot:hover .tip, .hotspot:focus .tip, .hotspot.active .tip{
  opacity:1; transform:translateX(-50%) translateY(-2px);
}

/* === 이미지 포함 팁(공용 변형) === */
.tip.tip--media{
  display:flex; flex-direction:column; align-items:center; 
  gap:8px; padding:10px; border-radius:10px;
  background:rgba(17,17,17,.92);
  white-space:normal;            /* 텍스트 줄바꿈 허용 */
  max-width:min(92vw, 440px);    /* 모바일에서 화면을 넘지 않도록 */
}
.tip.tip--media::after{
  border-top-color:rgba(17,17,17,.92);
}
.tip.tip--media .tip-img{
  width:240px; height:170px; object-fit:cover; display:block; border-radius:6px;
  max-width:min(92vw, 240px);
  height: calc((170 / 240) * min(92vw, 240px)); /* 비율 유지(모바일 축소) */
}
.tip.tip--media .tip-title{
  font-size:15px; font-weight:600; color:#fff; line-height:1.2; text-align:center;
}

/* 모바일 보정 */
@media (max-width:720px){
  .hotspot{ width:22px; height:22px; }
  .hotspot .tip{ font-size:.95rem; }
}
/* 1-9 */


/* ========= eduapply (교육신청 폼) ========= */
.eduapply_box_wrap{
  position: relative;
  font-family: var(--tbl-font, ui-sans-serif, system-ui, -apple-system,"Segoe UI",Roboto,"Noto Sans KR","Apple SD Gothic Neo","Malgun Gothic",sans-serif);
  color:#111;
}
.eduapply_box_wrap .inner{
  background:#fff;
  border:1px solid #e6e6e6;
  border-radius:14px;
  box-shadow:0 8px 24px rgba(0,0,0,.06);
  padding:22px 20px 26px;
}
.eduapply_box_wrap h2{
  margin:0 0 12px 0;
  font-size:1.35rem;
  font-weight:800;
  letter-spacing:-.2px;
  display:flex; align-items:flex-end; gap:10px; flex-wrap:wrap;
}
.eduapply_box_wrap h2 span{
  font-size:.9rem; font-weight:600; color:#888;
}

/* 입력 필드 공통 */
.eduapply_box_wrap .input_page,
.eduapply_box_wrap .txtarea_page{
  margin-bottom:12px;
}
.eduapply_box_wrap input[type="text"],
.eduapply_box_wrap input[type="email"],
.eduapply_box_wrap textarea{
  width:100%;
  border:1px solid #e6e6e6;
  border-radius:10px;
  padding:12px 14px;
  font-size:.98rem;
  background:#fff;
  transition:border-color .15s ease, box-shadow .15s ease;
}
.eduapply_box_wrap textarea{
  min-height:132px; line-height:1.6; resize:vertical;
}
.eduapply_box_wrap input:focus,
.eduapply_box_wrap textarea:focus{
  outline:none;
  border-color:#1ea1f2;
  box-shadow:0 0 0 3px rgba(30,161,242,.12);
}

/* 첨부파일 섹션 */
.eduapply_box_wrap .attach_wrap{
  margin:18px 0 8px;
}
.eduapply_box_wrap .attach_title{
  margin:0 0 10px 0;
  font-size:1.05rem;
  font-weight:800;
}
.eduapply_box_wrap .attach_table{
  display:grid;
  gap:12px;
}
.eduapply_box_wrap .attach_row{
  display:grid;
  grid-template-columns: 1fr 220px;
  gap:14px;
  border:1px dashed #eee;
  border-radius:12px;
  padding:14px;
  background:#fafafa;
}
.eduapply_box_wrap .attach_cell.left strong{
  display:block; font-weight:800; margin-bottom:4px;
}
.eduapply_box_wrap .attach_hint{
  font-size:.87rem; color:#777; margin:0 0 6px;
}
.eduapply_box_wrap .attach_dl{
  font-size:.92rem;
}
.eduapply_box_wrap .attach_dl a{
  text-decoration:none; border-bottom:1px solid transparent;
  color:#1ea1f2; font-weight:700;
}
.eduapply_box_wrap .attach_dl a:hover{ border-color:#1ea1f2; }
.eduapply_box_wrap .attach_dl .sep{ color:#bbb; margin:0 6px; }

/* 파일 버튼 */
.eduapply_box_wrap .file_btn{
  display:inline-flex; align-items:center; justify-content:center;
  width:100%; height:44px;
  border:1px solid #e6e6e6;
  border-radius:10px;
  background:#fff;
  cursor:pointer;
  position:relative;
  overflow:hidden;
  transition: border-color .15s ease, box-shadow .15s ease, transform .02s ease;
}
.eduapply_box_wrap .file_btn:hover{
  border-color:#1ea1f2;
  box-shadow:0 0 0 3px rgba(30,161,242,.08);
}
.eduapply_box_wrap .file_btn:active{ transform:translateY(1px); }
.eduapply_box_wrap .file_btn .file_text{
  pointer-events:none; font-weight:700; font-size:.95rem; color:#333;
}
.eduapply_box_wrap input[type="file"]{
  position:absolute; inset:0; width:100%; height:100%;
  opacity:0; cursor:pointer;
}

/* 파일명/용량 표시 */
.eduapply_box_wrap .file_meta{
  margin-top:6px; font-size:.9rem; color:#555;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.eduapply_box_wrap .file_meta .size{
  color:#888; margin-left:6px; font-weight:600;
}

/* 개인정보 동의 */
.eduapply_box_wrap .policy_wrap{ margin-top:18px; }
.eduapply_box_wrap .policy_title{
  margin:0 0 8px 0; font-size:1.05rem; font-weight:800;
}
.eduapply_box_wrap .policy_box{
  border:1px solid #e6e6e6; border-radius:12px;
  background:#fff;
  padding:12px 14px; max-height:220px; overflow:auto;
}
.eduapply_box_wrap .policy_box p{ margin:8px 0; line-height:1.7; color:#333; }
.eduapply_box_wrap .policy_check{
  display:flex; align-items:center; gap:8px; margin-top:10px; user-select:none;
}
.eduapply_box_wrap .policy_check input[type="checkbox"]{
  width:18px; height:18px; accent-color:#1ea1f2; cursor:pointer;
}
.eduapply_box_wrap .policy_check span{ font-size:.95rem; }

/* 전송 버튼 */
.eduapply_box_wrap .send_page{ margin-top:14px; }
.eduapply_box_wrap .send{
  appearance:none; border:0; cursor:pointer;
  height:48px; padding:0 22px;
  border-radius:12px;
  background:#1ea1f2; color:#fff; font-weight:800; font-size:1rem;
  box-shadow:0 8px 20px rgba(30,161,242,.25);
  transition: transform .02s ease, filter .15s ease, box-shadow .15s ease;
}
.eduapply_box_wrap .send:hover{ filter:brightness(1.05); box-shadow:0 10px 24px rgba(30,161,242,.28); }
.eduapply_box_wrap .send:active{ transform: translateY(1px); }

/* 메시지/로딩 */
.eduapply_box_wrap #x_message{
  margin-top:10px; border-radius:10px; padding:10px 12px; font-weight:700; font-size:.95rem;
  border:1px solid #e6e6e6; background:#fff; color:#333;
}
.eduapply_box_wrap .x-msg1{ border-color:#ffd1d1 !important; background:#fff6f6 !important; color:#b40000 !important; }
.eduapply_box_wrap .x-msg2{ border-color:#cfe9d7 !important; background:#f2fbf5 !important; color:#157347 !important; }
.eduapply_box_wrap #x_loading{
  margin-top:8px; display:inline-flex; align-items:center; gap:8px; color:#666;
}

/* 반응형 */
@media (max-width:1024px){
  .eduapply_box_wrap .attach_row{ grid-template-columns: 1fr 200px; }
}
@media (max-width:720px){
  .eduapply_box_wrap .inner{ padding:18px 16px 22px; }
  .eduapply_box_wrap h2{ font-size:1.22rem; }
  .eduapply_box_wrap .attach_row{ grid-template-columns:1fr; }
  .eduapply_box_wrap .file_btn{ height:46px; }
}






/* 네임스페이스: edu-tabs */
.edu-tabs .tabs{
  display:flex; gap:8px; overflow:auto; padding-bottom:8px; margin-bottom:80px;
  border-bottom:1px solid #e6e6e6;
}
.edu-tabs .tab{
  appearance:none; border:0; background:transparent;
  padding:10px 16px; font-weight:600; color:#777; cursor:pointer; white-space:nowrap;
  position:relative;
}
.edu-tabs .tab:hover{ color:#111; }
.edu-tabs .tab.is-active{ color:#111; }
.edu-tabs .tab.is-active::after{
  content:""; position:absolute; left:8px; right:8px; bottom:-2px; height:3px;
  background:#1ea1f2; border-radius:3px;
}

.edu-tabs .panels{ margin-top:18px; }
.edu-tabs .panel{ display:none; animation: edu-fade .22s ease; }
.edu-tabs .panel.is-active{ display:block; }

@keyframes edu-fade{
  from{ opacity:.0; transform: translateY(4px); }
  to{ opacity:1; transform: translateY(0); }
}










/* content02 */
.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 dd { font-size:16px; color:#555; 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 .icon li {width:31.3333%; margin-right:3%; min-height:300px;  float:left; text-align:justify;}
.content03 .icon li:nth-child(3n+3){margin-right:0}
.content03 .icon li .web_icon { width:100px; height:100px; margin-bottom:20px; background-color:#c7c7c7; color:#fff; display:table;  margin:0 auto}
.content03 .icon li .web_icon i { text-align:center; font-size:40px; display:table-cell; vertical-align:middle; margin-bottom:20px}
.content03 .icon li h2 {font-size:22px;color:#000;display:block;clear:both;padding-bottom:10px; margin-top:30px; letter-spacing:0; text-align:center}
.content03 .icon li p { text-align:center; word-break:keep-all}
.content03 .icon li .icon_img {text-align:center;padding-top:20px;display:block;}
@media screen and (max-width: 960px) {
	.content03 .icon li { width:50%; margin-right:0}
	.content03 .icon li p { max-width:300px; margin:0 auto}
}

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




/* content_area04 */
.content04 .point { padding:0 20px 0 0}
.content04 .point p { font-size:22px; font-weight:bold; padding-left:30px; color:#1a1a1a; background-image:url(../img/title_icon.png); background-repeat:no-repeat; background-position:left center;}
.content04 .point h2 { font-size:28px; font-weight:100; color:#3156A3; text-align:left; padding:40px 0 0;font-family: 'Nanum Myeongjo', serif;}
.boldtext {font-weight: 900;}
.text-my {font-family: 'Nanum Myeongjo', serif;}
.content04 .colum { max-width:1400px;  margin:0 auto; padding: 30px 0 }
.content04 .colum .left { width:50%; float:left; border-right:1px solid #ddd; padding-right:50px}
.content04 .colum .left h2 { font-size:20px; color:#000; letter-spacing:0; padding-bottom:20px; font-weight:bold}
.content04 .colum .right { width:50%;  float:left; padding-left:50px; line-height:1.8; text-align:left}
.content04 .colum .right h2 { font-size:20px; color:#000; letter-spacing:0; padding-bottom:20px; font-weight:bold}
.content04 .content_txt_box { width:100%; padding-top:50px; clear:both}
.content04 .title_text{float:left; display: block; line-height:1.8; width:25%; color:#1a1a1a; font-size:22px; letter-spacing:0; text-align:left; font-weight:bold; margin:0;  padding:0 0 0 30px; background-image:url(../img/title_icon.png); background-repeat:no-repeat; background-position:left center; box-sizing:border-box}
.content04 .sub_txt {float:right; width:75%;}
.content04 .sub_txt .h2 { font-size:20px; }
.content04 .content_sub_title .img { float:left; text-align:right; width:450px }
@media screen and (max-width: 960px) {
	.content04 .colum .left { width:100%; border:0; float:none; padding:0; clear:both}
	.content04 .colum .right { width:100%; padding:20px 0 0  }
	.content04 .title_text { width:100%; margin-bottom:20px; clear:both}
	.content04 .sub_txt { float:left; width:100%}
}

@media screen and (max-width: 640px) {

}
/* content_area04 */







/* content_area05 */
.content05 .photo_box { margin-bottom:50px; background-color:#f9f9f9; clear:both}
.content05 .photo_box .img { max-width:50%; float:left;display:block}
.content05 .photo_box .img img { width:100%}
.content05 .photo_box .txt { max-width:50%; float:left; padding:50px; background-color:#f9f9f9; display:block}
.content05 .photo_box .txt h2 { font-size:24px; padding-top:50px; letter-spacing:0; font-weight:bold; text-align:left}
.content05 .photo_box .txt p { padding-top:20px; word-break:keep-all}
@media screen and (max-width: 960px) {
	.content05 .photo_box .img { max-width:100%; display:block}
	.content05 .photo_box .txt { max-width:100%;}
	.content05 .photo_box .txt h2 { font-size:24px; padding-top:0; font-weight:bold}
}
/* content_area05 */






/* content_area06 */
.content06 .thumb_box  {width:31.3333%; margin-right:3%; display:block; float:left; }
@media screen and (min-width: 961px) {
    .content06 .thumb_box:nth-child(3n+3) { margin-right:0}
}
.content06 .thumb_box .img { width:100%; min-height:300px; background-image:url(../img/rnd03_thumb01.jpg); background-repeat:no-repeat; background-size:cover; clear:both; overflow:hidden; position:relative}
.content06 .thumb_box .txt { width:100%; padding:20px; text-align:left; clear:both}
.content06 .thumb_box .txt h2 { font-size:24px; text-align:center; letter-spacing:0; font-weight:bold}
.content06 .thumb_box .txt p { padding:20px 0px; text-align:center; }
@media screen and (max-width: 960px) {
    .content06 .thumb_box { width:49%; margin-right:2% }
	.content06 .thumb_box:nth-child(2n+2) { margin-right:0} 
}

@media screen and (max-width: 640px) {
    .content06 .thumb_box { width:100%; margin:0; clear:both; float:none}
}
/* content_area06 */