.history_AA {
  overflow: visible;
  position: relative;
  padding-top: 0rem;
  padding-bottom: 10rem; width: 100%; float: left
}

/* ========== 레이아웃 방향 설정 ========== */
/* 가로형 (기본) - 년도 왼쪽, 내용 오른쪽 */
@media only all and (min-width:768px) {
	.history_AA .col-group.layout-horizontal { width: 100%; display: grid; grid-template-columns: 400px 1fr; }
	.history_AA .col-group.layout-vertical { width: 100%; display: flex; flex-direction: column; grid-gap: 20px; }
}
@media only all and (max-width:767px) {
	.history_AA .col-group.layout-horizontal,
	.history_AA .col-group.layout-vertical { width: 100%; display: flex; grid-gap: 10px; flex-direction: column; }
}

/* 세로형일 때 왼쪽 영역 스타일 조정 */
.history_AA .col-group.layout-vertical .left { padding-right: 0; padding-bottom: 10px; }
.history_AA .col-group.layout-vertical .tabset { text-align: left; }
@media only all and (min-width:768px) {
	.history_AA .col-group.layout-vertical .tabset .stx,
	.history_AA .col-group.layout-vertical .tabset .history-tit { display: inline-block; width: auto; margin-right: 15px; }
}
/* 구분 //end -----------------------------------*/





.history_AA .col-group .left{ padding-top: 0px ; padding-right: 30px}
/* 구분 -----------------------------------*/
/**** pc ****/
@media only all and (min-width:768px) {.history_AA .col-group .right { padding-top:0px}

}
/**** pc2 ****/
@media all and (max-width:1280px) and (min-width:768px) {
}
/**** 모바일 ****/
@media only all and (max-width:767px) {.history_AA .col-group .right { padding-top: 0px; padding-left: 10PX; margin-bottom: 30px}

}
/**** 모바일2 ****/
@media only all and (max-width:400px) {
}
/* 구분 //end -----------------------------------*/

/* UL 자체에 레일/진행선/마커를 그림 */
.history_AA .col-group .history-list {
  position: relative;
  padding-top: 20px;
  --rail-x: 8px;
  --progress: 0px;
}

/* 회색 레일 (전체 높이) */
.history_AA .col-group .history-list::before {
  content: "";
  position: absolute;
  left: 8px;
  top: 0;
  width: 3px;
  height: 100%;
  background: #ccc;
}

/* 컬러 진행선 (스크롤만큼 채움) */
.history_AA .col-group .history-list::after {
  content: "";
  position: absolute;
  left: 8px;
  top: 0;
  width: 3px;
  height: var(--progress);
  background: var(--primary);
  transition: height .12s linear;
}

/* li 기본 스타일 - 라인 제거 (겹침 방지) */
.history_AA .col-group .history-list li {
  position: relative;
  padding-left: clamp(40px, calc(2.632vw + 29.474px), 80px);
  padding-bottom: clamp(20px, 4.688vw, 60px);
  border-left: none;
  transition: border-color 0.3s;
}

/* li 점 표시 - 기본 회색 */
.history_AA .col-group .history-list li::before {
  content: "";
  width: 10px;
  height: 10px;
  background-color: rgba(204,204,204,0);
  position: absolute;
  border-radius: 100%;
  left: 5px;
  top: 0;
  z-index: 0;
}

.history_AA .col-group .history-list li.active {
  position: relative;
}

.history_AA .col-group .history-list li.active::before {
  background-color: var(--primary);
}

.history_AA .col-group .history-list li.active+li::before {
  background-color: var(--primary);
}

/* PC: 진행선 끝의 동그라미(아이콘 버튼 느낌) */
@media only all and (min-width:768px) {
  .history_AA .col-group .history-list .progress-dot {
    position: absolute;
    left: -15px;
    top: 0;
    width: 47px;
    height: 47px;
    border-radius: 50%;
    background: var(--primary);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    transform: translateY(calc(var(--progress) - 13px));
    transition: transform .12s linear;
    box-shadow: 0 2px 6px rgba(0,0,0,.12);
    font-size: 25px;
    line-height: 1;
    z-index: 10;
  }
  .history_AA .col-group .history-list .progress-dot i {
    display: block;
  }
}

/* 모바일: 진행선 끝의 동그라미 */
@media only all and (max-width:767px) {
  .history_AA .col-group .history-list .progress-dot {
    position: absolute;
    left: -8px;
    top: 0;
    width: 35px;
    height: 35px;
    border-radius: 50%;
    background: var(--primary);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    transform: translateY(calc(var(--progress) - 13px));
    transition: transform .12s linear;
    box-shadow: 0 2px 6px rgba(0,0,0,.12);
    font-size: 20px;
    line-height: 1;
    z-index: 10;
  }
  .history_AA .col-group .history-list .progress-dot i {
    display: block;
  }
}

.history_AA .col-group .history-list li .year {display: none;
  position: absolute; 
  left: -13rem;
  top: 0;
  max-width: 10rem;
  text-align: right;
  font-weight: var(--fw-bold); font-size:clamp(18px, 2.813vw, 40px)!important; color: #000; font-family: "Roboto", sans-serif!important;
}

/* ========== month-group 레이아웃 방향 설정 (월/내용 배열) ========== */
/* 가로형 - 월(dt) 왼쪽, 내용(dd) 오른쪽 */
.history_AA .inner-list .month-group.layout-horizontal {
  display: grid;
  grid-template-columns: 50px 1fr;
  gap: 5px 15px;
  align-items: start;
}
/* 세로형 - 월(dt) 위, 내용(dd) 아래 */
.history_AA .inner-list .month-group.layout-vertical {
  display: flex;
  flex-direction: column;
}
/* inner-list 기본값 - gap으로 간격 제어 */
.history_AA .inner-list {
  display: flex;
  flex-direction: column;
}

.history_AA .inner-list+.inner-list {
  margin-top: 4.2rem;
}

.history_AA .inner-list dt {
  text-align: left;
  font-weight: var(--fw-bold);  font-size:clamp(20px, 2.813vw, 30px)!important;
}

.history_AA .inner-list dd {
  margin: 0;
  color: #333;
  display: flex;
  flex-direction: column;
}



.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-md-size); border-left: none
}

/* dot 스타일 - gap으로 간격 제어 */
.history_AA .inner-list dd .dot {
  width: 100%;
  float: left;
  position: relative;
  font-size: var(--tx-md-size);
  border-left: none;
  line-height: 130%;
  padding-left: 12px;
}
.history_AA .inner-list dd .dot::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.7em;
  width: 4px;
  height: 4px;
  background-color: #999;
  border-radius: 50%;
}
/**** 모바일 ****/
@media only all and (max-width:767px) {
  .history_AA .inner-list dd .dot {
    font-size: 14px;
  }
}




.history_AA .inner-list dd .dot p{ width: 100%; float:left;  position: relative; padding: 0px 0px 0px 10px;  font-size: var(--tx-md-size); border-left: none
}

.history_AA .inner-list dd ul.dot>li:before{content: "";    font-family: unicons-line; position: absolute; left: 0px; top: 10px;
}






/* 구분 -----------------------------------*/
/**** pc ****/
@media only all and (min-width:768px) {.tabset {width: 100%; float:left ; padding-left: 0; text-align: left; padding-top: 15px }
	.tabset .stx{width: 100%;  float:left ; color: #666; font-size: clamp(12px, 1.172vw, 15px); font-family: "Roboto", sans-serif!important; text-align: left; margin-bottom: 0px}
	.tabset a{width: 100%;  float:left ; color: #000 ; font-family: "Roboto", sans-serif!important; font-size:clamp(26px, 5.469vw, 50px); font-weight: 700}
	.tabset .history-tit{width: 100%;  float:left ; color: #000 ; font-family: "Roboto", sans-serif!important; font-size:clamp(26px, 5.469vw, 50px); font-weight: 700; text-align: left; white-space: nowrap}

}
/**** 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; padding-top: 0 }
	.tabset .stx{width: 100%;  float:left ; color: #666; font-size: 11px; font-family: "Roboto", sans-serif!important; text-align:left; margin-bottom:0px}
	.tabset a{width: 100%;  float:left ; color: #000 ; font-family: "Roboto", sans-serif!important; font-size:; font-weight: 700}
	.tabset .history-tit{width: 100%;  float:left ; color: #000 ; font-family: "Roboto", sans-serif!important; font-size: 32px; font-weight: 700; text-align: left; white-space: nowrap; margin-top: 0}

}
/**** 모바일2 ****/
@media only all and (max-width:400px) {
}
/* 구분 //end -----------------------------------*/





.tabset a.active{width: 100%;  float:left ;  }
.tabset .tabset-desc{width: 100%; float:left; color: #666; font-size: clamp(13px, 1.1vw, 14px); line-height: 1.6; margin-top: 10px;}



/* 구분 -----------------------------------*/
/**** pc ****/
@media only all and (min-width:768px) {
    .history_head { padding:clamp(10px, 3.125vw, 40px) clamp(20px, 6.250vw, 80px); border-radius:20px; background-color: #f7f7f7; display: grid;grid-template-columns: 300px auto ; margin-bottom:clamp(30px, 7.813vw, 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(30px, 3.906vw, 70px);
      font-weight: bold; line-height: 130%; width: 100%; float: left; font-family: "Roboto", sans-serif!important; font-weight: 700
    }
}
/**** pc2 ****/
@media all and (max-width:1280px) and (min-width:768px) {
}
/**** 모바일 ****/
@media only all and (max-width:767px) {
	

    .history-title {
       font-size:20px;
      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 -----------------------------------*/




/* 구분 -----------------------------------*/
/**** pc ****/
@media only all and (min-width:768px) {    .tab-menu {
      display: flex;
      justify-content: center;
      position: relative; padding-top: 20px
    }
	    .tab-menu:before { position: absolute; left: 0px; bottom:10px; 
      border-bottom: 1px solid #ccc;content: "";  width: 100%; float: left; height: 1px
    }

}
/**** pc2 ****/
@media all and (max-width:1280px) and (min-width:768px) {
}
/**** 모바일 ****/
@media only all and (max-width:767px) {    .tab-menu {
    display: grid; grid-template-columns: repeat(2, 1fr); grid-gap: 10PX;    position: relative; 
    }
	    .tab-menu:before {display: none
    }

}
/**** 모바일2 ****/
@media only all and (max-width:400px) {
}
/* 구분 //end -----------------------------------*/


/* 구분 -----------------------------------*/
/**** pc ****/
@media only all and (min-width:768px) {
	    .tab-menu a {
      padding: 0px clamp(16px, 2.344vw, 30px) 0px!important;
      font-size: 18px;
      font-weight: bold;
      color: #999;
      text-decoration: none;
      position: relative; height: auto!important; font-family: "Roboto", sans-serif!important; 
    }

    .tab-menu a.active {
      color: #000;font-size: var(--tit-md-size);
    }



}
/**** pc2 ****/
@media all and (max-width:1280px) and (min-width:768px) {
}
/**** 모바일 ****/
@media only all and (max-width:767px) {
	    .tab-menu a {
     padding: 7px 10px;
      font-size: 18px;
      font-weight: bold;
      color: #999;
      text-decoration: none;
      position: relative; height: auto!important; font-family: "Roboto", sans-serif!important; text-align: center; background-color: #fff
    }

    .tab-menu a.active {
      color: #fff;padding: 7px 10px; text-align: center; background-color: var(--primary);; border-radius: 6px
    }



}
/**** 모바일2 ****/
@media only all and (max-width:400px) {
}
/* 구분 //end -----------------------------------*/






/* 구분 -----------------------------------*/
/**** pc ****/
@media only all and (min-width:768px) {
	    .tab-menu a.active::after {
      content: '';
      position: absolute;
      bottom:0px;
      left: 50%;
      transform: translateX(-50%);
      width: 20px;
      height:20px;
      border-radius: 50%;
      background:var(--primary);;
      border: 5px solid #fff;
      box-shadow: 0 0 0 1px var(--primary);
    }

}
/**** pc2 ****/
@media all and (max-width:1280px) and (min-width:768px) {
}
/**** 모바일 ****/
@media only all and (max-width:767px) {
	    .tab-menu a.active::after {
      content: '';
      position: absolute;
      bottom:-5px;
      left:0PX;
      width: 100%;
      height:1px;

      background:var(--primary);; display: none

    
    }

}
/**** 모바일2 ****/
@media only all and (max-width:400px) {
}
/* 구분 //end -----------------------------------*/




.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  }



.outbg{ background-color: #f7f7f7; padding: clamp(50px, 11.719vw, 150px) 0px; width: 100%; float: left}
