/*
Theme Name: VGEC
Description: This is a child theme for Flatsome Theme
Author: UX Themes
Template: flatsome
Version: 3.0
*/

/*************** ADD CUSTOM CSS HERE.   ***************/


@media only screen and (max-width: 48em) {
/*************** ADD MOBILE ONLY CSS HERE  ***************/


}

.tts-list-benefits p,.tts-title-program p
{
margin-bottom:0px !important;
}

.tts-list-benefits
{
	display:flex; 
	align-items:center;
}












.japan-intern-timeline-section {
    overflow: hidden;
}

.japan-timeline-wrapper {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;
    position: relative;
    margin: 70px 0 30px;
    padding: 0 20px;
}

.japan-timeline-wrapper::before {
    content: '';
    position: absolute;
    top: 60px;
    left: 8.33%;
    right: 8.33%;
    height: 4px;
    background: #ddd;
    border-radius: 2px;
    z-index: 1;
}

.timeline-item {
    flex: 1;
    min-width: 140px;
    text-align: center;
    position: relative;
    z-index: 2;
}

.timeline-circle {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    margin: 0 auto 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    box-shadow: 0 8px 25px rgba(0,0,0,0.15);
    transition: all 0.3s ease;
}

.timeline-circle i {
    font-size: 48px;
    color: #fff;
}

.timeline-circle::after {
    content: '';
    position: absolute;
    top: 50%;
    right: -46px;
    width: 36px;
    height: 36px;
    background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="%23999"><path d="M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z"/></svg>') no-repeat center;
    background-size: 24px;
    transform: translateY(-50%);
    z-index: 3;
}

/* Bá» mÅ©i tÃªn cuá»‘i cÃ¹ng */
.timeline-item:last-child .timeline-circle::after {
    display: none;
}

.bg-teal { background: linear-gradient(135deg, #1abc9c, #16a085); }
.bg-green { background: linear-gradient(135deg, #2ecc71, #27ae60); }
.bg-pink { background: linear-gradient(135deg, #e91e63, #c2185b); }
.bg-purple { background: linear-gradient(135deg, #9c27b0, #7b1fa2); }
.bg-blue { background: linear-gradient(135deg, #3498db, #2980b9); }
.bg-orange { background: linear-gradient(135deg, #e67e22, #d35400); }

.timeline-number {
    font-size: 32px;
    font-weight: 900;
    color: #2c3e50;
    margin-bottom: 12px;
    line-height: 1;
}

.timeline-label {
    font-size: 15px;
    font-weight: 600;
    color: #2c3e50;
    line-height: 1.4;
    max-width: 140px;
    margin: 0 auto;
}

/* Hover effect */
.timeline-circle:hover {
    transform: translateY(-8px) scale(1.05);
    box-shadow: 0 15px 35px rgba(0,0,0,0.2);
}

/* Responsive */
@media (max-width: 849px) {
    .japan-timeline-wrapper {
        flex-direction: column;
        align-items: center;
        margin: 40px 0;
    }
    .japan-timeline-wrapper::before {
        display: none;
    }
    .timeline-item {
        margin-bottom: 40px;
    }
    .timeline-circle::after {
        display: none !important;
    }
    .timeline-circle {
        width: 100px;
        height: 100px;
    }
    .timeline-circle i {
        font-size: 40px;
    }
    .timeline-number {
        font-size: 28px;
    }
}

@media (max-width: 549px) {
    .timeline-label {
        font-size: 14px;
    }
    .timeline-main-title {
        font-size: 28px !important;
    }
}







































@media(min-width:1024px)
{
	.sliderbanner 
	{
		margin-bottom:-150px !important;
	}
}






/* ============== CHÆ¯Æ NG TRÃŒNH THá»°C Táº¬P SINH 2025 ============== */
.section-thuctapsinh-2025 {
    background: linear-gradient(135deg, #fdfdfd 0%, #ffffff 100%);
    position: relative;
    overflow: hidden;
}

/* Chá»¯ "ChÆ°Æ¡ng trÃ¬nh" viáº¿t tay */
.tts-title-program h2,
.tts-title-program h3,
.tts-title-program {
    font-family: 'Dancing Script', 'Great Vibes', cursive !important;
    font-size: 52px !important;
    color: #2c3e50 !important;
    margin: 0 0 8px 0 !important;
    position: relative;
}
.tts-title-program:after {
    content: "";
    display: block;
    width: 80px;
    height: 3px;
    background: #2c3e50;
    margin: 15px 0 25px;
    border-radius: 3px;
}

/* TiÃªu Ä‘á» lá»›n */
.tts-big-title {
    font-size: 24px !important;
    line-height: 1.3 !important;
    margin: 0 !important;
}
.tts-big-title strong,
.tts-big-title span:first-child {
    color: #e74c3c;
    font-weight: 800 !important;
    display: block;
}
.tts-big-title span:last-child {
    color: #f39c12;
    font-size: 48px !important;
    font-weight: 900 !important;
    text-shadow: 3px 3px 10px rgba(0,0,0,0.15);
}

/* Danh sÃ¡ch lá»£i Ã­ch */
.tts-list-benefits {
    font-size: 19px !important;
    line-height: 2 !important;
    color: #2c3e50 !important;
    font-weight: 600 !important;
}
.tts-list-benefits br {
    content: "";
}
.tts-list-benefits:before {
    content: "âœ“";
    color: #27ae60;
    font-weight: bold;
    font-size: 26px;
    margin-right: 12px;
    vertical-align: middle;
}

/* NÃºt TÆ° váº¥n ngay */
.btn-tts-consult {
    background: #2c3e50 !important;
    box-shadow: 0 10px 25px rgba(44,62,80,0.3) !important;
    padding-left: 50px !important;
    padding-right: 50px !important;
}
.btn-tts-consult .ux-btn-icon {
    margin-right: 12px !important;
}
.btn-tts-consult:after {
    content: "â†’";
    margin-left: 15px;
    font-size: 20px;
}

/* Responsive mobile */
@media (max-width: 767px) {
    .tts-big-title { font-size: 20px !important; }
    .tts-big-title span:last-child { font-size: 38px !important; }
    .tts-list-benefits { font-size: 17px !important; }
}







/* Job Opportunity Section */
.job-opportunity-section {
  position: relative;
  overflow: visible;
}

.job-opportunity-section .row {
  max-width: 1200px;
  margin: 0 auto;
  align-items: center;
}

/* Images Layout */
.job-opportunity-section .col:first-child {
  position: relative;
  padding: 20px;
}

.job-opportunity-section .ux-image {
  transition: transform 0.4s ease, box-shadow 0.4s ease;
}

.job-opportunity-section .ux-image:hover {
  transform: translateY(-5px);
  box-shadow: 0 15px 40px rgba(0, 0, 0, 0.15);
}

/* Title Styles */
.job-title {
  margin-bottom: 20px;
}

.job-title h2 {
  color: #333;
  font-size: 26px;
  font-weight: bold;
  margin: 8px 0;
  line-height: 1.3;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.job-title .title-red {
  color: #e74c3c;
  margin-top: 5px;
}

/* Description Styles */
.job-description {
  margin: 25px 0 30px 0;
}

.job-description p {
  color: #555;
  font-size: 17px;
  line-height: 1.8;
  margin: 0;
}

/* CTA Button */
.job-cta-button {
  margin-top: 10px;
  transition: all 0.3s ease;
  padding: 15px 40px;
  background: #ffc200;
  color: #333;
  font-weight: 700;
  border-radius: 50px !important;
  line-height: 1;
  text-transform: none;
  font-size: 20px;
}

.job-cta-button:hover {
  transform: translateX(5px);
  box-shadow: 0 8px 20px rgba(255, 193, 7, 0.4);
}

/* Divider Styles */
.job-opportunity-section .divider {
  opacity: 0.3;
}

/* Responsive */
@media (max-width: 768px) {
  .job-opportunity-section {
    padding: 40px 20px !important;
  }
  
  .job-opportunity-section .col:first-child {
    margin-bottom: 30px;
  }
  
  .job-title h2 {
    font-size: 20px !important;
  }
  
  .job-description p {
    font-size: 14px;
  }
  
  .job-opportunity-section .ux-image:nth-child(2) {
    margin: 20px 0 0 0 !important;
    width: 100% !important;
  }
  
  .job-cta-button {
    width: 100%;
  }
}

/* Animation */
.job-opportunity-section .col {
  animation: fadeInUp 0.8s ease forwards;
  opacity: 0;
}

.job-opportunity-section .col:nth-child(1) {
  animation-delay: 0.2s;
}

.job-opportunity-section .col:nth-child(2) {
  animation-delay: 0.4s;
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
































.thanhtuu .col-inner
{
	display: flex;
  align-items: center;
  padding-left: 20px;
	padding-top:10px;
	height:100%;
	border-radius: 30px 0px 30px 0px;
	text-align: center;
    justify-content: center;
}


.thanhtuu .button 
{
	  font-size: 1.2rem;
    display: inline-block;
    background: #ffda00;
    color: black;
    font-weight: 700;
    padding: 0px 3rem;
    border-radius: 7px;
}









/* ==================== VIá»†C LÃ€M NHáº¬T Báº¢N â€“ Äáº¸P Y Há»†T HÃŒNH Má»šI NHáº¤T ==================== */

.japan-job-section {
	
    background: #ffffff;
    /* margin: 50px auto; */
    max-width: 100%;
    position: relative;
    justify-content: center;
}

.japan-job-section .rowtab .tab-panels
{
	padding:0px !important;
	border:unset !important;
}

.japan-job-section .rowtab{
  border: 2px solid #dc2626 !important;
    border-radius: 10px !important;
    overflow: hidden;
   justify-content: center;
	
}

/* TiÃªu Ä‘á» chÃ­nh */
.japan-job-section h2 {
    font-size: 46px !important;
    font-weight: 900 !important;
    color: #1e1e1e !important;
    margin: 0 0 45px !important;
    padding-top: 35px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* 4 TAB Äá»Ž BO TRÃ’N â€“ giá»‘ng há»‡t hÃ¬nh */
.japan-tabs .nav-tabs {
display: flex;
justify-content: space-between;
    flex-wrap: wrap;
    gap: 14px;
    border: none !important;
    padding: 0 30px 35px;
	margin-top:30px;
    margin-bottom: 0 !important;
}
.japan-tabs .nav-tabs > li > a {
    background: #991b1b !important;
    color: #ffffff !important;
    font-weight: 700;
    font-size: 17px;
    padding: 5px 34px !important;
    border-radius: 10px !important;
    border: none !important;
	text-transform:initial !important;
    transition: all 0.35s ease;
    box-shadow: 0 6px 18px rgba(153, 27, 27, 0.35);
}
.japan-tabs .nav-tabs > li.active > a,
.japan-tabs .nav-tabs > li > a:hover {
    background: #dc2626 !important;
/*     transform: translateY(-6px); */
/*     box-shadow: 0 14px 30px rgba(220, 38, 38, 0.5) !important; */
	
}

/* Báº£ng lÆ°Æ¡ng â€“ header há»“ng nháº¡t, dÃ²ng káº» Ä‘á» nháº¡t */
.job-table {
    width: 100%;
    max-width: 100%;
    margin: 0px;
    border-collapse: separate;
    border-spacing: 0;
     background: transparent !important;
/*     border-radius: 20px; */
    overflow: hidden;
/*     box-shadow: 0 15px 40px rgba(0, 0, 0, 0.1); */
    font-size: 17px;
}
.job-table thead th {
   
    color: #991b1b;
    padding: 22px 10px;
    font-weight: 800;
    font-size: 17px;
    text-transform: uppercase;
    border-bottom: 3px solid #cd3c3f;
	
}
.job-table tbody td {
    padding: 10px 18px;
    text-align: left;
    color: black;
    border-bottom: 1px solid #cd3c3f;
}
.job-table tbody tr:last-child td {
    border-bottom: none;
}



/* NÃºt hotline Ä‘á» + TÆ° váº¥n ngay vÃ ng â€“ giá»‘ng há»‡t hÃ¬nh */
.hotline-btn,
.consult-btn {
    display: inline-block;
    font-size: 24px;
    font-weight: 900;
    padding: 0px 20px;
    border-radius: 50px;
    text-decoration: none;
    margin: 15px 20px;
    transition: all 0.4s ease;
    box-shadow: 0 12px 35px rgba(0,0,0,0.22);
}
.hotline-btn {
    background: #991b1b;
    color: #ffffff;
}
.hotline-btn:hover {
    background: #7f1d1d;
    transform: translateY(-7px);
    box-shadow: 0 20px 45px rgba(153,27,27,0.5);
}
.consult-btn {
    background: linear-gradient(90deg, #fbbf24, #f59e0b);
    color: #1f2937;
}
.consult-btn:hover {
    transform: translateY(-7px);
    box-shadow: 0 20px 45px rgba(251, 187, 36, 0.6);
}

/* Responsive hoÃ n háº£o */
@media (max-width: 849px) {
    .japan-tabs .nav-tabs {
        gap: 10px;
        padding: 0 15px 30px;
    }
    .japan-tabs .nav-tabs > li > a {
        padding: 14px 22px !important;
        font-size: 15.5px;
    }
    .japan-job-section h2 {
        font-size: 36px !important;
    }
    .hotline-btn,
    .consult-btn {
        display: block;
        width: 88%;
        margin: 18px auto;
        font-size: 22px;
    }
    .job-table {
        font-size: 15px;
    }
    .job-table thead th,
    .job-table tbody td {
        padding: 16px 10px;
    }
}



.nang-dong-sang-tao{
	background-color: #DD1D2C;
	color: white;
	
}
.nang-dong-sang-tao H3{
	color: white;
	
}
.luon-luon-tich-cuc{
		background-color: #FDCD2E;
	  color: white;
}
.cong-dan-toan-cau{
		background-color: #000;
	  color: white;
	height:893px;
}
.cong-dan-toan-cau H3{
	  color: white;
}

.doinet img
{
	border-radius:10px;
}

.doinet .video 
{
		border-radius:10px;
}

.warning-section-custom-right .divider
{
	    max-width: 100%;
    height: 1px;
    background-color: transparent !important;
    border-bottom: 2px dashed;
}

























/* === HERO BANNER === */
.hero-banner-section {
  /* background: linear-gradient(135deg, #ffe4e4 0%, #ffd4d4 100%); */
}

.hero-title h1 {
  color: #c62828;
  font-size: 42px;
  font-weight: bold;
  margin: 0 0 15px 0;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.hero-title h2 {
  color: #333;
  font-size: 24px;
  font-weight: 600;
  margin: 0 0 25px 0;
}

.hero-title p {
  color: #555;
  font-size: 16px;
  margin: 8px 0;
  line-height: 1.8;
}

.hero-cta {
  margin-top: 30px;
  animation: pulse 2s infinite;
}

/* === SECTION TITLES === */
.section-title h2 {
  color: #c62828;
  font-size: 32px;
  font-weight: bold;
  text-transform: uppercase;
  /* margin: 0 0 40px 0; */
  position: relative;
  display: inline-block;
  margin: 0px;
  padding: 5px 10px;
}

.section-title h2::after {
  content: '';
  position: absolute;
  /* bottom: -10px; */
  left: 50%;
  transform: translateX(-50%);
  /* width: 80px; */
  /* height: 3px; */
  /* background: #c62828; */
}

.section-title p {
  color: #666;
  font-size: 16px;
  margin-top: 20px;
}

/* === BENEFITS SECTION === */
.benefit-list ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.benefit-list ul li {
  color: #333;
  font-size: 16px;
  padding: 12px 0;
  border-bottom: 1px solid #f0f0f0;
  transition: all 0.3s ease;
}

.benefit-list ul li:hover {
  color: #c62828;
  padding-left: 10px;
  background: #fff;
}

/* === STEPS SECTION === */
.step-box .col-inner {
  background: #fff;
  padding: 30px 20px !important;
  border-radius: 15px;
  /* box-shadow: 0 5px 20px rgba(0,0,0,0.08); */
  transition: all 0.3s ease;
  height: 100%;
  border: 2px dashed #233c5e;
}



.step-number {
  width: 60px;
  height: 60px;
  background: #c62828;
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  font-weight: bold;
  margin: 0 auto 20px;
}

.step-box h4 {
  color: #333;
  font-size: 18px;
  font-weight: bold;
  margin: 15px 0;
  text-transform: uppercase;
}

.step-box p {
  color: #666;
  font-size: 14px;
  line-height: 1.7;
  margin: 0;
}

/* === TIMELINE === */
.timeline-content {
  max-width: 800px;
  margin: 40px auto;
}

.timeline-item {
  display: flex;
  align-items: center;
  margin: 25px 0;
  padding: 20px;
  /* background: #fff; */
  /* border-radius: 10px; */
  /* box-shadow: 0 3px 15px rgba(0,0,0,0.08); */
  transition: all 0.3s ease;
}

.timeline-item:hover {
  transform: translateX(10px);
  box-shadow: 0 5px 25px rgba(198,40,40,0.15);
}

.timeline-item .row 
{
	margin-bottom: 10px;
}

.timeline-item .row  p
{
	margin-bottom:0px; 
}

.timeline-month {
  min-width: 120px;
  background: #ffe684;
  color: #111c2d;
  padding: 15px 20px;
  /* border-radius: 8px; */
  font-weight: bold;
  text-align: center;
  /* margin-right: 25px; */
  display: flex;
  align-items: center;
  border-right: 5px solid #233c5e;
}

.timeline-desc {
  color: #555;
  font-size: 15px;
  line-height: 1.6;
}

/* === IMAGE CAPTIONS === */
.image-caption {
  margin-top: 20px;
}

.image-caption h4 {
  color: #c62828;
  font-size: 18px;
  font-weight: bold;
  margin: 0 0 10px 0;
  text-transform: uppercase;
}

.image-caption p {
  color: #666;
  font-size: 14px;
  line-height: 1.6;
  margin: 0;
}

.doc-caption p {
  color: #555;
  font-size: 14px;
  font-weight: 600;
  margin: 15px 0 0 0;
}

.health-caption {
  margin-top: 30px;
}

.health-caption p {
  color: #666;
  font-size: 16px;
  line-height: 1.7;
}

/* === FAQ SECTION === */
.faq-list {
  max-width: 900px;
  margin: 0 auto;
}

.faq-item {
  display: flex;
  background: #fff;
  padding: 25px;
  margin: 20px 0;
  border-radius: 12px;
  box-shadow: 0 3px 15px rgba(0,0,0,0.08);
  transition: all 0.3s ease;
}

.faq-item:hover {
  box-shadow: 0 8px 30px rgba(198,40,40,0.15);
  transform: translateY(-3px);
}

.faq-number {
  min-width: 50px;
  height: 50px;
  background: #c62828;
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  font-weight: bold;
  margin-right: 20px;
}

.faq-content h4 {
  color: #333;
  font-size: 17px;
  font-weight: bold;
  margin: 0 0 12px 0;
}

.faq-content p {
  color: #666;
  font-size: 15px;
  line-height: 1.7;
  margin: 0;
}

/* === CONTACT INFO === */
.contact-name h4 {
  color: #c62828;
  font-size: 18px;
  font-weight: bold;
  margin: 15px 0 5px 0;
  text-transform: uppercase;
}

.contact-name p {
  color: #666;
  font-size: 14px;
  margin: 0;
}

.contact-details h3 {
  color: #c62828;
  font-size: 24px;
  font-weight: bold;
  margin: 0 0 20px 0;
  text-transform: uppercase;
}

.contact-details p {
  color: #555;
  font-size: 16px;
  margin: 12px 0;
  line-height: 1.8;
}

/* === FOOTER CTA === */
.footer-cta-text h3 {
  color: #fff;
  font-size: 28px;
  font-weight: bold;
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.footer-cta-button {
  margin-top: 20px;
  transition: all 0.3s ease;
}

.footer-cta-button:hover {
  transform: scale(1.05);
  box-shadow: 0 8px 25px rgba(255,255,255,0.3);
}

/* === ANIMATIONS === */
@keyframes pulse {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.05);
  }
}

/* === RESPONSIVE === */
@media (max-width: 768px) {
  .hero-title h1 {
    font-size: 28px !important;
  }
  
  .hero-title h2 {
    font-size: 18px !important;
  }
  
  .section-title h2 {
    font-size: 24px !important;
  }
  
  .step-box {
    margin-bottom: 20px;
  }
  
  .timeline-item {
    flex-direction: column;
    text-align: center;
  }
  
  .timeline-month {
    margin-right: 0;
    margin-bottom: 15px;
  }
  
  .faq-item {
    flex-direction: column;
    text-align: center;
  }
  
  .faq-number {
    margin: 0 auto 15px;
  }
  
  .footer-cta-text h3 {
    font-size: 20px !important;
  }
}