/* ========== Banner / Swiper ========== */
.tp-banner-swiper{position:relative;overflow:hidden;padding:0;}
.tp-banner-swiper .tp-banner-slide{position:relative;height:320px;background:50%/cover;}
@media (min-width:768px){.tp-banner-swiper .tp-banner-slide{height:400px;}}
@media (min-width:1200px){.tp-banner-swiper .tp-banner-slide{height:480px;}}
/* tắt overlay theme */
.tp-banner-swiper .tp-banner-slide::before{content:none !important;}

.tp-banner-inner{
  position:relative;z-index:2;height:100%;
  display:flex;align-items:center;justify-content:center;
  padding:20px;text-align:center;
}
.tp-banner-copy{max-width:920px;margin:0 auto;}
.tp-banner-headline,.tp-banner-sub{
  color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.35);
  font-family:"Roboto",system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  text-align:center;
}
.tp-banner-headline{
  margin:0;text-transform:uppercase;font-weight:800;letter-spacing:.02em;line-height:1.25;font-size:22px;
}
.tp-banner-sub{margin:10px 0 0;opacity:.95;font-weight:500;font-size:13px;text-shadow:0 2px 8px rgba(0,0,0,.35);}
@media (min-width:768px){.tp-banner-headline{font-size:30px;}.tp-banner-sub{font-size:14px;}}
@media (min-width:1200px){.tp-banner-headline{font-size:36px;}.tp-banner-sub{font-size:15px;}}

/* Swiper pagination */
.bannerSwiper{position:relative;}
.bannerSwiper .swiper-pagination{
  position:absolute;left:50%;transform:translateX(-50%);
  bottom:18px;z-index:3;width:auto;padding:6px 10px;border-radius:999px;
}
@media (min-width:768px){.bannerSwiper .swiper-pagination{bottom:22px;}}
@media (min-width:1200px){.bannerSwiper .swiper-pagination{bottom:26px;}}
.bannerSwiper .swiper-pagination-bullet{background:#fff;opacity:.5;width:10px;height:10px;margin:0 6px !important;}
.bannerSwiper .swiper-pagination-bullet-active{opacity:1;}
.bannerSwiper .swiper-button-prev,.bannerSwiper .swiper-button-next{display:none !important;}


.tp-contact-section{
  padding:40px 0 72px;
  background:#fff;
  background-image:url(../images/anhlot.png);
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  font-family:Roboto,system-ui,-apple-system,"Segoe UI",Arial,sans-serif;
}

.tp-contact-wrap{
  margin-top: 100px;
  display:flex;gap:32px;align-items:stretch;
  background:#fff;border-radius:16px;box-shadow:0 20px 60px rgba(16,24,40,.08);
  padding:24px 28px;
}

.tp-contact-left{flex:0 0 41%;max-width:41%;}
.tp-contact-card{flex:1;max-width:59%;background:transparent;border-radius:0;box-shadow:none;padding:0;}

.tp-contact-heading{
  margin:0 0 16px;color:#2D8FCC;font-size:20px;line-height:25px;font-weight:600;
  display:inline-block;position:relative;padding-bottom:8px;
}
.tp-contact-heading::after{
  content:"";position:absolute;left:0;bottom:0;width:60px;height:3px;background:#2D8FCC;border-radius:2px;
}

.tp-contact-list{margin:10px 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:14px;}
.tp-contact-item{display:flex;align-items:flex-start;gap:12px;color:#425466;}
.tp-contact-item .tp-ico{flex:0 0 24px;width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;}
.tp-contact-item .tp-ico img{width:24px;height:24px;object-fit:contain;}
.tp-contact-item .tp-text{font-size:16px;line-height:24px;font-weight:400;margin:0;}

.tp-form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.tp-field{display:flex;flex-direction:column;gap:6px;}
.tp-label{font-size:14px;line-height:20px;color:#425466;font-weight:500;margin:0;}
.tp-req{color:#e11d48;margin-left:2px;}

.tp-input,.tp-textarea{
  width:100%;border:1px solid #E5EAF1;background:#fff;border-radius:8px;
  height:46px;padding:10px 12px;font-size:14px;line-height:20px;color:#1f2937;outline:0;
  transition:border-color .2s,box-shadow .2s;
}
.tp-textarea{height:112px;resize:vertical;}
.tp-input:focus,.tp-textarea:focus{border-color:#2D8FCC;box-shadow:0 0 0 3px rgba(45,143,204,.12);}

.tp-btn-wrap{display:flex;
   justify-content: flex-start !important;
  ;margin-top:12px;}
.tp-btn{
  min-width:120px;height:40px;padding:0 22px;border:0;border-radius:999px;cursor:pointer;
  color:#fff;font-weight:700;font-size:14px;line-height:40px;text-align:center;
  background:linear-gradient(90deg,#0A6DDA 0%,#38ABF8 100%);
  box-shadow:0 6px 16px rgba(10,109,218,.28);
  transition:filter .2s,transform .02s;
}
.tp-btn:hover{filter:brightness(1.02);}
.tp-btn:active{transform:translateY(1px);}

/* ========== Responsive ========== */
@media (max-width:991.98px){
  .tp-contact-wrap{flex-direction:column;gap:16px;padding:16px;}
  .tp-contact-left,.tp-contact-card{flex:0 0 auto;max-width:100%;width:100%;}
  .tp-form-row{grid-template-columns:1fr;gap:12px;}
  .tp-field{gap:6px;}
}

@media (max-width:575.98px){
  .tp-form-row{grid-template-columns:1fr;}
}
/* ==== Map section: thẳng hàng với card liên hệ ==== */
.tp-map-section{
  padding: 18px 0 72px;     
  background: #fff;
  font-family: Roboto, system-ui, -apple-system, "Segoe UI", Arial, sans-serif;
}

.tp-map-card{
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(16,24,40,.08);
  overflow: hidden;          
}

.tp-map-card iframe{
  display: block;
  width: 100%;
  height: 420px;
  border: 0;
}

/* ===== Responsive ===== */
@media (max-width: 991.98px){
  .tp-map-section{ padding: 16px 0 56px; }
  .tp-map-card iframe{ height: 340px; }
}

@media (max-width: 575.98px){
  .tp-map-card iframe{ height: 300px; }
}


@media (min-width: 320px) and (max-width: 575.98px){ 
  .tp-contact-item .tp-text {
    font-size: 14px;
    line-height: 20px;
  }
  .tp-contact-item.tp-contact-2 .tp-ico{
    display: none;
  }
  .tp-contact-item.tp-contact-2 .tp-text{
    margin-left: 36px;
  }
  .tp-contact-wrap {
    gap: 24px;
  }
  .tp-contact-section{
    padding-bottom: 30px;
  }
}