.history_AA {
  overflow: visible;
  position: relative;
  padding-top: 0rem;
  padding-bottom: 10rem; width: 100%; float: left
}

/* 구분 -----------------------------------*/
/**** pc ****/
@media only all and (min-width:768px) {
  .history_AA .col-group {
    width: 100%;
    float: left;
    display: grid;
    grid-template-columns: 480px 1fr;
    gap: 0 clamp(30px, 5vw, 80px);
  }
}
/**** pc2 ****/
@media all and (max-width:1280px) and (min-width:768px) {
  .history_AA .col-group {
    grid-template-columns: 280px 1fr;
    gap: 0 clamp(30px, 4vw, 60px);
  }
}
/**** 모바일 ****/
@media only all and (max-width:767px) {
  .history_AA .col-group {
    width: 100%;
    display: flex;
    grid-gap: 10px;
    flex-direction: column;
  }
}
/**** 모바일2 ****/
@media only all and (max-width:400px) {
}
/* 구분 //end -----------------------------------*/

/* ========== 가로형 탭 메뉴 (왼쪽 상단) - 한 줄 가로 배열 ========== */
.history_AA .tab-menu-horizontal {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  gap: 6px;
  width: 100%;
  margin-bottom: clamp(20px, 3vw, 40px);
}

.history_AA .tab-menu-horizontal a {
  flex: 1 1 auto;
  padding: 12px 14px;
  font-size: clamp(14px, 1.3vw, 17px);
  font-weight: bold;
  color: #000;
  text-decoration: none;
  font-family: "Roboto", sans-serif !important;
  border-radius: 50px;
  border: 1px solid #ccc;
  text-align: center;
  transition: all 0.3s ease;
  white-space: nowrap;
}

.history_AA .tab-menu-horizontal a.active {
  color: #fff;
  background-color: #333;
  border: 1px solid #333;
  border-radius: 50px 50px 50px 10px;
}

.history_AA .tab-menu-horizontal a:hover {
  border-color: #999;
}

/* 태블릿: 탭 한 줄 가로 배열 */
@media all and (max-width:1280px) and (min-width:768px) {
  .history_AA .tab-menu-horizontal {
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 6px;
  }
  .history_AA .tab-menu-horizontal a {
    flex: 1 1 auto;
    padding: 8px 12px;
    font-size: 13px;
  }
}

@media only all and (max-width:767px) {
  .history_AA .tab-menu-horizontal {
    flex-wrap: nowrap;
    gap: 5px;
  }
  .history_AA .tab-menu-horizontal a {
    flex: 1 1 auto;
    padding: 8px 8px;
    font-size: 12px;
  }
}

/* ========== 왼쪽 설명 문구 영역 ========== */
.history_AA .left-desc {
  width: 100%;
  margin-bottom: clamp(15px, 2vw, 25px);
}

.history_AA .left-desc .left-title {
  font-size: clamp(22px, 2.5vw, 32px);
  font-weight: 700;
  color: #000;
  line-height: 1.3;
  margin-bottom: clamp(8px, 1vw, 15px);
  font-family: var(--ff-ko10), sans-serif;
}

.history_AA .left-desc .left-description {
  font-size: clamp(14px, 1.2vw, 16px);
  color: #666;
  line-height: 1.6;
}

@media only all and (max-width:767px) {
  .history_AA .left-desc {
    display: none;
  }
}

.history_AA .col-group .left{ padding-top: 0px

}
/* 구분 -----------------------------------*/
/**** pc ****/
@media only all and (min-width:768px) {
  .history_AA .col-group .right {
    width: 100%;
    padding-left: clamp(100px, 10vw, 150px);
    padding-top: 15px;
  }
}
/**** pc2 ****/
@media all and (max-width:1280px) and (min-width:768px) {
  .history_AA .col-group .right {
    padding-left: clamp(80px, 8vw, 120px);
  }
}
/**** 모바일 ****/
@media only all and (max-width:767px) {.history_AA .col-group .right { padding-top: 20px; padding-left: 20PX

}

}
/**** 모바일2 ****/
@media only all and (max-width:400px) {
}
/* 구분 //end -----------------------------------*/




.history_AA .col-group .history-list li::before {
  content: ""; width: 10px; height: 10px; background-color:#ccc;
  position: absolute;  border-radius: 100%;
  left: -10px;
  top: 0;z-index: 0
}

.history_AA .col-group .history-list li.active {
  position: relative; 
  border-color: var(--secondary);
}

.history_AA .col-group .history-list li.active::before {
 content: ""; width: 10px; height: 10px; background-color:var(--secondary);
  position: absolute; 
}

.history_AA .col-group .history-list li.active+li::before {
 content: ""; width: 10px; height: 10px; background-color:var(--secondary);
  position: absolute;
}



/* 구분 -----------------------------------*/
/**** pc ****/
@media only all and (min-width:768px) {.history_AA .col-group .history-list li .year {
  position: absolute;
  left: -15rem;
  top: -20px;
  max-width: 15rem;
  text-align: right;
  font-weight: var(--fw-bold); font-size:calc(var(--tit-md-size) * 1.2); color: #000; font-family: "Roboto", sans-serif!important; font-weight: 900
}

}
/**** pc2 ****/
@media all and (max-width:1280px) and (min-width:768px) {
}
/**** 모바일 ****/
@media only all and (max-width:767px) {.history_AA .col-group .history-list li .year {
  position: absolute;
  left: 4rem;
  top: -10px;
  max-width: 15rem;
  text-align: right;
  font-weight: var(--fw-bold); font-size: 26px; color: #000; font-family: "Roboto", sans-serif!important; font-weight: 900
}

}
/**** 모바일2 ****/
@media only all and (max-width:400px) {
}
/* 구분 //end -----------------------------------*/





/* li의 기존 라인 제거 (겹침 방지) */
.history_AA .col-group .history-list li {
  position: relative;
  padding-left: clamp(20px, 3.359vw, 43px);
  padding-bottom: clamp(20px, 4.688vw, 60px);
  border-left: none;    padding-left:clamp(40px, calc(2.632vw + 29.474px), 80px)          
}

/* UL 자체에 레일/진행선/마커를 그림 */
.history_AA .col-group .history-list {
  position: relative;
  /* JS가 채워줌 */
  --rail-x: 24px;                    /* 왼쪽에서 라인이 들어올 x 좌표(px) */
  --progress: 0px;                   /* 채워진 높이(px) */
	
	
}

/* 회색 레일 (전체 높이) */
.history_AA .col-group .history-list::before{
  content:"";
  position:absolute; left:8px; top: 0;
  width: 1px; height: 100%;
  background: #ccc;
}

/* 컬러 진행선 (스크롤만큼 채움) */
.history_AA .col-group .history-list::after{
  content:"";
  position:absolute; left: 8px; top: 0;
  width: 1px; height: var(--progress);
  background: var(--secondary);
  transition: height .12s linear;
}


/* 구분 -----------------------------------*/
/**** pc ****/
@media only all and (min-width:768px) {
	
/* 진행선 끝의 동그라미(아이콘 버튼 느낌) */
.history_AA .col-group .history-list .progress-dot{
  position: absolute;
  left:-9px;   /* (지름 32px 기준) 레일 가운데에 맞춤 */
  top: 0;
  width:32px; height:32px;
  border-radius: 50%;
  background: var(--secondary);
  color:#fff; display:flex; align-items:center; justify-content:center;
  transform: translateY(calc(var(--progress) - 16px)); /* 반지름만큼 보정 */
  transition: transform .12s linear;
  box-shadow: 0 2px 6px rgba(0,0,0,.12);
  font-size:16px;                    /* ✔ 아이콘/문자 크기 */
  line-height: 1;
}

/* 필요하면 가운데 체크 화살표 등 아이콘 폰트 사용 가능 */
.history_AA .col-group .history-list .progress-dot i{
  display:block;
}

/* 각 항목의 원표시는 유지하고 싶으면 그대로 두고 색만 조정 */
.history_AA .col-group .history-list li::before{
  content: ""; width: 10px; height: 10px; background-color:rgba(204,204,204,0.00);
  position: absolute; border-radius: 100%;
  left:5px;    /* 레일 중심 맞춤 */
  top: 0;z-index: 0!important
}
.history_AA .col-group .history-list li.active::before{
  background-color: var(--secondary);
}


}
/**** pc2 ****/
@media all and (max-width:1280px) and (min-width:768px) {
}
/**** 모바일 ****/
@media only all and (max-width:767px) {

/* 진행선 끝의 동그라미(아이콘 버튼 느낌) */
.history_AA .col-group .history-list .progress-dot{
  position: absolute;
  left:-4px;   /* (지름 24px 기준) 레일 가운데에 맞춤 */
  top: 0;
  width:24px; height:24px;
  border-radius: 50%;
  background: var(--secondary);
  color:#fff; display:flex; align-items:center; justify-content:center;
  transform: translateY(calc(var(--progress) - 12px)); /* 반지름만큼 보정 */
  transition: transform .12s linear;
  box-shadow: 0 2px 6px rgba(0,0,0,.12);
  font-size:25px;                    /* ✔ 아이콘/문자 크기 */
  line-height: 1;
}

/* 필요하면 가운데 체크 화살표 등 아이콘 폰트 사용 가능 */
.history_AA .col-group .history-list .progress-dot i{
  display:block;
}

/* 각 항목의 원표시는 유지하고 싶으면 그대로 두고 색만 조정 */
.history_AA .col-group .history-list li::before{
  content: ""; width: 10px; height: 10px; background-color:rgba(204,204,204,0.00);
  position: absolute; border-radius: 100%;
  left:5px;    /* 레일 중심 맞춤 */
  top: 0;z-index: 0!important
}
.history_AA .col-group .history-list li.active::before{
  background-color: var(--secondary);
}


}
/**** 모바일2 ****/
@media only all and (max-width:400px) {
}
/* 구분 //end -----------------------------------*/












/* ========== item-row 레이아웃 방향 설정 (월/내용 배열) ========== */
/* gap, margin-bottom 등은 content.skin.php에서 동적으로 설정됨 */
/* inner-list 기본값 */
.history_AA .inner-list {
  display: flex;
  flex-direction: column;
}

/* 구분 -----------------------------------*/
/**** pc ****/
@media only all and (min-width:768px) {
/* 날짜 영역 - 내용에 맞게 유동 */
.history_AA .inner-list dt {
  white-space: nowrap;
}
/* 날짜 없는 항목 - 너비 0 */
.history_AA .inner-list dt.no-date {
  width: 0;
  min-width: 0;
  padding: 0;
  margin: 0;
  overflow: hidden;
}
/* 같은 달 묶기 - 첫번째 날짜만 표시, 나머지는 공간 유지 */
.history_AA .inner-list dt.same-month {
  visibility: hidden;
  width: 0;
  min-width: 0;
  padding: 0;
  margin: 0;
}
}
/**** pc2 ****/
@media all and (max-width:1280px) and (min-width:768px) {
}
/**** 모바일 ****/
@media only all and (max-width:767px) {
.history_AA .inner-list {
  display: flex;
  flex-direction: column;
  padding-top: 40px;
}
.history_AA .inner-list dt.no-date,
.history_AA .inner-list dt.same-month {
  display: none;
}
}
/**** 모바일2 ****/
@media only all and (max-width:400px) {
}
/* 구분 //end -----------------------------------*/


.history_AA .inner-list+.inner-list {
  margin-top: 4.2rem; 
}




/* 구분 -----------------------------------*/
/**** pc ****/
@media only all and (min-width:768px) {
	.history_AA .inner-list dt {
  text-align: left;
  font-weight: var(--fw-bold);  font-size:clamp(20px, 2.813vw, 22px)!important;margin-bottom:clamp(5px, 0.781vw, 10px);font-family:var(--ff-ko10)!important; line-height: 100%!important
}
.history_AA .inner-list dd {
  margin: 0;
  color: #333;  font-size: var(--tx-sm-size);  
}
	
.history_AA .inner-list dd ul.dot{ width: 100%; float:left; 
}

.history_AA .inner-list dd ul.dot>li{ width: 100%; float:left;  position: relative; padding: 0px 0px 0px 10px;  font-size: var(--tx-sm-size); margin-bottom: 10px; border-left: none
}

.history_AA .inner-list dd ul.dot>li:before{content: "·";    font-family: unicons-line; position: absolute; left: 0px; top: 0px;
}

}
/**** pc2 ****/
@media all and (max-width:1280px) and (min-width:768px) {
}
/**** 모바일 ****/
@media only all and (max-width:767px) {
	.history_AA .inner-list dt {
  text-align: left;
  font-weight: var(--fw-bold); font-size:calc(var(--tx-sm-size) * 1); font-family:var(--ff-ko10)!important; line-height: 110%!important
}
.history_AA .inner-list dd {
  margin: 0;
  color: #333;  font-size:calc(var(--tx-sm-size) * 0.9); 
}
	
.history_AA .inner-list dd ul.dot{ width: 100%; float:left; 
}

.history_AA .inner-list dd ul.dot>li{ width: 100%; float:left;  position: relative; padding: 0px 0px 0px 10px;   font-size:calc(var(--tx-sm-size) * 0.9);  margin-bottom: 10px; border-left: none
}

.history_AA .inner-list dd ul.dot>li:before{content: "·";    font-family: unicons-line; position: absolute; left: 0px; top: 0px;
}

}
/**** 모바일2 ****/
@media only all and (max-width:400px) {
}
/* 구분 //end -----------------------------------*/








/* 구분 -----------------------------------*/
/**** pc ****/
@media only all and (min-width:768px) {.tabset {width: 100%; float:left ; padding-left: clamp(0px, 3.906vw, 50px) }

}
/**** pc2 ****/
@media all and (max-width:1280px) and (min-width:768px) {.tabset {width: 100%; float:left ; padding-left:0px }
}
/**** 모바일 ****/
@media only all and (max-width:767px) {.tabset {width: 100%; float:left ; padding-left:0px }

}
/**** 모바일2 ****/
@media only all and (max-width:400px) {
}
/* 구분 //end -----------------------------------*/



.tabset .stx{width: 100%;  float:left ; color: #666; font-size: clamp(12px, 1.172vw, 15px); font-family: "Roboto", sans-serif!important;}
.tabset a{width: 100%;  float:left ; color: #000 ; font-family: "Roboto", sans-serif!important; font-size:clamp(26px, 3.125vw, 40px)}
.tabset a.active{width: 100%;  float:left ;  }



/* 구분 -----------------------------------*/
/**** pc ****/
@media only all and (min-width:768px) {
    .history_head {width: 100%; float: left;display: flex;  justify-content: center;  align-items: center;  justify-content: flex-start;  margin-bottom: clamp(50px, calc(3.289vw + 36.842px), 100px) }
}
/**** pc2 ****/
@media all and (max-width:1280px) and (min-width:768px) {
}
/**** 모바일 ****/
@media only all and (max-width:767px) {
    .history_head { padding:15px; border-radius:6px; background-color: #f7f7f7; display: grid;grid-template-columns: 100% ; margin-bottom:20px;    }
}
/**** 모바일2 ****/
@media only all and (max-width:400px) {
}
/* 구분 //end -----------------------------------*/


/* 구분 -----------------------------------*/
/**** pc ****/
@media only all and (min-width:768px) {
	

    .history-title {
      font-size: clamp(16px, 1.875vw, 24px);
      font-weight: bold; line-height: 130%
    }

    .history-title em {
     font-size:clamp(20px, 3.906vw, 50px);
      font-weight: bold; line-height: 130%; width: 100%; float: left; font-family: "Roboto", sans-serif!important;
    }
}
/**** pc2 ****/
@media all and (max-width:1280px) and (min-width:768px) {
}
/**** 모바일 ****/
@media only all and (max-width:767px) {
	

    .history-title {
       font-size:clamp(20px, 3.906vw, 50px);
      font-weight: bold; line-height: 130%; margin-bottom: 20PX; display: NONE
    }

    .history-title em {
     font-size:clamp(20px, 3.906vw, 50px);
      font-weight: bold; line-height: 130%; width: auto;  font-family: "Roboto", sans-serif!important; margin-left: 10PX
    }
}
/**** 모바일2 ****/
@media only all and (max-width:400px) {
}
/* 구분 //end -----------------------------------*/




/* 기존 상단 탭 메뉴 숨김 */
.history_AA .history_head {
  display: none !important;
}

.tab-menu {
      display: none;
      justify-content: center;
      position: relative; grid-gap: 10px;
    }


 .tab-menu a {
      padding: 15px clamp(16px, 2.344vw, 30px) !important;
font-size:calc(var(--tit-mds-size) * 0.7);
      font-weight: bold;
      color: #000;
      text-decoration: none;
      position: relative; height: auto!important;  display: flex;  justify-content: center;  align-items: center;font-family: "Roboto", sans-serif!important;  border-radius: 50px; border: 1px solid #ccc
    }

    .tab-menu a.active {
      color: #fff; background-color: #333;border: 1px solid #333; border-radius: 50px 50px 50px 10px
    }








.tabset a .char1 { color: #999;font-family: "Roboto", sans-serif!important; font-weight: 400  }
.tabset a .char2 {color: #999;font-family: "Roboto", sans-serif!important; font-weight: 400  }
.tabset a .char5{color: #999;font-family: "Roboto", sans-serif!important; font-weight: 400  }
.tabset a .char6 { color: #999;font-family: "Roboto", sans-serif!important; font-weight: 400  }
.tabset a .char7 {color: #999;font-family: "Roboto", sans-serif!important; font-weight: 400  }
