/* =========================================
   SHOP: CTA buttons + hero grid (iPhone safe)
   - Fix: buttons overlap on iPhone SE / 6S
   - Fix: grid stack on small screens
   ========================================= */

/* Scope เฉพาะหน้า shop เพื่อชนะ CSS ตัวอื่น */
.shopPage .ctaRow,
.page--shop .ctaRow{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

/* กันกรณีมี CSS ตัวอื่นทำให้ .btn เป็น inline/แปลก */
.shopPage .ctaRow > .btn,
.page--shop .ctaRow > .btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 1.2;
  white-space: normal;
  max-width: 100%;
}

/* Small phones: force stack (SE/6S) */
@media (max-width: 390px){
  .shopPage .ctaRow,
  .page--shop .ctaRow{
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }

  .shopPage .ctaRow > .btn,
  .page--shop .ctaRow > .btn{
    width: 100%;
    min-height: 44px;
    padding: 12px 14px;
    box-sizing: border-box;
  }
}

/* ===== HERO GRID RESPONSIVE (SHOP ONLY) ===== */
/* ให้ grid กลายเป็น 1 คอลัมน์ตั้งแต่จอเล็กลงมา */
@media (max-width: 980px){
  .shopPage .hero__grid,
  .shopPage .heroGrid,
  .page--shop .hero__grid,
  .page--shop .heroGrid{
    grid-template-columns: 1fr;
    gap: 22px;
  }
}

/* ================================
   SHOP HERO: Right Gold Card
   ================================ */

.shopPage .hero__card{
  border: 1px solid rgba(214, 179, 106, 0.45);  /* ทองอ่อนกว่า gold-soft */
  border-radius: 18px;
  padding: 22px 22px 24px;
  background: rgba(0, 0, 0, 0.35);
  box-shadow: 0 8px 24px rgba(0,0,0,0.25);
  max-width: 100%;
}

/* หัวข้อการ์ด */
.shopPage .hero__cardTitle{
  color: var(--gold);
  font-size: 15px;
  letter-spacing: 0.02em;
  margin: 0 0 12px 0;
  font-weight: 600;
}

/* เนื้อในการ์ด */
.shopPage .hero__cardBody p{
  margin: 0;
  color: #f1f1f1;
  line-height: 1.6;
  font-size: 15px;
}

/* จอเล็ก: ให้การ์ดไม่แน่นเกิน */
@media (max-width: 980px){
  .shopPage .hero__card{
    padding: 20px 18px 22px;
  }
}

/* ================================
   SHOP HERO: Fix overlap between goldline and h1
   ================================ */

.shopPage #shop .heroText .goldline{
  margin-bottom: 10px;        /* เว้นระยะจากหัวข้อใหญ่ */
  line-height: 1.3;
}

.shopPage #shop .heroText h1{
  margin-top: 0;             /* ตัด margin บนที่อาจซ้อน */
  line-height: 1.25;        /* กันตัวอักษรเบียด */
}

.shopPage #shop .heroText h1{
  margin-top: 2px;
}

/* ================================
   Recommended Products (Shop)
   ================================ */

.shopPage .recommended .sectionHead{
  margin: 24px 0 18px;
}

.shopPage .recommended .sectionTitle{
  margin: 6px 0 8px;
  line-height: 1.2;
}

.shopPage .recommended .sectionLead{
  margin: 0;
  opacity: .92;
  max-width: 68ch;
}

/* 2x2 grid (responsive) */
.shopPage .productGrid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin-top: 18px;
}

@media (max-width: 980px){
  .shopPage .productGrid{
    grid-template-columns: 1fr;
    gap: 16px;
  }
}

/* Card */
.shopPage .pCard{
  border: 1px solid rgba(214, 179, 106, 0.40); /* ทองอ่อนกว่าเส้นปุ่ม */
  border-radius: 18px;
  background: rgba(0,0,0,.30);
  overflow: hidden;
  box-shadow: 0 10px 26px rgba(0,0,0,.22);
}

.shopPage .pImg{
  width: 100%;
  height: auto;
  display: block;
}

/* Body */
.shopPage .pBody{
  padding: 16px 16px 18px;
}

.shopPage .pKicker{
  margin: 0 0 6px;
  color: var(--gold);
  font-size: 13px;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.shopPage .pTitle{
  margin: 0 0 10px;
  line-height: 1.2;
}

.shopPage .pDesc{
  margin: 0 0 10px;
  opacity: .92;
}

.shopPage .pQuote{
  margin: 0 0 14px;
  color: rgba(232, 216, 168, .92);
  font-style: italic;
}

/* Button: soft gold border */
.shopPage .btnSoftGold{
  border: 1px solid rgba(214, 179, 106, 0.45);
  background: transparent;
}

.shopPage .btnSoftGold:hover{
  border-color: rgba(214, 179, 106, 0.70);
  background: rgba(201,168,106,.10);
}

/* Slightly lighter vibe for Elephant Pants */
.shopPage .pCard--lite{
  background: rgba(255,255,255,.04);
}

.shopPage .productGrid > .pCard:nth-child(5){
  grid-column: 1 / -1;   /* กิน 2 คอลัมน์ */
  max-width: 520px;
  margin: 0 auto;
}

/* FIX: card 5 must NOT be centered/spanned */
.shopPage .productGrid{
  justify-items: stretch; /* กันกรณีมี center มาจากไฟล์อื่น */
}

.shopPage .productGrid > .pCard{
  width: 100%;
  margin: 0;              /* กัน auto-center */
}

.shopPage .productGrid > .pCard:nth-child(5){
  grid-column: auto !important; /* ยกเลิก span 2 คอลัมน์ */
  max-width: none !important;
  margin: 0 !important;
  justify-self: stretch !important;
}

/* SHOP ONLY: anti horizontal scroll */
.shopPage{
  overflow-x: hidden;
}

.shopPage html,
.shopPage body{
  overflow-x: hidden;
}

.shopPage main,
.shopPage header,
.shopPage footer,
.shopPage section{
  max-width: 100%;
}

.shopPage img,
.shopPage video,
.shopPage iframe,
.shopPage svg{
  max-width: 100%;
  height: auto;
  display: block;
}

.shopPage .heroGrid > *,
.shopPage .hero__grid > *,
.shopPage .productGrid > *,
.shopPage .cardGrid > *{
  min-width: 0;
}

/* Closing CTA spacing (match index2 feel) */
.shopPage .closingCtaSection{
  padding: 26px 0 34px;
}

.shopPage .closingCta{
  text-align: left;
}

.shopPage .closingCta .sectionTitle{
  margin: 8px 0 10px;
  line-height: 1.2;
}

.shopPage .closingCta .sectionLead{
  margin: 0 0 14px;
  opacity: .92;
  max-width: 70ch;
}
