/* ===== PAGE BANNER ===== */
.page-banner {
  position: relative; height: 280px;
  background-size: cover; background-position: center;
  display: flex; align-items: center;
}
.page-banner-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(0,0,0,0.65) 0%, rgba(0,0,0,0.3) 100%);
}
.page-banner-content {
  position: relative; z-index: 2; color: #fff;
}
.page-banner-content h1 {
  font-size: 40px; font-weight: 800; margin-bottom: 12px;
}
.page-banner-content .breadcrumb { color: rgba(255,255,255,0.85); }
.page-banner-content .breadcrumb a { color: #ffd700; }

/* ===== ABOUT STORY ===== */
.about-story { padding: 70px 0; background: #fff; }
.about-story-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center;
}
.about-story-img { position: relative; }
.about-story-img img {
  width: 100%; border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.15);
}
.about-exp-badge {
  position: absolute; bottom: -20px; right: -20px;
  background: linear-gradient(135deg, var(--pink), #66bb6a);
  color: #fff; border-radius: 16px; padding: 20px 24px;
  text-align: center; box-shadow: 0 8px 24px rgba(46,125,50,0.4);
}
.exp-num { display: block; font-size: 36px; font-weight: 900; line-height: 1; }
.exp-text { display: block; font-size: 12px; font-weight: 600; opacity: 0.9; margin-top: 4px; }

.about-label {
  display: inline-block; background: var(--pink-light); color: var(--pink);
  font-size: 12px; font-weight: 700; padding: 5px 16px;
  border-radius: 20px; text-transform: uppercase; letter-spacing: 1px;
  margin-bottom: 14px;
}
.about-story-content h2 {
  font-size: 32px; font-weight: 800; line-height: 1.3;
  margin-bottom: 18px; color: var(--text);
}
.about-story-content p {
  font-size: 15px; color: var(--text-light); line-height: 1.8; margin-bottom: 14px;
}
.about-highlights { display: flex; flex-direction: column; gap: 10px; margin: 20px 0 28px; }
.highlight-item { display: flex; align-items: center; gap: 10px; font-size: 14px; color: var(--text); }
.highlight-item i { color: var(--pink); font-size: 16px; flex-shrink: 0; }

/* ===== STATS ===== */
.about-stats {
  background: linear-gradient(135deg, var(--pink) 0%, #43a047 100%);
  padding: 60px 0; color: #fff;
}
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; }
.stat-item {
  text-align: center; padding: 20px;
  border-right: 1px solid rgba(255,255,255,0.2);
}
.stat-item:last-child { border-right: none; }
.stat-icon { font-size: 36px; margin-bottom: 12px; opacity: 0.9; }
.stat-num {
  font-size: 48px; font-weight: 900; line-height: 1;
  margin-bottom: 8px;
}
.stat-label { font-size: 14px; opacity: 0.85; font-weight: 500; }

/* ===== WHY CHOOSE US ===== */
.about-why { padding: 70px 0; background: #f9f9f9; }
.why-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.why-card {
  background: #fff; border-radius: var(--radius);
  padding: 32px 24px; box-shadow: var(--shadow);
  transition: transform 0.3s, box-shadow 0.3s;
  text-align: center;
}
.why-card:hover { transform: translateY(-6px); box-shadow: 0 16px 40px rgba(0,0,0,0.1); }
.why-icon {
  width: 64px; height: 64px; border-radius: 50%;
  background: var(--pink-light); color: var(--pink);
  display: flex; align-items: center; justify-content: center;
  font-size: 26px; margin: 0 auto 18px;
  transition: all 0.3s;
}
.why-card:hover .why-icon { background: var(--pink); color: #fff; }
.why-card h3 { font-size: 17px; font-weight: 800; margin-bottom: 12px; }
.why-card p { font-size: 14px; color: var(--text-light); line-height: 1.7; }

/* Trang Giới thiệu — “Tại sao chọn …” (bản featured) */
.about-why--featured {
  padding: 88px 0 96px;
  background:
    radial-gradient(900px 420px at 12% 8%, rgba(46, 125, 50, 0.07), transparent 55%),
    radial-gradient(700px 380px at 88% 92%, rgba(27, 94, 32, 0.06), transparent 50%),
    linear-gradient(180deg, #f7faf7 0%, #f2f6f3 45%, #fafcfa 100%);
}
.about-why__head { margin-bottom: 44px; }
.about-why__head h2 { margin-bottom: 10px; }

/* Căn giữa intro giống `.about-team__intro` */
.about-why--featured .about-why__head.section-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 44px;
}
.about-why--featured .about-why__eyebrow {
  margin-right: -0.16em;
}
.about-why--featured .about-why__head h2 {
  font-size: clamp(1.65rem, 4vw, 2.15rem);
  font-weight: 800;
  color: var(--text);
  margin: 0 0 12px;
  line-height: 1.25;
  position: relative;
  align-self: stretch;
  width: 100%;
  padding-bottom: 14px;
}
.about-why--featured .about-why__head h2::after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: 56px;
  height: 4px;
  border-radius: 4px;
  background: linear-gradient(90deg, var(--pink), #66bb6a);
}
.about-why--featured .about-why__head p {
  font-size: 15px;
  color: var(--text-light);
  line-height: 1.65;
  margin: 0;
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
}

.about-why__eyebrow {
  display: inline-block;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--pink);
  margin-bottom: 10px;
  padding: 6px 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(46, 125, 50, 0.14);
  box-shadow: 0 2px 12px rgba(27, 94, 32, 0.06);
}
.why-grid--featured {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  align-items: stretch;
}
.why-card--featured {
  position: relative;
  display: grid;
  grid-template-columns: 52px 1fr;
  grid-template-rows: auto 1fr;
  column-gap: 18px;
  row-gap: 4px;
  align-items: start;
  text-align: left;
  padding: 26px 24px 26px 22px;
  background: #fff;
  border-radius: 18px;
  border: 1px solid rgba(46, 125, 50, 0.1);
  box-shadow:
    0 2px 8px rgba(0, 0, 0, 0.04),
    0 14px 36px -16px rgba(27, 94, 32, 0.12);
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.25s ease;
  overflow: hidden;
}
.why-card--featured::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  border-radius: 4px 0 0 4px;
  background: linear-gradient(180deg, var(--pink) 0%, #66bb6a 100%);
  opacity: 0.85;
}
.why-card--featured:hover {
  transform: translateY(-5px);
  border-color: rgba(46, 125, 50, 0.2);
  box-shadow:
    0 8px 24px rgba(0, 0, 0, 0.06),
    0 22px 48px -18px rgba(27, 94, 32, 0.18);
}
.why-card__num {
  grid-row: 1 / span 2;
  grid-column: 1;
  align-self: center;
  font-size: 1.85rem;
  font-weight: 900;
  line-height: 1;
  color: rgba(46, 125, 50, 0.14);
  letter-spacing: -0.04em;
  user-select: none;
}
.why-card__icon-wrap {
  grid-column: 2;
  grid-row: 1;
}
.why-icon--featured {
  width: 52px;
  height: 52px;
  margin: 0;
  border-radius: 14px;
  font-size: 22px;
  background: linear-gradient(145deg, #e8f5e9 0%, #c8e6c9 100%);
  color: #1b5e20;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
}
.why-card--featured:hover .why-icon--featured {
  background: linear-gradient(145deg, var(--pink) 0%, #388e3c 100%);
  color: #fff;
  box-shadow: 0 6px 16px rgba(27, 94, 32, 0.25);
}
.why-card__body {
  grid-column: 2;
  grid-row: 2;
  min-width: 0;
}
.why-card__body h3 {
  font-size: 1.05rem;
  font-weight: 800;
  margin: 0 0 10px;
  color: var(--text);
  line-height: 1.35;
}
.why-card__body p {
  font-size: 13px;
  line-height: 1.72;
  color: var(--text-light);
  margin: 0;
}

/* ===== TEAM (trang Giới thiệu — phiên bản polished) ===== */
.about-team--polished {
  padding: 88px 0 96px;
  background:
    radial-gradient(1200px 400px at 50% -10%, rgba(46, 125, 50, 0.09), transparent 55%),
    linear-gradient(180deg, #f4f8f5 0%, #ffffff 38%, #f7faf7 100%);
}
.about-team__intro {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 48px;
}
.about-team__eyebrow {
  display: inline-block;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.16em;
  color: var(--pink);
  margin-bottom: 12px;
  padding: 6px 14px;
  border-radius: 999px;
  background: rgba(46, 125, 50, 0.1);
  border: 1px solid rgba(46, 125, 50, 0.15);
  /* Bù khoảng letter-spacing cuối chữ — pill và dòng dưới cùng trục giữa */
  margin-right: -0.16em;
}
.about-team__intro h2 {
  font-size: clamp(1.65rem, 4vw, 2.15rem);
  font-weight: 800;
  color: var(--text);
  margin: 0 0 12px;
  line-height: 1.25;
  position: relative;
  align-self: stretch;
  width: 100%;
  padding-bottom: 14px;
}
.about-team__intro h2::after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: 56px;
  height: 4px;
  border-radius: 4px;
  background: linear-gradient(90deg, var(--pink), #66bb6a);
}
.about-team__lede {
  font-size: 15px;
  color: var(--text-light);
  line-height: 1.65;
  margin: 0;
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
}
.about-team__hint {
  display: block;
  margin-top: 8px;
  font-size: 12px;
  font-weight: 600;
  color: rgba(46, 125, 50, 0.75);
  letter-spacing: 0.02em;
}

/* Bọc ngoài: tránh track rộng + margin âm làm tràn ngang cả trang khi cuộn tới đội ngũ */
.about-team--polished .team-scroll-clip {
  width: 100%;
  max-width: 100%;
  overflow-x: clip;
  overflow-y: visible;
}

/* Đội ngũ — cuộn ngang (snap); chỉ cuộn trong strip — không dùng margin âm (hay gây scrollbar ngang body) */
.team-scroll {
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  overscroll-behavior-y: auto;
  scroll-snap-type: x mandatory;
  scroll-padding-inline: 4px;
  padding: 6px 0 18px;
  margin: 0;
  max-width: 100%;
  scrollbar-width: thin;
  scrollbar-color: rgba(46, 125, 50, 0.35) transparent;
}
.team-scroll:focus-visible {
  outline: 2px solid var(--pink);
  outline-offset: 4px;
  border-radius: 12px;
}
.team-scroll::-webkit-scrollbar {
  height: 7px;
}
.team-scroll::-webkit-scrollbar-track {
  background: rgba(0, 0, 0, 0.04);
  border-radius: 4px;
}
.team-scroll::-webkit-scrollbar-thumb {
  background: rgba(46, 125, 50, 0.35);
  border-radius: 4px;
}
.team-scroll__track {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  gap: clamp(12px, 2vw, 18px);
  width: max-content;
  min-height: 1px;
  padding-bottom: 2px;
}
.team-scroll__slide {
  flex: 0 0 clamp(228px, 70vw, 268px);
  max-width: 82vw;
  scroll-snap-align: start;
  scroll-snap-stop: normal;
}
@media (prefers-reduced-motion: reduce) {
  .team-scroll {
    scroll-snap-type: none;
  }
}

.team-card--polished {
  display: flex;
  flex-direction: column;
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(46, 125, 50, 0.1);
  box-shadow:
    0 4px 6px -1px rgba(0, 0, 0, 0.05),
    0 16px 40px -12px rgba(27, 94, 32, 0.12);
  transition: transform 0.35s cubic-bezier(0.34, 1.2, 0.64, 1), box-shadow 0.35s ease, border-color 0.25s ease;
}
.team-card--polished:hover {
  transform: translateY(-6px);
  border-color: rgba(46, 125, 50, 0.22);
  box-shadow:
    0 12px 24px -8px rgba(0, 0, 0, 0.08),
    0 28px 56px -20px rgba(27, 94, 32, 0.18);
}

.team-card__visual {
  position: relative;
  background: linear-gradient(160deg, #e8f5e9 0%, #c8e6c9 100%);
}
.team-card__photo {
  aspect-ratio: 5 / 6;
  overflow: hidden;
}
.team-card__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  transition: transform 0.55s cubic-bezier(0.33, 1, 0.68, 1);
}
.team-card--polished:hover .team-card__photo img {
  transform: scale(1.05);
}

.team-card__social-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  background: linear-gradient(180deg, transparent 0%, rgba(27, 60, 32, 0.45) 55%, rgba(27, 94, 32, 0.82) 100%);
  opacity: 0;
  transition: opacity 0.35s ease;
  pointer-events: none;
}
.team-card--polished:hover .team-card__social-overlay {
  opacity: 1;
  pointer-events: auto;
}
.team-card__social-btn {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  color: #fff;
  text-decoration: none;
  transform: translateY(10px);
  opacity: 0;
  transition: transform 0.35s ease, opacity 0.35s ease, background 0.2s, box-shadow 0.2s;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2);
}
.team-card--polished:hover .team-card__social-btn {
  transform: translateY(0);
  opacity: 1;
}
.team-card--polished:hover .team-card__social-btn:nth-child(2) {
  transition-delay: 0.05s;
}
.team-card__social-btn--fb {
  background: #1877f2;
}
.team-card__social-btn--fb:hover {
  background: #0d65d9;
  color: #fff;
}
.team-card__social-btn--ig {
  background: linear-gradient(135deg, #f09433, #e6683c, #dc2743, #bc1888);
}
.team-card__social-btn--ig:hover {
  filter: brightness(1.08);
  color: #fff;
}

.team-card__body {
  padding: 16px 14px 18px;
  text-align: center;
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.team-card__name {
  font-size: 1.02rem;
  font-weight: 800;
  color: var(--text);
  margin: 0 0 6px;
  line-height: 1.3;
}
.team-card__role {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--pink);
  margin: 0 0 10px;
  padding: 4px 10px;
  border-radius: 999px;
  background: var(--pink-light);
  border: 1px solid rgba(46, 125, 50, 0.12);
  line-height: 1.3;
  max-width: 100%;
}
.team-card__bio {
  font-size: 12px;
  line-height: 1.6;
  color: var(--text-light);
  margin: 0;
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.team-card__links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(0, 0, 0, 0.06);
  width: 100%;
}
.team-card__link {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  color: #fff;
  text-decoration: none;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
}
.team-card__link:hover {
  transform: scale(1.08);
  color: #fff;
}
.team-card__link--fb { background: #1877f2; }
.team-card__link--ig {
  background: linear-gradient(135deg, #f09433, #dc2743, #bc1888);
}

/* Legacy team (nếu còn dùng ở chỗ khác) */
.about-team:not(.about-team--polished) { padding: 70px 0; background: #fff; }
.about-team:not(.about-team--polished) .team-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.about-team:not(.about-team--polished) .team-card {
  border-radius: var(--radius); overflow: hidden;
  box-shadow: var(--shadow); background: #fff;
  transition: transform 0.3s;
}
.about-team:not(.about-team--polished) .team-card:hover { transform: translateY(-6px); }
.about-team:not(.about-team--polished) .team-img { position: relative; overflow: hidden; aspect-ratio: 1; }
.about-team:not(.about-team--polished) .team-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s; }
.about-team:not(.about-team--polished) .team-card:hover .team-img img { transform: scale(1.06); }
.about-team:not(.about-team--polished) .team-social {
  position: absolute; inset: 0;
  background: rgba(46,125,50,0.75);
  display: flex; align-items: center; justify-content: center; gap: 12px;
  opacity: 0; transition: opacity 0.3s;
}
.about-team:not(.about-team--polished) .team-card:hover .team-social { opacity: 1; }
.about-team:not(.about-team--polished) .team-social a {
  width: 36px; height: 36px; border-radius: 50%;
  background: #fff; color: var(--pink);
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; transition: all 0.2s;
}
.about-team:not(.about-team--polished) .team-social a:hover { background: var(--pink); color: #fff; }
.about-team:not(.about-team--polished) .team-info { padding: 18px; text-align: center; }
.about-team:not(.about-team--polished) .team-info h4 { font-size: 16px; font-weight: 800; margin-bottom: 4px; }
.about-team:not(.about-team--polished) .team-info span { font-size: 12px; color: var(--pink); font-weight: 600; display: block; margin-bottom: 10px; }
.about-team:not(.about-team--polished) .team-info p { font-size: 13px; color: var(--text-light); line-height: 1.6; }

/* ===== CERTIFICATES ===== */
.about-cert { padding: 70px 0; background: #f9f9f9; }
.cert-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.cert-item {
  background: #fff; border-radius: var(--radius);
  padding: 32px 20px; text-align: center;
  box-shadow: var(--shadow); transition: transform 0.3s;
}
.cert-item:hover { transform: translateY(-4px); }
.cert-item i {
  font-size: 40px; color: var(--pink);
  margin-bottom: 14px; display: block;
}
.cert-item h4 { font-size: 18px; font-weight: 800; margin-bottom: 8px; }
.cert-item p { font-size: 13px; color: var(--text-light); line-height: 1.6; }

/* ===== ABOUT CTA ===== */
.about-cta {
  background: linear-gradient(135deg, #1b5e20 0%, #2e7d32 50%, #43a047 100%);
  padding: 60px 0; color: #fff;
}
.about-cta-inner {
  display: flex; align-items: center;
  justify-content: space-between; gap: 32px; flex-wrap: wrap;
}
.about-cta h2 { font-size: 28px; font-weight: 800; margin-bottom: 8px; }
.about-cta p { font-size: 15px; opacity: 0.88; }
.about-cta-btns { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
/* style.css gán .btn-primary màu xanh !important → trùng nền CTA; nút “Mua ngay” tách màu nổi bật */
.about-cta .about-cta__btn-buy,
.about-cta a.about-cta__btn-buy {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 30px !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  letter-spacing: 0.02em;
  color: #1a2e16 !important;
  background: linear-gradient(180deg, #fffef5 0%, #ffe082 55%, #ffb300 100%) !important;
  border: 2px solid rgba(255, 255, 255, 0.95) !important;
  border-radius: 999px !important;
  box-shadow:
    0 4px 0 rgba(0, 0, 0, 0.12),
    0 8px 24px rgba(0, 0, 0, 0.22);
  text-decoration: none;
  transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}
.about-cta .about-cta__btn-buy:hover,
.about-cta a.about-cta__btn-buy:hover {
  color: #0d1f0d !important;
  background: linear-gradient(180deg, #ffffff 0%, #ffecb3 45%, #ffa000 100%) !important;
  border-color: #fff !important;
  transform: translateY(-3px);
  box-shadow:
    0 6px 0 rgba(0, 0, 0, 0.1),
    0 14px 32px rgba(0, 0, 0, 0.28);
  filter: brightness(1.02);
}
.about-cta .about-cta__btn-buy:focus-visible {
  outline: 3px solid #fff;
  outline-offset: 3px;
}
.about-cta .btn-primary:not(.about-cta__btn-buy) { background: #fff; color: var(--pink); border-color: #fff; }
.about-cta .btn-primary:not(.about-cta__btn-buy):hover { background: rgba(255,255,255,0.9); }
.btn-cta-outline {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 28px; border-radius: 30px;
  border: 2px solid rgba(255,255,255,0.7); color: #fff;
  font-weight: 600; font-size: 14px; transition: all 0.2s;
}
.btn-cta-outline:hover { background: rgba(255,255,255,0.15); }

/* ===== CONTACT INFO CARDS ===== */
.contact-info-section { padding: 50px 0; background: #f9f9f9; }
.contact-info-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.contact-info-card {
  background: #fff; border-radius: var(--radius);
  padding: 28px 20px; text-align: center;
  box-shadow: var(--shadow); transition: transform 0.3s;
}
.contact-info-card:hover { transform: translateY(-4px); }
.contact-info-icon {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--pink-light); color: var(--pink);
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; margin: 0 auto 14px;
}
.contact-info-card h4 { font-size: 16px; font-weight: 800; margin-bottom: 8px; }
.contact-info-card p { font-size: 14px; color: var(--text-light); line-height: 1.7; }
.contact-info-card a { color: var(--pink); font-weight: 600; }

/* ===== CONTACT MAIN ===== */
.contact-main-section { padding: 60px 0; background: #fff; }
.contact-main-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; }

/* Row 1: Form + Map */
.contact-top-row { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: stretch; margin-bottom: 40px; }
.contact-map-inline { display: flex; flex-direction: column; min-width: 0; }
/* Cần min-height: flex:1 trong cột dọc dễ bị co về 0 → Leaflet/OSM không vẽ được */
.map-embed-inline { flex: 1; min-height: 380px; min-width: 0; display: flex; flex-direction: column; }
.map-embed-inline iframe { height: 100%; min-height: 380px; flex: 1; }
.contact-leaflet-map {
  flex: 1;
  width: 100%;
  min-height: 380px;
  height: 380px;
  position: relative;
  z-index: 1;
}
.contact-leaflet-map .leaflet-container {
  height: 100% !important;
  width: 100% !important;
  min-height: 380px;
  border-radius: 10px;
  font: inherit;
}

/* Row 2: Quick contact + Hours + Social */
.contact-bottom-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }

/* Form */
.contact-form-wrap h2 { font-size: 28px; font-weight: 800; margin-bottom: 8px; }
.contact-form-wrap > p { font-size: 14px; color: var(--text-light); margin-bottom: 28px; }
.contact-form { display: flex; flex-direction: column; gap: 18px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.form-group { display: flex; flex-direction: column; gap: 6px; }
.form-group label { font-size: 13px; font-weight: 700; color: var(--text); }
.form-group input,
.form-group select,
.form-group textarea {
  padding: 11px 16px; border: 1.5px solid var(--border);
  border-radius: 10px; font-size: 14px; outline: none;
  font-family: inherit; transition: border-color 0.2s;
  background: #fff;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { border-color: var(--pink); }
.form-group textarea { resize: vertical; }
.contact-field-error {
  display: none;
  font-size: 12px;
  color: #ef4444;
  margin-top: 4px;
  line-height: 1.35;
}
.btn-submit {
  display: flex; align-items: center; justify-content: center;
  gap: 8px; font-size: 15px; padding: 14px;
  border: none; cursor: pointer; width: 100%;
}

/* Sidebar */
.contact-sidebar { display: flex; flex-direction: column; gap: 20px; }
.contact-quick {
  background: #fff; border-radius: var(--radius);
  padding: 22px; box-shadow: var(--shadow);
}
.contact-quick h3 { font-size: 16px; font-weight: 800; margin-bottom: 16px; padding-bottom: 10px; border-bottom: 2px solid var(--pink); display: flex; align-items: center; gap: 8px; }
.contact-quick h3 i { color: var(--pink); }
.quick-btn {
  display: flex; align-items: center; gap: 14px;
  padding: 12px 14px; border-radius: 10px;
  margin-bottom: 10px; transition: transform 0.2s;
  color: #fff; font-size: 13px;
}
.quick-btn:last-child { margin-bottom: 0; }
.quick-btn:hover { transform: translateX(4px); }
.quick-btn i, .quick-btn img {
  width: 40px; height: 40px; border-radius: 50%;
  background: rgba(255,255,255,0.2);
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; flex-shrink: 0;
  object-fit: contain; padding: 8px;
}
.quick-btn strong { display: block; font-size: 14px; font-weight: 700; }
.quick-btn span { font-size: 12px; opacity: 0.85; }
.quick-zalo { background: linear-gradient(135deg, #0068ff, #00aaff); }
.quick-fb { background: linear-gradient(135deg, #0084ff, #a334fa); }
.quick-chat { background: linear-gradient(135deg, #128c7e, #25d366); }
.quick-phone { background: linear-gradient(135deg, var(--pink), #66bb6a); }

.contact-hours {
  background: #fff; border-radius: var(--radius);
  padding: 22px; box-shadow: var(--shadow);
}
.contact-hours h3 { font-size: 16px; font-weight: 800; margin-bottom: 16px; padding-bottom: 10px; border-bottom: 2px solid var(--pink); display: flex; align-items: center; gap: 8px; }
.contact-hours h3 i { color: var(--pink); }
.contact-hours ul { display: flex; flex-direction: column; gap: 10px; }
.contact-hours li { display: flex; justify-content: space-between; align-items: center; font-size: 14px; }
.contact-hours li span { color: var(--text-light); }
.contact-hours li strong { color: var(--text); font-weight: 700; }
/* Mỗi mốc giờ: một dòng, không chia trái/phải như trạng thái “Hôm nay” */
.contact-hours li.work-time-line {
  display: block;
  justify-content: flex-start;
  align-items: flex-start;
  padding-bottom: 6px;
  margin-bottom: 2px;
  border-bottom: 1px solid rgba(0,0,0,.06);
}
.contact-hours li.work-time-line:last-of-type { border-bottom: none; }
.open-now strong { color: var(--pink); }
.open-now.is-closed {
  margin-top: 6px;
  padding: 10px 12px;
  border-radius: 10px;
  background: #ffe4e6;
  border: 1px solid #fecdd3;
}
.open-now.is-closed span { color: var(--text); }
.badge-open {
  background: var(--pink-light); color: var(--pink);
  font-size: 12px; font-weight: 700;
  padding: 3px 10px; border-radius: 12px;
}
.badge-closed {
  background: #fecaca;
  color: #991b1b;
  font-size: 12px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 12px;
}

.contact-social {
  background: #fff; border-radius: var(--radius);
  padding: 22px; box-shadow: var(--shadow);
}
.contact-social h3 { font-size: 16px; font-weight: 800; margin-bottom: 16px; padding-bottom: 10px; border-bottom: 2px solid var(--pink); display: flex; align-items: center; gap: 8px; }
.contact-social h3 i { color: var(--pink); }
.contact-social-links { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.contact-social-links a {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 14px; border-radius: 10px;
  font-size: 13px; font-weight: 600; color: #fff;
  transition: opacity 0.2s;
}
.contact-social-links a:hover { opacity: 0.85; }
.social-fb { background: #1877f2; }
.social-ig { background: linear-gradient(135deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888); }
.social-tt { background: #000; }
.social-yt { background: #ff0000; }

/* ===== MAP INLINE (sidebar / full row) ===== */
.contact-map-row {
  grid-column: 1 / -1;
  margin-bottom: 8px;
}
.contact-map-inline { background: #fff; border: 1px solid #eee; border-radius: 12px; padding: 20px; }
.contact-map-inline h3 { font-size: 16px; font-weight: 700; margin-bottom: 14px; display: flex; align-items: center; gap: 8px; }
.contact-map-inline h3 i { color: var(--pink); }
.map-embed-inline iframe { display: block; }
/* Bản đồ rộng 50% chiều ngang container, căn giữa */
.map-embed-inline--half-width {
  width: 50%;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}
.map-embed-inline--half-width iframe {
  width: 100%;
}

/* ===== FAQ ===== */
.contact-faq { padding: 70px 0; background: #fff; }
.faq-list { display: flex; flex-direction: column; gap: 12px; max-width: 800px; margin: 0 auto; }
.faq-item { border: 1.5px solid var(--border); border-radius: 10px; overflow: hidden; }
.faq-question {
  width: 100%; display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; background: #fff; border: none; cursor: pointer;
  font-size: 15px; font-weight: 700; color: var(--text); text-align: left;
  transition: background 0.2s;
}
.faq-question:hover { background: var(--pink-light); }
.faq-question.active { background: var(--pink-light); color: var(--pink); }
.faq-question i { font-size: 12px; color: var(--pink); transition: transform 0.3s; flex-shrink: 0; }
.faq-question.active i { transform: rotate(180deg); }
.faq-answer {
  max-height: 0; overflow: hidden;
  transition: max-height 0.35s ease, padding 0.3s;
  padding: 0 20px;
}
.faq-answer.open { max-height: 200px; padding: 14px 20px; }
.faq-answer p { font-size: 14px; color: var(--text-light); line-height: 1.7; margin: 0; }

/* ===== RESPONSIVE ===== */
@media (max-width: 1024px) {
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .stat-item:nth-child(2) { border-right: none; }
  .stat-item:nth-child(3) { border-top: 1px solid rgba(255,255,255,0.2); }
  .about-team:not(.about-team--polished) .team-grid { grid-template-columns: repeat(2, 1fr); }
  .why-grid--featured { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .cert-grid { grid-template-columns: repeat(2, 1fr); }
  .contact-info-grid { grid-template-columns: repeat(2, 1fr); }
  .contact-main-grid { grid-template-columns: 1fr; }
  .contact-top-row { grid-template-columns: 1fr; }
  .contact-bottom-row { grid-template-columns: 1fr; }
  .map-embed-inline--half-width { width: 100%; }
}
@media (max-width: 768px) {
  .about-story-grid { grid-template-columns: 1fr; }
  .about-exp-badge { right: 10px; bottom: -10px; }
  .why-grid { grid-template-columns: 1fr 1fr; }
  .about-team:not(.about-team--polished) .team-grid { grid-template-columns: 1fr 1fr; }
  .why-grid--featured { grid-template-columns: 1fr; }
  .about-cta-inner { flex-direction: column; text-align: center; }
  .page-banner { height: 200px; }
  .page-banner-content h1 { font-size: 28px; }
  .form-row { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .why-grid { grid-template-columns: 1fr; }
  .about-team:not(.about-team--polished) .team-grid { grid-template-columns: 1fr; }
  .about-team--polished { padding: 56px 0 64px; }
  .team-scroll__slide { flex-basis: min(246px, 86vw); }
  .cert-grid { grid-template-columns: 1fr 1fr; }
  .contact-info-grid { grid-template-columns: 1fr 1fr; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .stat-item { padding: 14px 10px; }
  .stat-num { font-size: 34px; }
  .stat-label { font-size: 12px; }
  .page-banner-content h1 { font-size: 22px; }
}
