/* =========================================================
   EXECUTIVE TEAM PAGE
   - Keep original topnav HTML 1:1
   - Make topnav overlay on cover
   - Keep footer / mini nav pattern same as About pages
========================================================= */

.executive-team-page {
  background: #f6f7fb;
}

/* ทำให้ hero เดิมไม่กินพื้นที่บนหน้า แต่กลายเป็น layer ลอยทับ */
.hero--about-sub.hero--about-sub-overlay {
  position: absolute;
  inset: 0 0 auto 0;
  width: 100%;
  z-index: 30;
  min-height: 0;
  padding: 0;
  background: transparent;
}

.hero--about-sub.hero--about-sub-overlay .wrap {
  position: relative;
  z-index: 2;
}

/* พื้นโปร่งเฉพาะตอนยังไม่เลื่อน — เลื่อนแล้วให้ขาวเหมือนหน้า about อื่น (.is-sticky) */
.executive-team-page #site-header.site-header:not(.is-sticky) {
  background: transparent;
}

.executive-team-page #site-header .topbar {
  position: relative;
  z-index: 5;
}

/* =========================
   COVER
========================= */
.about-cover--executive-team {
  position: relative;
  min-height: 430px;
  padding: 132px 20px 78px;
  display: grid;
  place-items: center;
  overflow: hidden;
  text-align: center;
  color: #fff;
  background:
    linear-gradient(135deg, rgba(4, 20, 52, 0.80), rgba(3, 54, 102, 0.52)),
    url("/images/about-us/executive-team/cover.jpg") center top / cover no-repeat;
}

.about-cover--executive-team::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 120px;
  background: linear-gradient(to bottom, rgba(246, 247, 251, 0), rgba(246, 247, 251, 1));
  pointer-events: none;
}

.about-cover--executive-team .about-cover__inner {
  position: relative;
  z-index: 1;
  width: min(960px, 100%);
}

.about-cover--executive-team .about-cover__eyebrow {
  display: inline-block;
  margin-bottom: 14px;
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.95);
}

.about-cover--executive-team .about-cover__title {
  margin: 0;
  font-size: clamp(2.8rem, 6vw, 4.9rem);
  line-height: 0.98;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: -0.04em;
  text-shadow: 0 10px 28px rgba(0, 0, 0, 0.22);
}

.about-cover--executive-team .about-cover__subtitle {
  max-width: 820px;
  margin: 20px auto 0;
  font-size: 1.02rem;
  line-height: 1.9;
  color: rgba(255, 255, 255, 0.90);
}

/* =========================
   CONTENT
========================= */
.executive-team-page .about-section {
  position: relative;
  z-index: 2;
}

.executive-intro {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.82fr);
  gap: 34px;
  align-items: stretch;
}

.executive-intro__copy {
  padding-top: 2px;
}

.executive-intro__kicker {
  margin: 0 0 12px;
  color: #165fba;
  font-size: 0.92rem;
  font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.executive-intro__title {
  margin: 0;
  max-width: 700px;
  color: #0f172a;
  font-size: clamp(2.2rem, 4vw, 4.2rem);
  line-height: 1.02;
  letter-spacing: -0.05em;
  font-weight: 800;
}

.executive-intro__title span {
  color: #1666c1;
}

.executive-intro__text {
  max-width: 700px;
  margin: 24px 0 0;
  color: #55657d;
  font-size: 1rem;
  line-height: 1.95;
}

.executive-intro__quote {
  max-width: 640px;
  margin: 26px 0 0;
  padding: 20px 22px;
  border-left: 4px solid #1666c1;
  background: linear-gradient(180deg, #f7fbff 0%, #f1f7ff 100%);
  color: #28415c;
  font-size: 0.98rem;
  line-height: 1.85;
}

.executive-intro__visual {
  overflow: hidden;
  border-radius: 28px;
  min-height: 430px;
  background:
    linear-gradient(145deg, rgba(22, 102, 193, 0.12), rgba(22, 102, 193, 0.04)),
    #dfe8f5;
  box-shadow: 0 24px 56px rgba(15, 23, 42, 0.10);
  border: 1px solid rgba(22, 102, 193, 0.08);
}

/* รูปเดี่ยว (ถ้ามี) */
.executive-intro__visual > img {
  width: 100%;
  height: 100%;
  min-height: 430px;
  object-fit: cover;
  display: block;
}

/* Chairman + President คู่กัน */
.executive-intro__visual--pair {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(10px, 2vw, 16px);
  padding: clamp(10px, 2vw, 14px);
  min-height: auto;
  align-content: start;
}

.executive-intro__portrait {
  margin: 0;
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.executive-intro__portrait-img-wrap {
  flex: 1;
  min-height: 260px;
  border-radius: 18px;
  overflow: hidden;
  background:
    linear-gradient(145deg, rgba(22, 102, 193, 0.10), rgba(22, 102, 193, 0.03)),
    #e8eef8;
}

.executive-intro__portrait-img-wrap img {
  width: 100%;
  height: 100%;
  min-height: 260px;
  object-fit: cover;
  object-position: center top;
  display: block;
}

.executive-intro__portrait-caption {
  margin-top: 10px;
  padding: 0 2px;
  text-align: center;
}

.executive-intro__portrait-role {
  display: block;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #1666c1;
}

.executive-intro__portrait-name {
  display: block;
  margin-top: 4px;
  font-size: 0.94rem;
  font-weight: 800;
  color: #0f172a;
  line-height: 1.28;
}

/* =========================
   TEAM GRID
========================= */
.executive-team-section {
  padding: 18px 0 88px;
  background: linear-gradient(180deg, #f6f7fb 0%, #ffffff 100%);
}

.executive-team-section__wrap {
  width: min(1180px, calc(100% - 40px));
  margin: 0 auto;
}

.executive-team-section__header {
  margin-bottom: 30px;
  text-align: center;
}

.executive-team-section__eyebrow {
  margin: 0 0 12px;
  color: #165fba;
  font-size: 0.88rem;
  font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.executive-team-section__title {
  margin: 0;
  color: #0f172a;
  font-size: clamp(2rem, 3vw, 3.2rem);
  line-height: 1.08;
  letter-spacing: -0.04em;
}

.executive-team-section__subtitle {
  max-width: 800px;
  margin: 14px auto 0;
  color: #596980;
  font-size: 1rem;
  line-height: 1.85;
}

.executive-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 26px;
}

.executive-card {
  overflow: hidden;
  border-radius: 24px;
  background: #fff;
  border: 1px solid rgba(15, 23, 42, 0.06);
  box-shadow: 0 18px 42px rgba(15, 23, 42, 0.08);
  transition: transform 0.28s ease, box-shadow 0.28s ease;
}

.executive-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 28px 64px rgba(15, 23, 42, 0.14);
}

.executive-card__photo {
  aspect-ratio: 4 / 4.4;
  overflow: hidden;
  background: linear-gradient(145deg, #dcecff, #eef5fc);
}

.executive-card__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.executive-card__body {
  padding: 22px 22px 24px;
}

.executive-card__name {
  margin: 0;
  color: #0f172a;
  font-size: 1.18rem;
  line-height: 1.35;
  font-weight: 800;
}

.executive-card__role {
  margin: 8px 0 0;
  color: #1666c1;
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.executive-card__desc {
  margin: 14px 0 0;
  color: #5b6b81;
  font-size: 0.96rem;
  line-height: 1.8;
}

.executive-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}

.executive-card__tag {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: #eef5ff;
  color: #264766;
  font-size: 0.79rem;
  font-weight: 700;
}

/* =========================
   RESPONSIVE
========================= */
@media (max-width: 1180px) {
  .executive-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .executive-intro {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 920px) {
  .about-cover--executive-team {
    padding-top: 148px;
    min-height: 400px;
  }

  .executive-intro__visual:not(.executive-intro__visual--pair) {
    min-height: 320px;
  }

  .executive-intro__visual:not(.executive-intro__visual--pair) > img {
    min-height: 320px;
  }

  .executive-intro__visual--pair .executive-intro__portrait-img-wrap,
  .executive-intro__visual--pair .executive-intro__portrait-img-wrap img {
    min-height: 240px;
  }
}

@media (max-width: 720px) {
  .about-cover--executive-team {
    min-height: 360px;
    padding: 152px 16px 64px;
  }

  .about-cover--executive-team .about-cover__subtitle {
    font-size: 0.96rem;
    line-height: 1.8;
  }

  .executive-grid {
    grid-template-columns: 1fr;
  }

  .executive-intro__visual--pair {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    padding: 10px;
  }

  .executive-intro__visual--pair .executive-intro__portrait-name {
    font-size: 0.82rem;
  }

  .executive-intro__visual--pair .executive-intro__portrait-role {
    font-size: 0.62rem;
  }

  .executive-card__body {
    padding: 20px 18px 22px;
  }
}