.header-contact {
background:none;
padding:0rem;
margin-top:1rem;
}
@media (min-width: 768px) {
.header-contact {
background:var(--bs-navbar-bg-color);
padding:0.5rem;
margin-top:0rem;
}
}

.hero {
  padding:0px;
  margin:0px;
  position: relative;
  z-index:0;
  margin-top:0rem;
  min-height:80vh;
}
@media (min-width: 768px) {
.hero {
	min-height:80vh;
	overflow:hidden;
}
}



.video-background {
    position: absolute;
    top: 50%;
    left: 50%;
    min-width: 100%;
    width: auto; 
    height: auto;
    transform: translate(-50%, -50%);
    object-fit: cover;
    z-index: -1;
}



/* index-about
-------------------------------------------------- */

.index-about {
	background: url() var(--bs-light-customer) no-repeat center 50%;
	position: relative;
	width:100%;
	height:auto;
}
.index-about .img-box {
  position: relative;
  padding: 0 15px 15px 0;
}

.index-about .img-box img {
  position: relative;
  max-width: 100%;
  z-index:1;
}

.index-about .img-box::before {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  width: calc(100% - 15px);
  height: calc(100% - 15px);
  background-color: none;
  border:solid 5px #d71d04;
  z-index: 1;
  opacity: 0.95;
}



/* owl-carousel-about
-------------------------------------------------- */
.owl-carousel-about{
	position: relative;
}

.owl-carousel-about .owl-nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
 
}



.owl-carousel-about .owl-nav .owl-next span,
.owl-carousel-about .owl-nav .owl-prev span{
  position: absolute;
  top: calc(50% - 4.5rem);
  bottom: 0;
  z-index: 2;
  display: inline-block;
  font-size:2em;
  border:solid 2px #d71d04;
  border-radius:50%;
  width:1.725em;
  height:1.725em;
  line-height:1.5em;
  background:none;
  background-repeat: no-repeat;
  background-position: 50%;
  background-size: 100% 100%;
  outline: none;
  margin:30px 10px 0px 10px;
  color: #d71d04;
  z-index:2000;
  }


.owl-carousel-about .owl-nav .owl-next span {
	right:0px;
}
.owl-carousel-about .owl-nav .owl-prev span {
	left:0px;

}
.owl-carousel-about .owl-nav .owl-next span:hover,.owl-carousel-about .owl-nav .owl-prev span:hover {
  background:#d71d04;
  color: #fff;
}




.owl-carousel-about .owl-dots {
	margin-top:15px;
	text-align:center;

   
}
.owl-carousel-about .owl-dots .owl-dot {
	display:inline-block;
	zoom:1;
	outline: none;
}
.owl-carousel-about .owl-dots .owl-dot span {
	width:12px;
	height:12px;
	margin:5px 7px;
	background:#D6D6D6;
	display:block;
	-webkit-backface-visibility:visible;
	transition:opacity .2s ease;
	border-radius:30px
}
.owl-carousel-about .owl-dots .owl-dot.active span,.owl-carousel-about .owl-dots .owl-dot:hover span {
	background:var(--bs-customer);
}

.owl-carousel-about .owl-item {
	
}


/* index-counter
-------------------------------------------------- */
.index-counter {
	position: relative;
}
.index-counter-bg {
  position: absolute;
  z-index:-1;
  top: 0;
  width: 100%;
  height: 68%;
}
.index-counter-bg::before {
  position: absolute;
   z-index:0;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  padding:0px;
  margin:0px;
  content: "";
  background: #010101;
  border-bottom:solid 0px #f4f7fb;
}



.index-counter  .counter-number {
  position: relative;
  text-align:center;
}
.index-counter  .counter-number::after {
  background: #f1f2f3;
  bottom: 0;
  content: "";
  height: 50px;
  margin-top: -30px;
  position: absolute;
  right: 0;
  top: 50%;
  width: 1px;
  z-index: 1;
}

@media (max-width: 767px) {
.index-counter  .counter-number::after {
  background: #1ab2f6;
  bottom: 0;
  content: "";
  height: 50px;
  margin-top: -30px;
  position: absolute;
  right: 0;
  top: 50%;
  width: 0px;
}
}

.index-counter .col-item:last-child .counter-number::after {
  width: 0px;
}

.index-counter  .counter-number h1{
	font-size:3.25em;
}
.index-counter .col-item:nth-child(1) .counter-number h1{
	color:#00cde5;
}
.index-counter .col-item:nth-child(2) .counter-number h1{
	color:#ff5e5e;
}
.index-counter .col-item:nth-child(3) .counter-number h1{
	color:#5bb286;
}
.index-counter .col-item:nth-child(4) .counter-number h1{
	color:#f9b73f;
}
.index-counter .col-item:nth-child(5) .counter-number h1{
	color:#6177ff;
}
.index-counter .col-item:nth-child(6) .counter-number h1{
	color:#b540ff;
}
.index-counter  .counter-number p{
    margin-top:0px;
	
	color:#848484;
}




/*======= index-product =========*/


.index-product {

}
.index-product .nav-item{
	
}


.index-product .nav-item .nav-link{
	background:var(--bs-customer-two);
	margin-left:5px;
	margin-right:5px;
	margin-bottom:15px;
	border:solid 1px var(--bs-customer-two);
	color:#fff;
}
.index-product .nav-item .nav-link.active{
	background:var(--bs-customer);
	border:solid 1px var(--bs-customer);
	color:#fff;
}
.index-product .tab-pane {
	transition:.25s;
}


.index-product-list {

}
.index-product-list .item{
	
}
.index-product-list .item:nth-child(even){
	background:#f8f9fa;
}
.index-product-list .item:nth-child(even) .item-img{
	order: 2 !important;
}
.index-product-list .item:nth-child(even) .item-title{
	order: 1 !important;
}


.index-project {

}
.index-project .card{
	border:solid 1px #dee2e6;
}
.index-project .card-header{
	background:#f8f9fa;
	border-bottom:solid 1px #dee2e6;
}
.index-project .bg-card-1{
  background: url(../images/bg-flower.png) #f8f9fa no-repeat;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  width: 100%;
  min-height: 180px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.index-project .bg-card-2{
  background: url(../images/bg-women.png) #f8f9fa no-repeat;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  width: 100%;
  min-height: 170px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
@media (max-width: 768px) {
  .index-project .bg-card-1,.index-project .bg-card-2 {
    min-height: 100px;
  }
}
/*======= index-feature  =========*/
.index-feature {
	position: relative;
}
.index-feature-bg {
  position: absolute;
  z-index:-1;
  bottom: 0;
  width: 100%;
  height: 50%;
}
.index-feature-bg::before {
  position: absolute;
   z-index:0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  padding:0px;
  margin:0px;
  content: "";
  background:#010101;
  border-bottom:solid 0px #f4f7fb;
}


.features-one {


	
}
.features-one .features-item {
	

}
.features-one .features-images{
	width:100%;
	height:auto;
}

.features-one .features-item p {
	color: rgb(115, 115, 115);
}



.features-one .features-item i {
	font-size:3em;
	color:#010101;

}

.features-one .features-item h5{
	font-weight:600;
	margin-top:15px;
}


.features-one .features-item.active i {
	background: #010101;
	color:#2d313d;
}
.features-one .features-item.active h1 {
	color:#fff;
}
.features-one .features-item.active p {
	color:#fff;
}

.features-one img {
	color:#fff;
	padding:12px;
	width:100%;
}
.features-one .features-item img {
	color:#fff;
	padding:12px;
	width:100px;
	height:100px;
}

/* owl-carousel-job
-------------------------------------------------- */
.owl-carousel-job{
	position: relative;
}

.owl-carousel-job .owl-nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}



.owl-carousel-job .owl-nav .owl-next span,
.owl-carousel-job .owl-nav .owl-prev span{
  display: inline-block;
  font-size:2em;
  border:solid 0px #7f7f7f;
  border-radius:0%;
  width:2.5rem;
  height:2.5rem;
  line-height:2rem;
  background:#f7f8f9;
  background-repeat: no-repeat;
  background-position: 50%;
  background-size: 100% 100%;
  outline: none;
  margin:30px 10px 0px 10px;
  color: #7f7f7f;
  }


.owl-carousel-job .owl-nav .owl-next span:hover,.owl-carousel-job .owl-nav .owl-prev span:hover {
  background:#7f7f7f;
  color: #fff;
}




.owl-carousel-job .owl-dots {
	margin-top:15px;
	text-align:center;

   
}
.owl-carousel-job .owl-dots .owl-dot {
	display:inline-block;
	zoom:1;
	outline: none;
}
.owl-carousel-job .owl-dots .owl-dot span {
	width:12px;
	height:12px;
	margin:5px 7px;
	background:#D6D6D6;
	display:block;
	-webkit-backface-visibility:visible;
	transition:opacity .2s ease;
	border-radius:30px
}
.owl-carousel-job .owl-dots .owl-dot.active span,.owl-carousel-job .owl-dots .owl-dot:hover span {
	background:#010101;
}

.owl-carousel-job .owl-item {
	
}

/* owl-carousel-news
-------------------------------------------------- */
.owl-carousel-news{
	position: relative;
}

.owl-carousel-news .owl-nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}



.owl-carousel-news .owl-nav .owl-next span,
.owl-carousel-news .owl-nav .owl-prev span{
  display: inline-block;
  font-size:2em;
  border:solid 0px #7f7f7f;
  border-radius:0%;
  width:2.5rem;
  height:2.5rem;
  line-height:2rem;
  background:#f7f8f9;
  background-repeat: no-repeat;
  background-position: 50%;
  background-size: 100% 100%;
  outline: none;
  margin:30px 10px 0px 10px;
  color: #7f7f7f;
  }


.owl-carousel-news .owl-nav .owl-next span:hover,.owl-carousel-news .owl-nav .owl-prev span:hover {
  background:#7f7f7f;
  color: #fff;
}




.owl-carousel-news .owl-dots {
	margin-top:15px;
	text-align:center;

   
}
.owl-carousel-news .owl-dots .owl-dot {
	display:inline-block;
	zoom:1;
	outline: none;
}
.owl-carousel-news .owl-dots .owl-dot span {
	width:12px;
	height:12px;
	margin:5px 7px;
	background:#D6D6D6;
	display:block;
	-webkit-backface-visibility:visible;
	transition:opacity .2s ease;
	border-radius:30px
}
.owl-carousel-news .owl-dots .owl-dot.active span,.owl-carousel-news .owl-dots .owl-dot:hover span {
	background:#010101;
}

.owl-carousel-news .owl-item {
	
}

.grid {
	position: relative;
	margin: 0px;
	padding:0px;
	max-width: 100%;
	list-style: none;
	text-align: center;
}

/* Common style */
.grid figure {
	position: relative;
	float: left;
	overflow: hidden;
	max-width: 100%;
	max-height: 100%;
	width: 100%;
	background: #1b4d96;
	text-align: center;
	cursor: pointer;
}

.grid figure img {
	position: relative;
	display: block;
	min-height: 100%;
	max-width: 100%;
	opacity: 0.8;
}

.grid figure figcaption {
	padding: 2em;
	color: #fff;
	text-transform: none;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}

.grid figure figcaption::before,
.grid figure figcaption::after {
	pointer-events: none;
}

.grid figure figcaption,
.grid figure figcaption > a {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

/* Anchor will cover the whole item by default */
/* For some effects it will show as a button */
.grid figure figcaption > a {
	z-index: 1000;
	text-indent: 200%;
	white-space: nowrap;
	font-size: 0;
	opacity: 0;
}

.grid figure h5 {
	
	font-weight: 500;
}



.grid figure h5,
.grid figure p {
	margin: 0;
}

.grid figure p {
	
}
/*-----------------*/
/***** Goliath *****/
/*-----------------*/

figure.effect-goliath {
	
}

figure.effect-goliath img,
figure.effect-goliath h5 {
	-webkit-transition: -webkit-transform 0.35s;
	transition: transform 0.35s;
}

figure.effect-goliath img {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}

figure.effect-goliath h5,
figure.effect-goliath p {
	position: absolute;
	bottom: 0;
	left: 0;
	padding: 30px;
}

figure.effect-goliath p {
	text-transform: none;
	opacity: 0;
	-webkit-transition: opacity 0.35s, -webkit-transform 0.35s;
	transition: opacity 0.35s, transform 0.35s;
	-webkit-transform: translate3d(0,50px,0);
	transform: translate3d(0,50px,0);
}

figure.effect-goliath:hover img {
	-webkit-transform: translate3d(0,-80px,0);
	transform: translate3d(0,-80px,0);
}

figure.effect-goliath:hover h5 {
	-webkit-transform: translate3d(0,-100px,0);
	transform: translate3d(0,-100px,0);
}

figure.effect-goliath:hover p {
	opacity: 1;
	-webkit-transform: translate3d(0,0,0);
	transform: translate3d(0,0,0);
}
/*---------------*/
/***** Sadie *****/
/*---------------*/

figure.effect-sadie figcaption::before {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: -webkit-linear-gradient(top, rgba(0,0,0,0.5) 0%, rgba(0,0,0,0.5) 75%);
	background: linear-gradient(to bottom, rgba(0,0,0,0.5) 0%, rgba(0,0,0,0.5) 75%);
	content: '';
	opacity: 0.75;
	/*-webkit-transform: translate3d(0,50%,0);
	transform: translate3d(0,50%,0);*/
}

figure.effect-sadie h5 {
	position: absolute;
	top: 50%;
	left: 0;
	width: 100%;
	color: #fff;
	-webkit-transition: -webkit-transform 0.35s, color 0.35s;
	transition: transform 0.35s, color 0.35s;
	-webkit-transform: translate3d(0,-50%,0);
	transform: translate3d(0,-50%,0);
}

figure.effect-sadie figcaption::before,
figure.effect-sadie p {
	-webkit-transition: opacity 0.35s, -webkit-transform 0.35s;
	transition: opacity 0.35s, transform 0.35s;
}

figure.effect-sadie p {
	position: absolute;
	bottom: 0;
	left: 0;
	padding: 15px;
	width: 100%;
	opacity: 0;
	-webkit-transform: translate3d(0,10px,0);
	transform: translate3d(0,10px,0);
}

figure.effect-sadie:hover h5 {
	color: #fff;
	-webkit-transform: translate3d(0,-50%,0) translate3d(0,-40px,0);
	transform: translate3d(0,-50%,0) translate3d(0,-40px,0);
}

figure.effect-sadie:hover figcaption::before ,
figure.effect-sadie:hover p {
	background: -webkit-linear-gradient(top, rgba(0,0,0,0) 0%, rgba(0,0,0,0.8) 75%);
	background: linear-gradient(to bottom, rgba(0,0,0,0) 0%, rgba(0,0,0,0.8) 75%);
	opacity: 1;
	-webkit-transform: translate3d(0,0,0);
	transform: translate3d(0,0,0);
}


/* owl-carousel-news
-------------------------------------------------- */
.owl-carousel-news {
	
}


.owl-carousel-news .owl-nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: space-between;
  position: absolute;
  z-index:-1;
  top: 50%;
  left: 0px;
  right: 0px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

@media(min-width:768px) {
.owl-carousel-news .owl-nav {
  left: -30px;
  right: -30px;
}
}

.owl-carousel-news .owl-nav .owl-next span,
.owl-carousel-news .owl-nav .owl-prev span{
  display: inline-block;
  font-size:3.5rem;
  background:none;
  background-repeat: no-repeat;
  background-position: 50%;
  background-size: 100% 100%;
  outline: none;
  margin:0px 0px 0px 0px;
  color: #888;
  z-index:1;
  }


.owl-carousel-news .owl-nav .owl-next span:hover,.owl-carousel-news .owl-nav .owl-prev span:hover {

  color: #010101;
}




.owl-carousel-news .owl-dots {
	margin-top:30px;
	text-align:center;

   
}
.owl-carousel-news .owl-dots .owl-dot {
	display:inline-block;
	zoom:1;
	outline: none;
}
.owl-carousel-news .owl-dots .owl-dot span {
	width:15px;
	height:4px;
	margin:0px 5px;
	background:#D6D6D6;
	display:block;
	-webkit-backface-visibility:visible;
	transition:opacity .2s ease;
	border-radius:0px
}
.owl-carousel-news .owl-dots .owl-dot.active span,.owl-carousel-news .owl-dots .owl-dot:hover span {
	background:#010101;

}








.page-contact {

}
.page-contact .pc-i{
	background:#fff;
	width:45px;
	height:45px;
	line-height:1.75rem;
	text-align:center;
}
.page-contact .pc-item:hover .pc-i{
	background:#010101;
	color: #fff;
}
.page-contact .border-black{
	border:solid 3px #333;
}



.page .contact-us-item-1 {
	border-right:solid 0px #495057;
	border-bottom:solid 0px #495057;
}
.page .contact-us-item-2 {
	border-bottom:solid 0px #495057;
}
.page .contact-us-item-3 {
	border-right:solid 0px #495057;
}
 
@media (min-width: 768px) {
.page .contact-us-item-1 {
	border-right:solid 1px #495057;
	border-bottom:solid 1px #495057;
	min-height:20vh;
}
.page .contact-us-item-2 {
	border-bottom:solid 1px #495057;
}
.page .contact-us-item-3 {
	border-right:solid 1px #495057;
	min-height:40vh;
}
}
.page .information {

}

.page .information ul{

}
.page .information ul li{
	border-bottom:solid 1px #000;
	padding-top:1rem;
	padding-bottom:1rem;
	margin-bottom:1rem;
}
.page .information ul li span{
	font-weight:bold;
}
@media (min-width: 768px) {
.page .information ul li span{
	margin-right:30px;
}
}

.page .wp-block-gallery {

}
.page .wp-block-gallery .wp-block-image{
	padding:15px;
}
@media (min-width: 768px) {
.page .wp-block-gallery .wp-block-image{
	padding:30px;
}
}
.page-team h5 {
  position: relative;
  margin-bottom:45px;

}

.page-team h5:after {
    content: "";
    position: absolute;
    top: 39px;
    left: calc(50% - 20px);
    width: 40px;
    height: 3px;
    background: #000;
}

.page-certifications {

}

.page-certifications .wp-block-columns {
	gap: 0 !important;
}


.page-certifications .wp-block-column {
}

.page-certifications .wp-block-group{
	display: block;
	padding:15px;
	color:#666;
	text-align:center;
}
.page-certifications .wp-block-group .wp-block-image{
	width:100%;
	max-width:100%;
	height:auto;
}
.page-certifications .wp-block-group .wp-block-heading{
	margin-bottom:0px;
	color:#666;
}

.page-certifications .wp-block-group p {
	margin-bottom:0px;
	font-size:0.95rem;
}
.page-certifications .wp-block-group:hover {
	border-radius: var(--bs-border-radius-xl) !important;
    box-shadow: var(--bs-box-shadow) !important;
    transition: all 0.3s ease;
	color:#000;
}
.page-certifications .wp-block-group:hover .wp-block-heading{
	color:#000;
}
/* owl-carousel-certificate-roll
-------------------------------------------------- */
.owl-carousel-certificate-roll {
	-webkit-transition-timing-function: linear;    /*Ö®Ç°ÊÇease-out*/
  	-moz-transition-timing-function: linear;
  	-ms-transition-timing-function: linear;
  	-o-transition-timing-function: linear;
  	transition-timing-function: linear;
}


.owl-carousel-certificate-roll .owl-nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}



.owl-carousel-certificate-roll .owl-nav .owl-next span,
.owl-carousel-certificate-roll .owl-nav .owl-prev span{
  display: inline-block;
  font-size:2em;
  border:solid 2px #df2919;
  border-radius:50%;
  width:1.725em;
  height:1.725em;
  line-height:1.5em;
  background:none;
  background-repeat: no-repeat;
  background-position: 50%;
  background-size: 100% 100%;
  outline: none;
  margin:30px 10px 0px 10px;
  color: #df2919;
  }


.owl-carousel-certificate-roll .owl-nav .owl-next span:hover,.owl-carousel-certificate-roll .owl-nav .owl-prev span:hover {
  background:#df2919;
  color: #fff;
}




.owl-carousel-certificate-roll .owl-dots {
	margin-top:30px;
	text-align:center;

   
}
.owl-carousel-certificate-roll .owl-dots .owl-dot {
	display:inline-block;
	zoom:1;
	outline: none;
}
.owl-carousel-certificate-roll .owl-dots .owl-dot span {
	width:15px;
	height:4px;
	margin:0px 5px;
	background:#D6D6D6;
	display:block;
	-webkit-backface-visibility:visible;
	transition:opacity .2s ease;
	border-radius:0px
}
.owl-carousel-certificate-roll .owl-dots .owl-dot.active span,.owl-carousel-certificate-roll .owl-dots .owl-dot:hover span {
	background:#df2919;

}

.timeline-outer {
    position: relative;
    width: 100%;
	height:auto;
    overflow: hidden;
}

.timeline-axis {
    position: absolute;
    top: 300px;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--line-color);
    z-index: 1;
    pointer-events: none;
}

.timeline-viewport {
    overflow: hidden;
    position: relative;
    z-index: 2;
}

.timeline-track {
    display: flex;
    transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
    will-change: transform;
}

.t-item {
    flex: 0 0 calc(100% / 5);
    position: relative;
    height: 600px;
    cursor: pointer;
}

.t-item.top .card-wrap {
    position: absolute;
    top: 360px;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    max-width: 850px;
}
@media (min-width: 767px) {
.t-item.top .card-wrap {
	min-width:300px;
}
}
.t-item.top .year-label {
    position: absolute;
    top: 210px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 14px;
    color: #999;
    font-weight: 500;
    transition: all 0.3s ease;
    user-select: none;
}

.t-item.top .dot {
    position: absolute;
    top: 251px;
    left: 50%;
    transform: translateX(-50%);
    width: 18px;
    height: 18px;
    border: 2px solid var(--dot-color);
    border-radius: 50%;
    background: #fff;
    transition: all 0.3s ease;
    z-index: 3;
}

.t-item.top .dot::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 6px;
    height: 6px;
    background: var(--dot-color);
    border-radius: 50%;
    transition: all 0.3s ease;
}

.t-item.top .connect-line {
    position: absolute;
    top: 269px;
    left: 50%;
    transform: translateX(-50%);
    width: 2px;
    height: 31px;
    background: var(--line-color);
    transition: all 0.3s ease;
}

.t-item.bottom .card-wrap {
    position: absolute;
    bottom: 360px;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    max-width: 850px;
}
@media (min-width: 767px) {
.t-item.bottom .card-wrap {
	min-width:300px;
}
}
.t-item.bottom .year-label {
    position: absolute;
    top: 365px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 14px;
    color: #999;
    font-weight: 500;
    transition: all 0.3s ease;
    user-select: none;
}

.t-item.bottom .dot {
    position: absolute;
    top: 331px;
    left: 50%;
    transform: translateX(-50%);
    width: 18px;
    height: 18px;
    border: 2px solid var(--dot-color);
    border-radius: 50%;
    background: #fff;
    transition: all 0.3s ease;
    z-index: 3;
}

.t-item.bottom .dot::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 6px;
    height: 6px;
    background: var(--dot-color);
    border-radius: 50%;
    transition: all 0.3s ease;
}

.t-item.bottom .connect-line {
    position: absolute;
    top: 300px;
    left: 50%;
    transform: translateX(-50%);
    width: 2px;
    height: 31px;
    background: var(--line-color);
    transition: all 0.3s ease;
}

.card-wrap {
    opacity: 0;
    visibility: hidden;
    transition: all 0.35s ease;
    z-index: 10;
}

.info-card {
    background: var(--card-bg);
    border: 1px solid #e0e0e0;
    border-radius: 10px;
    padding: 18px;
    box-shadow: 0 6px 24px rgba(0,0,0,0.00);
    display: flex;
    gap: 14px;
    align-items: flex-start;
}

.info-card .card-img {
    width: 100px;
    height: 80px;
    background: #d0d0d0;
    border-radius: 6px;
    flex-shrink: 0;
}

.info-card .card-body {
    flex: 1;
    min-width: 0;
}

.info-card .card-title {
    font-size: 15px;
    font-weight: 600;
    color: #333;
    margin-bottom: 6px;
    line-height: 1.4;
}

.info-card .card-text {
    font-size: 12px;
    color: #777;
    line-height: 1.6;
    margin: 0;
}

.t-item.active .year-label {
    color: var(--active-color);
    font-weight: 700;
    font-size: 16px;
}

.t-item.active .dot {
    border-color: var(--active-color);
    border-width: 3px;
    width: 22px;
    height: 22px;
}

.t-item.active .dot::after {
    background: var(--active-color);
    width: 8px;
    height: 8px;
}

.t-item.active .connect-line {
    background: var(--active-color) !important;
}

.t-item.active .card-wrap {
    opacity: 1;
    visibility: visible;
}

.t-item:not(.active):hover .card-wrap {
    opacity: 1;
    visibility: visible;
    transition-delay: 0.08s;
}

.t-item:not(.active):hover .year-label {
    color: #555;
}

.t-item:not(.active):hover .dot {
    border-color: #666;
    transform: translateX(-50%) scale(1.15);
}

.t-control {
    position: absolute;
    top: 280px;
    width: 44px;
    height: 44px;
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 20;
    transition: all 0.25s ease;
    box-shadow: 0 2px 10px rgba(0,0,0,0.08);
}

.t-control:hover {
    background: var(--active-color);
    border-color: var(--active-color);
}

.t-control:hover svg { stroke: #fff; }

.t-control.prev { left: 16px; }
.t-control.next { right: 16px; }

.t-control svg {
    width: 18px;
    height: 18px;
    stroke: #666;
    stroke-width: 2.5;
    fill: none;
    stroke-linecap: round;
    stroke-linejoin: round;
}

@media (max-width: 991px) {
    .t-item { flex: 0 0 calc(100% / 3); }
}

@media (max-width: 767px) {
    .t-item { flex: 0 0 calc(100% / 2); }
    .info-card { flex-direction: column; }
    .info-card .card-img { width: 100%; height: 100px; }
}

@media (max-width: 480px) {
    .t-item { flex: 0 0 100%; }
}



/* Left Visual - Sticky with Images */
        .visual-col {
            position: sticky;
            top: 0;
            height: 100vh;
            display: flex;
            align-items: center;
            justify-content: center;
            overflow: hidden;
            
        }

        .visual-wrapper {
            position: relative;
            width: 100%;
            height: 100%;
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .step-image {
            position: absolute;
            width: 85%;
            max-width: 520px;
            aspect-ratio: 1 / 1;
            object-fit: cover;
            border-radius: 1rem;
            opacity: 0;
            transform: scale(0.92) translateY(20px);
            transition: all 0.8s cubic-bezier(0.16, 1, 0.3, 1);
            box-shadow: 0 20px 60px rgba(45, 62, 54, 0.12);
            pointer-events: none;
        }

        .step-image.active {
            opacity: 1;
            transform: scale(1) translateY(0);
            pointer-events: auto;
        }

        /* Step number badge on image */
        .image-badge {
            position: absolute;
            top: 8%;
            right: 12%;
            width: 44px;
            height: 44px;
            background: rgba(45, 62, 54, 0.9);
            color: #fff;
            border-radius: 10px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-weight: 700;
            font-size: 1rem;
            opacity: 0;
            transform: scale(0.6);
            transition: all 0.5s cubic-bezier(0.34, 1.56, 0.64, 1) 0.2s;
            z-index: 10;
            box-shadow: 0 4px 20px rgba(0,0,0,0.15);
        }

        .step-image.active ~ .image-badge,
        .step-image.active + .image-badge,
        .image-badge.active {
            opacity: 1;
            transform: scale(1);
        }

        /* Floating particles decoration */
        .particle {
            position: absolute;
            border-radius: 50%;
            background: rgba(74, 124, 89, 0.08);
            pointer-events: none;
            animation: float 8s ease-in-out infinite;
        }

        @keyframes float {
            0%, 100% { transform: translateY(0) translateX(0); }
            33% { transform: translateY(-20px) translateX(10px); }
            66% { transform: translateY(10px) translateX(-10px); }
        }

        /* Right Content */
        .steps-col {
            border-left: 1px solid var(--border);
            position: relative;
        }

        .step-item {
            min-height: 25vh;
            padding: 3rem 3rem;
            border-bottom: 1px solid var(--border);
            display: flex;
            flex-direction: column;
            justify-content: center;
            transition: all 0.6s ease;
            position: relative;
        }

        .step-item:last-child {
            padding-top:0rem;
			border-bottom: none;
            min-height: 100vh;
        }

        .step-item.inactive {
            opacity: 0.35;
        }

        .step-item.active {
            opacity: 1;
        }

        .step-number {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            width: 32px;
            height: 32px;
            background: var(--bs-dark);
            color: #fff;
            border-radius: 6px;
            font-weight: 600;
            font-size: 0.9rem;
            margin-right: 0.75rem;
            transition: all 0.4s ease;
        }

        .step-item.inactive .step-number {
            background: transparent;
            color: var(--dot-inactive);
            border: 2px solid var(--dot-inactive);
        }

        .step-title {
           
            font-weight: 500;
            margin-bottom: 1.25rem;
            display: flex;
            align-items: center;
            letter-spacing: -0.02em;
            transition: color 0.4s;
        }

        .step-item.inactive .step-title {
            color: var(--dot-inactive);
        }

        .step-desc {
            font-size: 1.05rem;
            line-height: 1.7;
            color: var(--muted);
            max-width: 480px;
            transition: opacity 0.4s;
        }

        .step-item.inactive .step-desc {
            opacity: 0.6;
        }

        .step-dot {
            position: absolute;
            right: 2rem;
            top: 50%;
            transform: translateY(-50%);
            width: 10px;
            height: 10px;
            border-radius: 50%;
            background: var(--dot-inactive);
            transition: all 0.4s ease;
        }

        .step-item.active .step-dot {
            background: var(--dot-active);
            transform: translateY(-50%) scale(1.3);
        }

        /* Progress line on right */
        .progress-track {
            position: absolute;
            right: 2.4rem;
            top: 0;
            bottom: 0;
            width: 2px;
            background: var(--border);
            z-index: 0;
        }

        .progress-fill {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            background: var(--bs-dark);
            transition: height 0.5s ease;
        }

       

        /* Responsive */
        @media (max-width: 991px) {
            .visual-col {
                position: relative;
                height: 50vh;
                border-bottom: 1px solid var(--border);
            }

            .step-image {
                width: 70%;
                max-width: 320px;
            }

            .steps-col {
                border-left: none;
            }

            .step-item {
                min-height: auto;
                padding: 3rem 1.5rem;
            }

            .step-dot, .progress-track {
                display: none;
            }
        }