/**/


.vt_service {
	padding-top: 36px;
	background: #fff;

	.about-grid {
		display: grid;
		grid-template-columns: 1fr;
		align-items: center;
		gap: 60px;

		@media (max-width: 992px) {
			grid-template-columns: 1fr;
		}
	}

	&.v2 .about-grid {

		.about-content {
			text-align: center;

			.btn_detail {
				display: none;
			}
		}
	}

	.about-content {
		h2 {
			font-size: 38px;
			font-weight: 800;
			color: #222;
			margin-top: 15px;
			margin-bottom: 24px;
			line-height: 1.5;

			@media (max-width: 768px) {
				font-size: 30px;
			}
		}
		h3 {
			color: #333;
			font-size: 16px;
			font-weight: bold;
			line-height: 1.7;
			margin-bottom: 20px;
			text-align: center
		}
		p {
			color: #333;
			font-size: 16px;
			line-height: 1.7;
			margin-bottom: 20px;
			text-align: center
		}
	}
}

.vt_cat_dautu {
    position: relative;
    margin-top: 60px;
    background: #fff;
    z-index: 1;
  
	.container {
		position: relative;
	}
	.section-header {
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        margin-bottom: 40px;
		h2 {
            font-size: 28px;
            font-weight: 700;
            text-transform: uppercase;
            line-height: 1.3;
			margin: 0;
        }
		.right-bot {
            
        }
		@media (max-width: 768px) {
			.right-bot {
				text-align: -webkit-center;
				margin-top: 20px;
			}
		}
    }
	@media (max-width: 768px) {
		.section-header {
			display: block;
		}
	}

  .dautuSwiper  {
    overflow: hidden !important;
  }

  .section-title {
    text-align: left;
    font-size: 38px;
    font-weight: 800;
    color: #111;
    margin-bottom: 50px;
	  @media (max-width: 768px) {
		font-size: 30px;
		margin-bottom: 20px;
		text-align: center;
	  }
  }

  .swiper {
    overflow: visible;
    padding-bottom: 10px;
    position: relative;
  }

  .news-card {
    background: #fff;
    border-radius: 14px;
    box-shadow: 0 2px 15px rgba(0, 0, 0, 0.05);
    padding: 20px;
    transition: all 0.3s ease;
	text-align: center;

    &:hover {
      transform: translateY(-6px);
      box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1);
    }
	.view-more {
		text-align: -webkit-center;
	}
    .img-box {
      width: 100%;
      aspect-ratio: 4/3;
      border-radius: 12px;
      overflow: hidden;
      background: #d9d9d9;
      margin-bottom: 15px;

      img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        transition: transform 0.3s ease;
      }

      &:hover img {
        transform: scale(1.05);
      }
    }

    .meta {
      display: flex;
      align-items: center;
      gap: 20px;
      color: #666;
      font-size: 14px;
      margin-bottom: 10px;

      i {
        margin-right: 5px;
        color: #999;
      }
    }

    h3 {
      font-size: 16px;
      font-weight: 700;
      color: #003366;
      margin-bottom: 10px;
    text-overflow: ellipsis;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;

      a {
        color: inherit;
        text-decoration: none;
        transition: color 0.3s ease;

        &:hover {
          color: #00aaff;
        }
      }
    }

    p {
      font-size: 14px;
      color: #555;
      line-height: 1.6;
      margin-bottom: 10px;
    text-overflow: ellipsis;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
	text-align: left;
    }
  }

  /* Swiper navigation */
  .swiper-button-prev,
  .swiper-button-next {
    color: #888;
    width: 40px;
    height: 40px;
    background: #f3f3f3;
    border-radius: 50%;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    transition: all 0.3s ease;

    &:after {
      font-size: 16px;
      font-weight: bold;
    }

    &:hover {
      background: #00aaff;
      color: #fff;
    }
  }

  .swiper-button-prev {
    left: -30px;
  }

  .swiper-button-next {
    right: -30px;
  }

  .view-all {
	display: flex;
	margin-top: 30px;
	justify-content: center;
    .btn-primary-outline {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      border: 1.5px solid #00aaff;
      color: #00aaff;
      border-radius: 50px;
      padding: 10px 22px;
      font-weight: 600;
      text-decoration: none;
      transition: all 0.3s ease;

      i {
        background: #00aaff;
        color: #fff;
        border-radius: 50%;
        padding: 8px;
        font-size: 14px;
      }

      &:hover {
        background: #00aaff;
        color: #fff;

        i {
          background: #fff;
          color: #00aaff;
        }
      }
    }
  }

  @media (max-width: 768px) {
    .swiper-button-prev,
    .swiper-button-next {
      display: none;
    }
  }
}
.vt_tuvansg {
	.consultation-box {
		margin-right: 19% !important;
	}
	.consultation-container {
		width: 100vw;
		margin-left: calc(50% - 50vw);
	}
}
.vt_tuvan {
	padding-top: 36px;
	background: #fff;

	.about-grid {
		display: grid;
		grid-template-columns: 1fr;
		align-items: center;
		gap: 60px;

		@media (max-width: 992px) {
			grid-template-columns: 1fr;
		}
	}

	&.v2 {
		.about-grid {
			.about-content {
				text-align: center;
			}
		}
	}

	.consultation-container {
		background: url('../images/handshake-bg.jpg') no-repeat center center/cover;
		padding: 60px 0;
		display: flex;
		justify-content: flex-end;
		align-items: center;
	}

	.consultation-box {
		background: #0b2a56;
		padding: 40px 30px;
		border-radius: 10px;
		width: 480px;
		color: #fff;
		margin-right: 8%;
		transform: translateY(-120px);
		z-index: 1;

		h2 {
			font-size: 22px;
			font-weight: 700;
			margin-bottom: 10px;
			text-transform: uppercase;
		}

		p {
			font-size: 14px;
			margin-bottom: 25px;
			line-height: 1.6;
		}

		.consultation-form {
			.form-row {
				display: flex;
				gap: 10px;
				margin-bottom: 15px;

				@media (max-width: 768px) {
					flex-direction: column;
				}

				&.row-3 {
					display: grid;
					grid-template-columns: repeat(3, 1fr);
					gap: 10px;

					@media (max-width: 768px) {
						grid-template-columns: 1fr;
					}
				}
			}

			input,
			select,
			textarea {
				width: 100%;
				padding: 10px 12px;
				border: none;
				border-radius: 4px;
				font-size: 14px;
				font-family: "Montserrat", sans-serif;
			}

			textarea {
				resize: none;
				height: 80px;
				margin-bottom: 15px;
			}

			.form-footer {
				display: flex;
				align-items: center;
				justify-content: space-between;

				@media (max-width: 768px) {
					flex-direction: column;
					gap: 10px;
				}

				.captcha {
					display: flex;
					align-items: center;
					font-size: 13px;

					input {
						margin-right: 8px;
					}
				}

				.btn-submit {
					background: #2c7efc;
					color: #fff;
					border: none;
					padding: 10px 20px;
					border-radius: 50px;
					cursor: pointer;
					transition: 0.3s;
					font-family: "Montserrat", sans-serif;

					&:hover {
						background: #1b5fcc;
					}
				}
			}
		}
	}

	@media (max-width: 768px) {
		.consultation-box {
			width: 90%;
			margin: 0 auto;
			transform: unset;
			margin-right: 8% !important;
		}
	}
}

.dabdsm, .dabdsca {
  padding-top: 36px;
  background: #fff;
}
.vt_property {
	padding-bottom: 30px;
  .about-content {
	  text-align: center;
    h2 {
      font-size: 38px;
      font-weight: 800;
      color: #222;
      margin-top: 15px;
      margin-bottom: 24px;
      line-height: 1.5;
	  text-align: center;

      @media (max-width: 768px) {
        font-size: 30px;
      }
    }
	.sub-label {
      display: inline-block;
      background: #0a1f44; /* xanh navy như hình */
      color: #fff;
      font-size: 14px;
      font-weight: 600;
      padding: 6px 20px;
      border-radius: 20px;
      margin-bottom: 20px;
      text-transform: none;
    }

    p {
      color: #333;
      font-size: 16px;
      line-height: 1.7;
      margin-bottom: 20px;
      text-align: center;
    }
  }

  .property-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
    margin-top: 40px;

    @media (max-width: 1200px) { grid-template-columns: repeat(3, 1fr); }
    @media (max-width: 992px)  { grid-template-columns: repeat(2, 1fr); }
    @media (max-width: 576px)  { grid-template-columns: 1fr; }

    .property-item {
      text-align: center;
      padding: 20px;
      border: 1px solid #eee;
      border-radius: 12px;
      background: #fafafa;
      transition: all 0.3s ease;

      &:hover {
        transform: translateY(-5px);
        box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1);
      }

      .thumb {
        width: 100%;
        height: 160px;
        background: #ddd;
        border-radius: 8px;
        margin-bottom: 15px;
      }

      h3 {
        color: #333;
        font-size: 18px;
        font-weight: bold;
        line-height: 1.7;
        margin-bottom: 10px;
      }
	  .view-more {
            text-align: -webkit-center;
        }

      p {
        color: #555;
        font-size: 15px;
        line-height: 1.6;
        margin-bottom: 15px;
      }
	  
    }
  }

  /* Dự án nổi bật – dùng cùng phần tử với .vt_property */
  .vt_project {
    position: relative;
    margin-top: 60px;
    background: #fff;
    z-index: 1;
  
	.container {
		position: relative;
	}
	

  .dautuSwiper  {
    overflow: hidden !important;
  }

  .section-title {
    text-align: left;
    font-size: 38px;
    font-weight: 800;
    color: #111;
    margin-bottom: 50px;
	  @media (max-width: 768px) {
		font-size: 30px;
		margin-bottom: 20px;
		text-align: center;
	  }
  }

  .swiper {
    overflow: visible;
    padding-bottom: 10px;
    position: relative;
  }

  .news-card {
    background: #fff;
    border-radius: 14px;
    box-shadow: 0 2px 15px rgba(0, 0, 0, 0.05);
    padding: 20px;
    transition: all 0.3s ease;
	text-align: center;

    &:hover {
      transform: translateY(-6px);
      box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1);
    }
	

	.view-more {
		text-align: -webkit-center;
	}
    .img-box {
      width: 100%;
      aspect-ratio: 4/3;
      border-radius: 12px;
      overflow: hidden;
      background: #d9d9d9;
      margin-bottom: 15px;

      img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        transition: transform 0.3s ease;
      }

      &:hover img {
        transform: scale(1.05);
      }
    }

    .meta {
      display: flex;
      align-items: center;
      gap: 20px;
      color: #666;
      font-size: 14px;
      margin-bottom: 10px;

      i {
        margin-right: 5px;
        color: #999;
      }
    }

    h3 {
      font-size: 16px;
      font-weight: 700;
      color: #003366;
      margin-bottom: 10px;
    text-overflow: ellipsis;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;

      a {
        color: inherit;
        text-decoration: none;
        transition: color 0.3s ease;

        &:hover {
          color: #00aaff;
        }
      }
    }

    p {
      font-size: 14px;
      color: #555;
      line-height: 1.6;
      margin-bottom: 10px;
    text-overflow: ellipsis;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
	text-align: left;
    }
  }

  /* Swiper navigation */
  .swiper-button-prev,
  .swiper-button-next {
    color: #888;
    width: 40px;
    height: 40px;
    background: #f3f3f3;
    border-radius: 50%;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    transition: all 0.3s ease;

    &:after {
      font-size: 16px;
      font-weight: bold;
    }

    &:hover {
      background: #00aaff;
      color: #fff;
    }
  }

  .swiper-button-prev {
    left: -30px;
  }

  .swiper-button-next {
    right: -30px;
  }

  .view-all {
	display: flex;
	margin-top: 30px;
	justify-content: center;
    .btn-primary-outline {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      border: 1.5px solid #00aaff;
      color: #00aaff;
      border-radius: 50px;
      padding: 10px 22px;
      font-weight: 600;
      text-decoration: none;
      transition: all 0.3s ease;

      i {
        background: #00aaff;
        color: #fff;
        border-radius: 50%;
        padding: 8px;
        font-size: 14px;
      }

      &:hover {
        background: #00aaff;
        color: #fff;

        i {
          background: #fff;
          color: #00aaff;
        }
      }
    }
  }

  @media (max-width: 768px) {
    .swiper-button-prev,
    .swiper-button-next {
      display: none;
    }
  }
}

 

}

.vt_project .badges {
  display: flex;
  gap: 8px;
  list-style: none;
  padding: 0;
  margin: 10px 0 15px;

  .badge {
    background: #2196f3;
    color: #fff;
    font-size: 12px;
    font-weight: 500;
    padding: 6px 14px;
    border-radius: 999px;
    display: inline-block;
    transition: background 0.3s ease;

    &:hover {
      background: #1976d2;
    }
  }
}

.vt_project .section-header {
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        margin-bottom: 40px;
		h2 {
            font-size: 28px;
            font-weight: 700;
            text-transform: uppercase;
            line-height: 1.3;
			margin: 0;
        }
		.right-bot {
            
        } 
		@media (max-width: 768px) {
			.right-bot {
				text-align: -webkit-center;
				margin-top: 20px;
			}
		}
    
}
@media (max-width: 768px) {
	.vt_project .section-header {
		display: block;
	}
}

 /* FAQ – cũng là cùng phần tử */
  .vt_faq {
  padding: 40px 0 70px;
  background: #fff;

  .faq-head {
    text-align: center;
    margin-bottom: 28px;

    h2 {
      font-size: 42px;
      line-height: 1.2;
      font-weight: 800;
      color: #0a1f44;
      text-transform: uppercase;
      margin: 0 0 10px;
      @media (max-width: 768px) { font-size: 32px; }
    }

    p {
      margin: 0;
      color: #768092;
      font-size: 16px;
      line-height: 1.7;
    }
  }

  .faq-list {
    display: grid;
    gap: 18px;
  }

  .faq-item {
    background: #fff;
    border: 1px solid #eef0f3;
    border-radius: 12px;
    box-shadow: 0 2px 10px rgba(0,0,0,.04);
    overflow: hidden;
    transition: box-shadow .25s ease;

    &[open] {
      box-shadow: 0 8px 24px rgba(0,0,0,.06);
    }

    summary {
      list-style: none; /* ẩn marker mặc định */
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      padding: 18px 22px;
      cursor: pointer;

      /* ẩn marker trên WebKit */
      &::-webkit-details-marker { display: none; }

      .q {
        font-size: 18px;
        font-weight: 700;
        color: #202a3b;
      }

      .toggle {
        flex: 0 0 auto;
        width: 36px;
        height: 36px;
        border-radius: 50%;
        border: none;
        background: #f2f4f7;
        position: relative;
        cursor: pointer;

        /* dấu + */
        &:before,
        &:after {
          content: "";
          position: absolute;
          left: 50%;
          top: 50%;
          width: 14px;
          height: 2px;
          background: #111827;
          transform: translate(-50%, -50%);
          transition: transform .2s ease, opacity .2s ease;
        }
        /* gạch dọc để thành + */
        &:after { transform: translate(-50%, -50%) rotate(90deg); }
      }
    }

    /* khi mở -> thành dấu – */
    &[open] summary .toggle {
      &:after { opacity: 0; transform: translate(-50%, -50%) rotate(90deg) scaleX(0); }
    }

    .answer {
      padding: 0 22px 18px;
      color: #4b5563;
      font-size: 16px;
      line-height: 1.7;
    }
  }
}

/* Banner tư vấn là section riêng, nên đặt ngoài .vt_property */
.consultation {
  background: url('../images/handshake-bg.jpg') center/cover no-repeat;
  position: relative;
  padding: 120px 0;
  display: flex;
  justify-content: center;
  align-items: center;
  .view-more {
            text-align: -webkit-center;
        }

  .overlay {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    padding: 40px;
  }

  .consult-box {
    background: rgba(255, 255, 255, 0.9);
    padding: 60px 40px;
    max-width: 900px;
    border-radius: 8px;
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.1);
    text-align: center;

    h2 {
      font-size: 28px;
      font-weight: 800;
      color: #222;
      margin-bottom: 20px;
    }

    p {
      color: #333;
      font-size: 16px;
      line-height: 1.8;
      margin-bottom: 16px;
    }

    .btn_consult {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 10px 28px;
      background: #fff;
      border: 1px solid #0a4db7;
      color: #0a4db7;
      font-weight: 600;
      border-radius: 30px;
      text-decoration: none;
      transition: all 0.3s ease;

      .icon {
        background: #0a4db7;
        color: #fff;
        width: 28px;
        height: 28px;
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 14px;
      }

      &:hover {
        background: #0a4db7;
        color: #fff;

        .icon {
          background: #fff;
          color: #0a4db7;
        }
      }
    }
  }
}

.vt_about.nhansu, .vt_lanhdao, .vt_bplegal, .vt_bptuvan {
	h2 {
		text-align: center;
	}
}


.vt_doingu {
  padding-top: 36px;
  background: #032762;

  /* header: tiêu đề + nút điều hướng thẳng hàng */
  .dg-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    margin: 30px 0;
  }

  .dg-title {
    font-size: 28px;
    font-weight: 800;
    color: #fff;
    margin: 0;
    line-height: 1.5;
  }

  .dg-nav {
    display: flex;
    gap: 12px;

    /* dùng chính class của Swiper nhưng bỏ absolute mặc định */
    .swiper-button-prev,
    .swiper-button-next {
      position: static;  /* rất quan trọng: thẳng hàng với tiêu đề */
      width: 40px; height: 40px;
      border-radius: 50%;
      background: #fff;
      display: inline-flex;
      align-items: center;
      justify-content: center;

      &::after {
        font-size: 16px;
        color: #032762;
        font-weight: 700;
      }
    }
  }

  /* --- Khuôn mẫu bạn đưa --- */
  .about-grid {
    display: grid;
    grid-template-columns: 1fr;
    align-items: center;
    gap: 60px;

    @media (max-width: 992px) {
      grid-template-columns: 1fr;
    }
  }

  &.v2 .about-grid {
    .about-content {
      text-align: center;
      .btn_detail { display: none; }
    }
  }

  .about-content {
    h2 {
      font-size: 38px;
      font-weight: 800;
      color: #222;
      margin-top: 15px;
      margin-bottom: 24px;
      line-height: 1.5;

      @media (max-width: 768px) { font-size: 30px; }
    }
    h3, p {
      color: #333;
      font-size: 16px;
      line-height: 1.7;
      margin-bottom: 20px;
      text-align: center;
    }
  }

  /* --- Slider --- */
  .teamSwiper {
    --gap: 80px;       /* phải khớp với JS spaceBetween */
    --desc-w: 520px;   /* chiều rộng box mô tả */
    margin-top: 12px;
	overflow: hidden;

    .swiper-wrapper { align-items: center; overflow: visible; }

    .swiper-slide {
      transition: opacity .3s ease;
      .team-card {
        position: relative;
      }
      .team-img {
        width: 720px;   /* gần với ảnh mẫu */
        height: 430px;
        background: #d9d9d9;
        border-radius: 8px;
      }

      /* Mặc định ẩn desc ở mọi slide */
      .team-desc {
        position: absolute;
        top: 66%;
        left: 100%;
		transform: translateY(-50%) translateX(calc(var(--gap) / 2 - 50%));
        /* Mặc định dính vào cạnh phải ảnh */
        width: 480px;
        background: #fff;
        padding: 28px 32px;
        box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
        opacity: 0;
        pointer-events: none;
        transition: all 0.35s ease;
		z-index: 3;

        p {
          color: #333;
          font-size: 15px;
          line-height: 1.8;
          margin: 0;
        }
      }
    }

    /* slide đang active: hiển thị desc */
    .swiper-slide-active {
      opacity: 1;
	  z-index: 5;
      .team-desc { opacity: 1; pointer-events: auto; }
    }

    /* slide còn lại làm mờ giống hình */
    .swiper-slide:not(.swiper-slide-active) { opacity: .35; }
  }

  /* Responsive nhỏ hơn: desc co lại và dịch vị trí */
  @media (max-width: 1200px) {
    .teamSwiper {
      --gap: 48px;
      --desc-w: 420px;

      .swiper-slide .team-img { width: 620px; height: 380px; }
    }
  }

  @media (max-width: 992px) {
    .dg-header { align-items: flex-start; }
    .teamSwiper {
      --gap: 24px;
      --desc-w: 360px;

      .swiper-slide .team-img { width: 520px; height: 320px; }
    }
  }

  @media (max-width: 768px) {
    .teamSwiper {
      /* Trên mobile chỉ hiển thị 1 slide, desc đặt dưới */
      --desc-w: 100%;
      .swiper-slide .team-desc {
        position: static;
        margin-top: 16px;
        opacity: 1;
        right: auto;
        width: 100%;
      }
    }
  }
}



.vt_doingu {
	padding-bottom: 30px;
  .section-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 40px;

    h2 {
      font-size: 28px;
      font-weight: 700;
      text-transform: uppercase;
      line-height: 1.3;
	  color: #fff
    }
  }
 }
 
 
.vt_eventon {
	.about-content {
		p {
			text-align: center;
		}
	}
}

.vt_event_online, .vt_event_offline, .vt_relate {
	padding: 30px 0 20px;
	.badges {
	  display: flex;
	  gap: 8px;
	  list-style: none;
	  padding: 0;
	  margin: 10px 0 15px;

	  .badge {
		background: #2196f3;
		color: #fff;
		font-size: 12px;
		font-weight: 500;
		padding: 6px 14px;
		border-radius: 999px;
		display: inline-block;
		transition: background 0.3s ease;

		&:hover {
		  background: #1976d2;
		}
	  }
	}
	.swiper-button-prev,
    .swiper-button-next {
		position: absolute;
		color: #888;
		width: 40px;
		height: 40px;
		background: #f3f3f3;
		border-radius: 50%;
		box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
		transition: all 0.3s ease;
		&:after {
			font-size: 16px;
			font-weight: bold;
		}
		&:hover {
			background: #00aaff;
			color: #fff;
		}
    }
	.container {
		position: relative;
	}
}

.vt_event_expo {
	.expo-section {
	  background-image: url('../images/handshake-bg.jpg');
	  background-size: cover;
	  background-position: center;
	  position: relative;
	  width: 100%;
	  height: 100vh;
	  display: flex;
	  justify-content: center;
	  align-items: center;

	  .overlay {
		background: rgba(255, 255, 255, 0.85);
		width: 80%;
		max-width: 1200px;
		padding: 60px 80px;
		text-align: center;
		box-shadow: 0 0 10px rgba(0,0,0,0.1);
	  }

	  .expo-content {
		h2 {
		  font-size: 28px;
		  font-weight: 700;
		  color: #1b1b1b;
		  margin-bottom: 25px;
		  letter-spacing: 1px;
		}

		p {
		  font-size: 15px;
		  line-height: 1.7;
		  color: #333;
		  margin-bottom: 15px;
		}

		.btn-detail {
		  display: inline-flex;
		  align-items: center;
		  justify-content: center;
		  gap: 10px;
		  background-color: #0d6efd;
		  color: #fff;
		  text-decoration: none;
		  font-weight: 500;
		  padding: 12px 28px;
		  border-radius: 50px;
		  transition: all 0.3s ease;

		  .icon {
			display: inline-block;
			font-size: 18px;
			background: #fff;
			color: #0d6efd;
			border-radius: 50%;
			width: 28px;
			height: 28px;
			line-height: 28px;
			text-align: center;
		  }
		  &:hover {
			background-color: #084298;
		  }
		}
	  }
	}
}


.related-posts {
  text-align: center;
  padding: 60px 0;
  background: #fff;

  .related-posts_title {
    font-size: 20px;
    font-weight: 700;
    text-transform: uppercase;
    margin-bottom: 40px;
    letter-spacing: 0.5px;
  }

  .related-posts_grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px 30px;
    max-width: 1100px;
    margin: 0 auto;
  }

  .post-card {
    text-align: left;
    background: #fff;

    .post-card_thumb {
      width: 100%;
      height: 200px;
      background: #eaeaea;
      border-radius: 6px;
      margin-bottom: 15px;
    }

    .post-card_meta {
      display: flex;
      align-items: center;
      font-size: 13px;
      color: #7a7a7a;
      margin-bottom: 8px;

      .post-card_author {
        display: flex;
        align-items: center;
        margin-right: 15px;

        .dot {
          width: 8px;
          height: 8px;
          background: #ccc;
          border-radius: 50%;
          display: inline-block;
          margin-right: 6px;
        }
      }

      .post-card_date {
        display: flex;
        align-items: center;

        i {
          display: inline-block;
          width: 14px;
          height: 14px;
          background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="14" height="14" fill="gray"><path d="M3 1v1H1v11h12V2h-2V1h-1v1H4V1H3zm9 3v8H2V4h10zM3 6h8v1H3V6z"/></svg>') no-repeat center;
          background-size: contain;
          margin-right: 5px;
        }
      }
    }

    .post-card_title {
      display: block;
      font-size: 15px;
      font-weight: 600;
      color: #004aad;
      text-decoration: none;
      line-height: 1.4;
      margin-bottom: 8px;

      &:hover {
        text-decoration: underline;
      }
    }

    .post-card_excerpt {
      font-size: 13px;
      color: #555;
      line-height: 1.6;
      margin: 0;
    }
  }

  .post-card_more {
    margin-top: 50px;
    button {
      border: 1px solid #004aad;
      background: transparent;
      color: #004aad;
      padding: 10px 25px;
      border-radius: 25px;
      font-size: 13px;
      letter-spacing: 0.5px;
      cursor: pointer;
      transition: 0.3s;

      &:hover {
        background: #004aad;
        color: #fff;
      }
    }
  }
	.related-posts_more {
		margin: 30px 0;
		.view-more {
			text-align: -webkit-center;
		}
	}
}

@media (max-width: 992px) {
	.related-posts {
		.related-posts_grid {
			grid-template-columns: repeat(2, 1fr);
		}
	}
}

@media (max-width: 600px) {
	.related-posts {
		.related-posts_grid {
			grid-template-columns: 1fr;
		}
	}
	.vt_event_expo {
		& .expo-section {
			.overlay {
				padding: 20px;
			}
		}
	}
}

.category-posts {
  text-align: center;
  padding: 60px 0;
  background: #fff;

  .category-posts_title {
    font-size: 20px;
    font-weight: 700;
    text-transform: uppercase;
    margin-bottom: 40px;
    letter-spacing: 0.5px;
  }

  .category-posts_grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px 30px;
    max-width: 1100px;
    margin: 0 auto;
  }

  .post-card {
    text-align: left;
    background: #fff;

    .post-card_thumb {
      width: 100%;
      height: 200px;
      background: #eaeaea;
      border-radius: 6px;
      margin-bottom: 15px;
    }

    .post-card_meta {
      display: flex;
      align-items: center;
      font-size: 13px;
      color: #7a7a7a;
      margin-bottom: 8px;

      .post-card_author {
        display: flex;
        align-items: center;
        margin-right: 15px;

        .dot {
          width: 8px;
          height: 8px;
          background: #ccc;
          border-radius: 50%;
          display: inline-block;
          margin-right: 6px;
        }
      }

      .post-card_date {
        display: flex;
        align-items: center;

        i {
          display: inline-block;
          width: 14px;
          height: 14px;
          background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="14" height="14" fill="gray"><path d="M3 1v1H1v11h12V2h-2V1h-1v1H4V1H3zm9 3v8H2V4h10zM3 6h8v1H3V6z"/></svg>') no-repeat center;
          background-size: contain;
          margin-right: 5px;
        }
      }
    }

    .post-card_title {
      display: block;
      font-size: 15px;
      font-weight: 600;
      color: #004aad;
      text-decoration: none;
      line-height: 1.4;
      margin-bottom: 8px;

      &:hover {
        text-decoration: underline;
      }
    }

    .post-card_excerpt {
      font-size: 13px;
      color: #555;
      line-height: 1.6;
      margin: 0;
    }
  }

  .post-card_more {
    margin-top: 50px;
    button {
      border: 1px solid #004aad;
      background: transparent;
      color: #004aad;
      padding: 10px 25px;
      border-radius: 25px;
      font-size: 13px;
      letter-spacing: 0.5px;
      cursor: pointer;
      transition: 0.3s;

      &:hover {
        background: #004aad;
        color: #fff;
      }
    }
  }
	.category-posts_more {
		margin: 30px 0;
		.view-more {
			text-align: -webkit-center;
		}
	}
}

@media (max-width: 992px) {
	.category-posts {
		.category-posts_grid {
			grid-template-columns: repeat(2, 1fr);
		}
	}
}

@media (max-width: 600px) {
	.category-posts {
		.category-posts_grid {
			grid-template-columns: 1fr;
		}
	}
}

nav.navigation.pagination {
    padding: 30px 0 0;
	.page-numbers {
		padding: 8px 15px;
		border-radius: 100%;
		&:hover {
			background: #0c2d6b;
			color: #fff;
		}
	}
	.page-numbers.current {
		background: #0c2d6b;
		color: #fff;
	}
}

.single .entry-content {
    text-align: justify;
}
.single .entry-meta-author {
    display: inline-flex;
	& img {
		margin-right: 7px;
		border-radius: 100%;
	}
	& time svg.svg-inline--fa.fa-clock {
		margin: 0 7px 0 15px;
	}
}


.share-section {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: Arial, sans-serif;
  font-size: 14px;

  .share-label {
    color: #333;
    font-weight: 500;
  }

  .share-icons {
    list-style: none;
    display: flex;
    align-items: center;
    margin: 0;
    padding: 0;

    li {
      margin-right: 10px;

      a {
        color: #555;
        text-decoration: none;
        font-size: 16px;
        transition: color 0.2s;

        &:hover {
          color: #000;
        }
      }
    }
  }

  .copy-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    background-color: #36a3f7;
    color: white;
    border: none;
    border-radius: 20px;
    padding: 6px 12px;
    font-size: 13px;
    cursor: pointer;
    transition: background-color 0.2s;

    i {
      font-size: 13px;
    }

    &:hover {
      background-color: #1e90ff;
    }
  }
}
.single .entry-meta {
	display: flex;
    justify-content: space-between;
	@media (max-width: 650px) {
		display: block;
    }
}
.single .wp-block-image img {
    width: 100%;
}


.vt_relate
	.post-card_meta {
      display: flex;
      align-items: center;
      font-size: 13px;
      color: #7a7a7a;
      margin-bottom: 8px;

      .post-card_author {
        display: flex;
        align-items: center;
        margin-right: 15px;

        .dot {
          width: 8px;
          height: 8px;
          background: #ccc;
          border-radius: 50%;
          display: inline-block;
          margin-right: 6px;
        }
      }

      .post-card_date {
        display: flex;
        align-items: center;

        i {
          display: inline-block;
          width: 14px;
          height: 14px;
          background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="14" height="14" fill="gray"><path d="M3 1v1H1v11h12V2h-2V1h-1v1H4V1H3zm9 3v8H2V4h10zM3 6h8v1H3V6z"/></svg>') no-repeat center;
          background-size: contain;
          margin-right: 5px;
        }
      }
    }
}
input#captcha {
    width: auto;
} 

.astate-card .project-card {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin: 0 auto 40px;
  background: #fff;

  .project-info {
    flex: 1;
    max-width: 50%;

    .title {
      font-size: 20px;
      font-weight: 700;
      text-transform: uppercase;
      color: #000;
      line-height: 1.4;
      margin-top: 0;
      margin-bottom: 10px;
    }

    .tags {
      display: flex;
      gap: 8px;
      margin-bottom: 15px;

      span {
        background: #00a8ff;
        color: #fff;
        font-size: 12px;
        padding: 3px 10px;
        border-radius: 20px;
        display: inline-block;
      }
    }

    .description {
      font-size: 13px;
      line-height: 1.6;
      color: #444;
      margin-bottom: 20px;
    }

    hr {
      border: none;
      border-top: 1px solid #e5e5e5;
      margin: 15px 0;
    }

    .investment {
      .label {
        font-size: 13px;
        color: #777;
        margin-bottom: 5px;
      }

      .price {
        font-weight: 700;
        font-size: 18px;
        color: #000;
        margin-bottom: 20px;
      }

      .cta {
        background: #00a8ff;
        color: #fff;
        border: none;
        padding: 8px 20px;
        border-radius: 30px;
        cursor: pointer;
        font-size: 14px;
        display: inline-flex;
        align-items: center;
        gap: 8px;
        transition: background 0.3s ease;

        &:hover {
          background: #008ed6;
        }
      }
    }
  }
}

.vt_estate {
  padding-top: 36px;
  background: #032762;

  /* header: tiêu đề + nút điều hướng thẳng hàng */
  .dg-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    margin: 30px 0;
  }

  .dg-title {
    font-size: 28px;
    font-weight: 800;
    color: #fff;
    margin: 0;
    line-height: 1.5;
  }

  .dg-nav {
    display: flex;
    gap: 12px;

    /* dùng chính class của Swiper nhưng bỏ absolute mặc định */
    .swiper-button-prev,
    .swiper-button-next {
      position: static;  /* rất quan trọng: thẳng hàng với tiêu đề */
      width: 40px; height: 40px;
      border-radius: 50%;
      background: #fff;
      display: inline-flex;
      align-items: center;
      justify-content: center;

      &::after {
        font-size: 16px;
        color: #032762;
        font-weight: 700;
      }
    }
  }

  /* --- Khuôn mẫu bạn đưa --- */
  .about-grid {
    display: grid;
    grid-template-columns: 1fr;
    align-items: center;
    gap: 60px;

    @media (max-width: 992px) {
      grid-template-columns: 1fr;
    }
  }

  &.v2 .about-grid {
    .about-content {
      text-align: center;
      .btn_detail { display: none; }
    }
  }

  .about-content {
    h2 {
      font-size: 38px;
      font-weight: 800;
      color: #222;
      margin-top: 15px;
      margin-bottom: 24px;
      line-height: 1.5;

      @media (max-width: 768px) { font-size: 30px; }
    }
    h3, p {
      color: #333;
      font-size: 16px;
      line-height: 1.7;
      margin-bottom: 20px;
      text-align: center;
    }
  }

  /* --- Slider --- */
  .estateSwiper {
    --gap: 80px;       /* phải khớp với JS spaceBetween */
    --desc-w: 520px;   /* chiều rộng box mô tả */
    margin-top: 12px;
	overflow: hidden;

    .swiper-wrapper { align-items: center; overflow: visible; }

    .swiper-slide {
      transition: opacity .3s ease;
      .estate-card {
        position: relative;
      }
      .estate-img {
        width: 720px;   /* gần với ảnh mẫu */
        height: 430px;
        background: #d9d9d9;
        border-radius: 8px;
      }

      /* Mặc định ẩn desc ở mọi slide */
      .estate-desc {
        position: absolute;
        top: 66%;
        left: 100%;
		transform: translateY(-50%) translateX(calc(var(--gap) / 2 - 50%));
        /* Mặc định dính vào cạnh phải ảnh */
        width: 480px;
        background: #fff;
        padding: 28px 32px;
        box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
        opacity: 0;
        pointer-events: none;
        transition: all 0.35s ease;
		z-index: 3;

        p {
          color: #333;
          font-size: 15px;
          line-height: 1.8;
          margin: 0;
        }
      }
    }

    /* slide đang active: hiển thị desc */
    .swiper-slide-active {
      opacity: 1;
	  z-index: 5;
      .estate-desc { opacity: 1; pointer-events: auto; }
    }

    /* slide còn lại làm mờ giống hình */
    .swiper-slide:not(.swiper-slide-active) { opacity: .35; }
  }

  /* Responsive nhỏ hơn: desc co lại và dịch vị trí */
  @media (max-width: 1200px) {
    .estateSwiper {
      --gap: 48px;
      --desc-w: 420px;

      .swiper-slide .estate-img { width: 620px; height: 380px; }
    }
  }

  @media (max-width: 992px) {
    .dg-header { align-items: flex-start; }
    .estateSwiper {
      --gap: 24px;
      --desc-w: 360px;

      .swiper-slide .estate-img { width: 520px; height: 320px; }
    }
  }

  @media (max-width: 768px) {
    .estateSwiper {
      /* Trên mobile chỉ hiển thị 1 slide, desc đặt dưới */
      --desc-w: 100%;
      .swiper-slide .estate-desc {
        position: static;
        margin-top: 16px;
        opacity: 1;
        right: auto;
        width: 100%;
      }
    }
  }
}



.vt_estate {
	padding-bottom: 30px;
  .section-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 40px;

    h2 {
      font-size: 28px;
      font-weight: 700;
      text-transform: uppercase;
      line-height: 1.3;
	  color: #fff
    }
  }
 }
 
 .estate-relate {
  text-align: center;
  padding: 60px 0;
  background: #fff;

  .title {
    font-size: 20px;
    font-weight: 700;
    text-transform: uppercase;
    margin-bottom: 40px;
  }

  .grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
    max-width: 1100px;
    margin: 0 auto 50px;
  }

  .card {
    text-align: left;

    .thumb {
      width: 100%;
      height: 180px;
      background: #d9d9d9;
      border-radius: 10px;
      margin-bottom: 15px;
    }

    .meta {
      .author {
        display: flex;
        align-items: center;
        font-size: 12px;
        color: #666;
        margin-bottom: 8px;

        .avatar {
          width: 18px;
          height: 18px;
          border-radius: 50%;
          background: #ccc;
          margin-right: 6px;
        }

        .dot {
          width: 4px;
          height: 4px;
          border-radius: 50%;
          background: #999;
          margin: 0 8px;
        }
      }

      .card-title {
        font-size: 14px;
        color: #002c5f;
        font-weight: 600;
        line-height: 1.5;
        margin-bottom: 8px;
      }

      .excerpt {
        font-size: 12px;
        line-height: 1.6;
        color: #666;
      }
    }
  }

  .view-more {
    background: transparent;
    border: 1px solid #00a8ff;
    color: #00a8ff;
    padding: 10px 25px;
    border-radius: 25px;
    font-size: 13px;
    cursor: pointer;
    transition: all 0.3s ease;

    &:hover {
      background: #00a8ff;
      color: #fff;
    }
  }
}

.vt_estate, .con_estate {
	width: 100vw;
	margin-left: calc(50% - 50vw);
}