.elementor-12521 .elementor-element.elementor-element-db317cf{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-12521 .elementor-element.elementor-element-4d4fa0e{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-12521 .elementor-element.elementor-element-1f4c90e{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-12521 .elementor-element.elementor-element-04d13d3{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-12521 .elementor-element.elementor-element-6a8968a{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-12521 .elementor-element.elementor-element-8760433{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-12521 .elementor-element.elementor-element-0c1e047{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-12521 .elementor-element.elementor-element-da60a70{--display:flex;}.elementor-12521 .elementor-element.elementor-element-2ff429c{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-12521 .elementor-element.elementor-element-3fdf06b{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-12521 .elementor-element.elementor-element-35ca053{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-12521 .elementor-element.elementor-element-be3378a{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-widget-heading .elementor-heading-title{font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-size:var( --e-global-typography-primary-font-size );font-weight:var( --e-global-typography-primary-font-weight );text-transform:var( --e-global-typography-primary-text-transform );line-height:var( --e-global-typography-primary-line-height );color:var( --e-global-color-primary );}@media(max-width:1366px){.elementor-widget-heading .elementor-heading-title{font-size:var( --e-global-typography-primary-font-size );line-height:var( --e-global-typography-primary-line-height );}}@media(max-width:1024px){.elementor-widget-heading .elementor-heading-title{font-size:var( --e-global-typography-primary-font-size );line-height:var( --e-global-typography-primary-line-height );}}@media(max-width:767px){.elementor-widget-heading .elementor-heading-title{font-size:var( --e-global-typography-primary-font-size );line-height:var( --e-global-typography-primary-line-height );}}/* Start custom CSS for html, class: .elementor-element-5736a7e *//* ===== HERO – Phuket Island Hopping (เวอร์ชันปรับฟอนต์ + เอฟเฟกต์) ===== */

.ph-hero {
  position: relative;
  width: 100%;
  min-height: 340px;
  padding: 76px 20px 60px;
  box-sizing: border-box;

  /* รูปพื้นหลังจากตัวแปร inline style */
  background-image: var(--ph-hero-bg);
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;

  color: #f9fafb;
  overflow: hidden;

  /* ฟอนต์รวม (รองรับไทย) */
  font-family: "Sarabun", system-ui, -apple-system, BlinkMacSystemFont,
    "Segoe UI", Roboto, sans-serif;
}

/* เลเยอร์ทับให้ตัวหนังสือชัด + ละมุน */
.ph-hero-overlay {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 10% 0%, rgba(125, 211, 252, 0.4), transparent 55%),
    linear-gradient(to bottom right, rgba(15, 23, 42, 0.92), rgba(15, 23, 42, 0.7));
  pointer-events: none;
}

.ph-hero-inner {
  position: relative;
  max-width: 960px;
  margin: 0 auto;
  animation: ph-fade-up 0.7s ease-out both;
}

/* แท็กเล็กด้านบน */
.ph-hero-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 12px;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.82);
  border: 1px solid rgba(148, 163, 184, 0.7);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #e0f2fe;
  margin-bottom: 14px;
  backdrop-filter: blur(10px);
}

.ph-hero-tag::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: #38bdf8;
  box-shadow: 0 0 0 5px rgba(56, 189, 248, 0.4);
}

/* Title – gradient text + shadow เบาๆ */
.ph-hero-title {
  margin: 0 0 12px;
  font-size: clamp(28px, 4.4vw, 42px);
  line-height: 1.18;
  letter-spacing: -0.03em;
  font-weight: 700;

  background: linear-gradient(120deg, #fefce8, #e0f2fe, #bae6fd);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;

  text-shadow: 0 10px 30px rgba(15, 23, 42, 0.8);
}

/* เส้นเน้นใต้ title นิดๆ ให้ดูแพง */
.ph-hero-title::after {
  content: "";
  display: block;
  width: 72px;
  height: 2px;
  margin-top: 10px;
  border-radius: 999px;
  background: linear-gradient(to right, #38bdf8, #facc15);
}

/* Subtitle – อ่านง่าย ละมุน */
.ph-hero-subtitle {
  max-width: 640px;
  margin: 14px 0 18px;
  font-size: 15px;
  line-height: 1.85;
  font-weight: 400;
  color: #e5e7eb;
  text-shadow: 0 6px 18px rgba(15, 23, 42, 0.9);
}

/* Meta ใต้ subtitle */
.ph-hero-meta {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: #dbeafe;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.ph-pill {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.78);
  border: 1px solid rgba(191, 219, 254, 0.9);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
}

.ph-dot {
  width: 4px;
  height: 4px;
  border-radius: 999px;
  background: #bfdbfe;
  opacity: 0.9;
}

.ph-meta-text {
  opacity: 0.92;
}

/* เอฟเฟ็กต์ fade-up */
@keyframes ph-fade-up {
  from {
    opacity: 0;
    transform: translateY(14px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ===== Responsive ===== */
@media (max-width: 768px) {
  .ph-hero {
    padding: 60px 16px 40px;
    min-height: 280px;
  }

  .ph-hero-subtitle {
    font-size: 14px;
  }

  .ph-hero-meta {
    font-size: 11px;
    letter-spacing: 0.06em;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-38ee9ed *//* ===== SECTION 01 (FINAL VERSION) ===== */

.ih-section {
  background-color: #ffffff;
  padding: 60px 20px;
  box-sizing: border-box;
}

.ih-inner {
  max-width: 1120px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1.2fr 1fr;
  gap: 40px;
  align-items: start;
  font-family: "Sarabun", system-ui, -apple-system, BlinkMacSystemFont,
    "Segoe UI", Roboto, sans-serif;
  color: #111827;
}

/* ===== IMAGE BOX (ทั้งซ้าย + ขวา เท่ากัน) ===== */
.ih-img-box {
  width: 100%;
  aspect-ratio: 4 / 5; /* ทำให้รูปซ้าย-ขวา "เท่ากัน" เสมอ */
  border-radius: 16px;
  overflow: hidden;
  background-color: #e5e7eb;
}

.ih-img-box img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* ===== LEFT COLUMN ===== */
.ih-why {
  padding-top: 20px;
  border-top: 1px solid #e5e7eb;
}

.ih-why-title {
  margin: 0 0 14px;
  font-size: 16px;
  font-weight: 600;
  color: #111827;
}

.ih-why-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.ih-why-item p {
  font-size: 13px;
  color: #4b5563;
  margin-top: 4px;
  line-height: 1.7;
}

.ih-why-label {
  font-size: 13px;
  font-weight: 600;
  color: #111827;
}

/* ===== CENTER COLUMN ===== */
.ih-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: #9ca3af;
  margin-bottom: 6px;
}

.ih-title {
  margin: 0 0 16px;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.45;
  color: #111827;
}

.ih-text {
  font-size: 14px;
  line-height: 1.85;
  color: #4b5563;
  margin-bottom: 12px;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 960px) {
  .ih-inner {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .ih-img-box {
    aspect-ratio: 4 / 5;
  }

  .ih-why-grid {
    grid-template-columns: 1fr;
  }

  .ih-section {
    padding: 40px 16px;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-9f22b56 *//* ===== SECTION 02 – ISLAND ZONES (READABLE VERSION) ===== */

.zones-block {
  background-color: #ffffff;
  padding: 60px 20px 64px;
  box-sizing: border-box;
}

.zones-inner {
  max-width: 1040px; /* บีบความกว้างให้อ่านสบายตา */
  margin: 0 auto;
  font-family: "Sarabun", system-ui, -apple-system, BlinkMacSystemFont,
    "Segoe UI", Roboto, sans-serif;
  color: #111827;
}

/* Header */
.zones-head {
  text-align: center;
  margin-bottom: 32px;
}

.zones-label {
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #9ca3af;
  margin-bottom: 6px;
}

.zones-title {
  margin: 0 0 10px;
  font-size: 26px;
  font-weight: 700;
  color: #0f172a;
}

.zones-intro {
  margin: 0 auto;
  max-width: 620px;
  font-size: 15px;
  line-height: 1.9;
  color: #4b5563;
}

/* Grid layout */
.zones-grid {
  margin-top: 20px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
}

/* Card base */
.zone-card {
  border-radius: 18px;
  background-color: #ffffff;
  border: 1px solid #e5e7eb;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.04);
  transition: box-shadow 0.2s ease, transform 0.2s ease, border-color 0.2s ease;
}

.zone-card-inner {
  padding: 20px 22px 18px;
}

/* Hover effect – นิดเดียวพอ ให้ดูแพงแต่ไม่รก */
.zone-card:hover {
  border-color: rgba(25, 124, 243, 0.55);
  box-shadow: 0 16px 40px rgba(15, 23, 42, 0.08);
  transform: translateY(-3px);
}

/* Title & tagline */
.zone-name {
  margin: 0 0 4px;
  font-size: 18px;
  font-weight: 600;
  color: #0f172a;
}

.zone-tagline {
  margin: 0 0 14px;
  font-size: 14px;
  line-height: 1.7;
  color: #475569;
}

/* Meta list */
.zone-meta {
  list-style: none;
  margin: 0;
  padding: 0;
}

.zone-meta li {
  display: grid;
  grid-template-columns: 90px minmax(0, 1fr);
  gap: 10px;
  padding: 8px 0;
  border-top: 1px solid #f3f4f6;
}

.zone-meta li:first-child {
  padding-top: 0;
  border-top: none;
}

.zone-meta-label {
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #9ca3af;
}

.zone-meta-value {
  font-size: 14px;
  line-height: 1.9; /* บรรทัดห่างขึ้น อ่านง่ายขึ้น */
  color: #374151;   /* เข้มขึ้นให้อ่านชัด */
}

/* Responsive */
@media (max-width: 900px) {
  .zones-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .zones-block {
    padding: 40px 16px 44px;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-a463b28 *//* ===== SECTION: ISLAND TABLE (PREMIUM) ===== */

.island-table-section {
  background: #ffffff;
  padding: 72px 20px 70px;
  box-sizing: border-box;
}

.island-table-inner {
  max-width: 1120px;
  margin: 0 auto;
  font-family: "Sarabun", system-ui, -apple-system, BlinkMacSystemFont,
    "Segoe UI", Roboto, sans-serif;
  color: #111827;
}

/* Head area */
.island-table-head {
  margin-bottom: 22px;
}

.island-table-label {
  display: inline-block;
  font-size: 12px;
  font-weight: 600;
  color: #197cf3;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 6px;
}

.island-table-title {
  margin: 0 0 8px;
  font-size: 26px;
  font-weight: 700;
}

.island-table-intro {
  margin: 0;
  font-size: 14px;
  line-height: 1.9;
  color: #4b5563;
}

/* Card container around table */
.island-table-card {
  margin-top: 16px;
  border-radius: 18px;
  border: 1px solid #e5e7eb;
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.06);
  background: #ffffff;
  overflow: hidden;
}

/* Scroll container for mobile */
.island-table-scroll {
  width: 100%;
  overflow-x: auto;
}

/* Table styles */
.island-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
  min-width: 720px; /* ให้คอลัมน์ไม่แคบเกินไป */
}

.island-table th,
.island-table td {
  padding: 12px 16px;
  text-align: left;
  border-bottom: 1px solid #e5e7eb;
  vertical-align: top;
}

/* Header row */
.island-table thead th {
  font-weight: 600;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #6b7280;
  background: #f3f7ff;
}

/* Body rows */
.island-table tbody tr:nth-child(odd) {
  background: #ffffff;
}

.island-table tbody tr:nth-child(even) {
  background: #f9fafb;
}

/* Emphasis island group column */
.island-table tbody td:first-child {
  font-weight: 600;
  color: #111827;
}

/* Hover effect */
.island-table tbody tr:hover {
  background: #eef6ff;
}

/* Responsive */
@media (max-width: 768px) {
  .island-table-section {
    padding: 48px 16px 52px;
  }

  .island-table-title {
    font-size: 22px;
  }

  .island-table-card {
    border-radius: 14px;
  }

  .island-table {
    font-size: 13px;
    min-width: 640px;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-38a5d3c *//* ===== SECTION: SERVICE CARDS (4 CARDS) ===== */

.service-cards-section {
  background: #ffffff;
  padding: 70px 20px 80px;
  box-sizing: border-box;
  font-family: "Sarabun", system-ui, -apple-system, "Segoe UI", sans-serif;
}

.service-cards-inner {
  max-width: 1160px;
  margin: 0 auto;
}

/* HEADER */
.service-header {
  text-align: center;
  margin-bottom: 40px;
}

.service-label {
  font-size: 13px;
  font-weight: 600;
  color: #197cf3;
  text-transform: uppercase;
  margin-bottom: 6px;
  letter-spacing: 0.08em;
}

.service-title {
  font-size: 30px;
  font-weight: 700;
  line-height: 1.3;
  color: #1f2937;
  margin: 0;
}

.service-title span {
  color: #ff6b35; /* หรือเปลี่ยนเป็น #197cf3 ถ้าอยากใช้โทนฟ้า */
}

/* GRID – 4 CARDS ON DESKTOP */
.service-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
}

/* CARD */
.service-card {
  background: #ffffff;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid #e5e7eb;
  box-shadow: 0 20px 40px rgba(15, 23, 42, 0.06);
  transition: 0.25s ease;
  display: flex;
  flex-direction: column;
  height: 100%;
}

.service-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 25px 60px rgba(15, 23, 42, 0.10);
}

/* IMAGE */
.service-img img {
  width: 100%;
  height: 150px;
  object-fit: cover;
  display: block;
}

/* CONTENT */
.service-content {
  padding: 16px 18px 18px;
  display: flex;
  flex-direction: column;
  height: 100%;
}

/* ICON CIRCLE */
.service-icon {
  width: 40px;
  height: 40px;
  border-radius: 999px;
  background: #197cf3;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  margin-bottom: 10px;
}

.service-icon span {
  line-height: 1;
}

/* TITLE & TEXT */
.service-name {
  font-size: 16px;
  font-weight: 700;
  margin: 0 0 6px;
  color: #111827;
}

.service-text {
  font-size: 14px;
  color: #6b7280;
  line-height: 1.7;
  margin: 0 0 12px;
  flex-grow: 1;
}

/* BUTTON */
.service-btn {
  font-size: 14px;
  font-weight: 600;
  color: #197cf3;
  text-decoration: none;
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  transition: color 0.2s ease, transform 0.2s ease;
}

.service-btn:hover {
  color: #0c5db9;
  transform: translateX(2px);
}

/* RESPONSIVE */
@media (max-width: 1024px) {
  .service-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .service-img img {
    height: 160px;
  }
}

@media (max-width: 640px) {
  .service-grid {
    grid-template-columns: 1fr;
  }

  .service-title {
    font-size: 24px;
  }

  .service-cards-section {
    padding: 50px 16px 60px;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-fffd8ce *//* ===== PLAN SECTION WITH REAL ICONS ===== */

.plan-section {
  background: #ffffff;
  padding: 70px 20px 80px;
  font-family: "Sarabun", system-ui, -apple-system, "Segoe UI", sans-serif;
}

.plan-inner {
  max-width: 1120px;
  margin: 0 auto;
}

/* HEADER */
.plan-header {
  text-align: center;
  margin-bottom: 40px;
}

.plan-label {
  font-size: 12px;
  font-weight: 600;
  color: #197cf3;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 6px;
}

.plan-title {
  margin: 0 0 10px;
  font-size: 28px;
  font-weight: 700;
  color: #111827;
}

.plan-intro {
  max-width: 680px;
  margin: 0 auto;
  font-size: 15px;
  line-height: 1.8;
  color: #4b5563;
}

/* GRID */
.plan-grid {
  margin-top: 28px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

/* CARD */
.plan-card {
  background: #f9fafb;
  border-radius: 18px;
  padding: 20px 22px;
  border: 1px solid #e5e7eb;
  box-shadow: 0 16px 36px rgba(15, 23, 42, 0.06);
  transition: 0.25s ease;
}

.plan-card:hover {
  background: #eef6ff;
  border-color: rgba(25, 124, 243, 0.7);
  transform: translateY(-4px);
  box-shadow: 0 22px 50px rgba(15, 23, 42, 0.1);
}

/* ICON WRAPPER */
.plan-icon {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  background: #197cf3;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 12px;
  padding: 4px;
}

/* SVG INSIDE ICON */
.plan-icon-svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* TEXT */
.plan-card-title {
  font-size: 17px;
  font-weight: 700;
  margin: 0 0 8px;
  color: #111827;
}

.plan-card-text {
  font-size: 14px;
  line-height: 1.8;
  color: #4b5563;
  margin-bottom: 12px;
}

/* LIST */
.plan-list {
  margin: 0;
  padding-left: 18px;
  font-size: 14px;
  color: #374151;
  line-height: 1.7;
}

.plan-list li {
  margin-bottom: 6px;
}

/* RESPONSIVE */
@media (max-width: 960px) {
  .plan-grid {
    grid-template-columns: 1fr;
  }
  .plan-title {
    font-size: 24px;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-1efa8b9 *//* ===== PRO TIPS (ALT LAYOUT + EFFECTS) ===== */

.tips2-section {
  background: radial-gradient(circle at top, #eff6ff 0, #ffffff 42%, #ffffff 100%);
  padding: 72px 20px 88px;
  font-family: "Sarabun", system-ui, -apple-system, "Segoe UI", sans-serif;
  color: #111827;
}

.tips2-inner {
  max-width: 1120px;
  margin: 0 auto;
}

/* Header */
.tips2-header {
  text-align: center;
  margin-bottom: 40px;
}

.tips2-label {
  font-size: 12px;
  font-weight: 600;
  color: #197cf3;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 6px;
}

.tips2-title {
  margin: 0 0 10px;
  font-size: 28px;
  font-weight: 700;
  position: relative;
  display: inline-block;
}

.tips2-title::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -10px;
  width: 60%;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, #197cf3, #22c55e);
  transform: translateX(-50%);
  opacity: 0.25;
}

.tips2-intro {
  max-width: 720px;
  margin: 14px auto 0;
  font-size: 15px;
  line-height: 1.9;
  color: #4b5563;
}

/* Grid */
.tips2-grid {
  margin-top: 32px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 32px;
}

/* Block wrapper */
.tips2-block {
  position: relative;
  padding-left: 22px;
  border-radius: 18px;
  background: #ffffff;
  box-shadow:
    0 18px 40px rgba(15, 23, 42, 0.08),
    0 0 0 1px rgba(226, 232, 240, 0.8);
  overflow: hidden;
}

/* gradient bar on the left */
.tips2-block::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 3px;
  background: linear-gradient(180deg, #197cf3, #22c55e);
}

.tips2-block::after {
  content: "";
  position: absolute;
  inset: 0 auto 0 -30%;
  width: 60%;
  background: radial-gradient(circle at left, rgba(25, 124, 243, 0.18), transparent 60%);
  pointer-events: none;
}

.tips2-block-title {
  margin: 18px 18px 14px;
  font-size: 18px;
  font-weight: 700;
}

/* Checklist items */
.tips2-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 0 18px 8px;
  padding: 8px 10px;
  border-radius: 12px;
  transition: background 0.2s ease, transform 0.2s ease;
}

.tips2-item:hover {
  background: #f1f5f9;
  transform: translateX(2px);
}

.tips2-bullet {
  margin-top: 5px;
}

.tips2-dot {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: #22c55e;
  box-shadow: 0 0 0 0 rgba(34, 197, 94, 0.35);
  display: block;
  animation: tips-dot-pulse 1.8s ease-out infinite;
}

.tips2-item-body {
  font-size: 14px;
  line-height: 1.9;
  color: #374151;
}

.tips2-item-body strong {
  color: #111827;
}

/* Season cards */
.tips2-season-card {
  margin: 0 18px 14px;
  padding: 14px 14px 16px;
  border-radius: 14px;
  border: 1px solid #e5e7eb;
  background: linear-gradient(135deg, #f9fafb, #f1f5f9);
  font-size: 14px;
  line-height: 1.8;
  color: #374151;
  position: relative;
  overflow: hidden;
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.tips2-season-card::after {
  content: "";
  position: absolute;
  inset: -40% -40% auto auto;
  background: radial-gradient(circle at top right, rgba(25, 124, 243, 0.12), transparent 60%);
  pointer-events: none;
}

.tips2-season-card--dry {
  border-left: 4px solid #197cf3;
}

.tips2-season-card--green {
  border-left: 4px solid #16a34a;
}

.tips2-season-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 16px 40px rgba(15, 23, 42, 0.16);
  border-color: rgba(25, 124, 243, 0.45);
}

.tips2-season-tag {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 4px;
  color: #6b7280;
}

/* Responsive */
@media (max-width: 900px) {
  .tips2-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .tips2-section {
    padding: 56px 16px 68px;
  }

  .tips2-title {
    font-size: 24px;
  }
}

/* Bullet breathing animation */
@keyframes tips-dot-pulse {
  0% {
    transform: scale(1);
    box-shadow: 0 0 0 0 rgba(34, 197, 94, 0.4);
  }
  70% {
    transform: scale(1.15);
    box-shadow: 0 0 0 10px rgba(34, 197, 94, 0);
  }
  100% {
    transform: scale(1);
    box-shadow: 0 0 0 0 rgba(34, 197, 94, 0);
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-2df1b12 *//* ===== FAQ SECTION ===== */

.faq-section {
  background: #ffffff;
  padding: 72px 20px 88px;
  font-family: "Sarabun", system-ui, -apple-system, "Segoe UI", sans-serif;
  color: #0f172a;
}

.faq-inner {
  max-width: 1120px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 32px;
  align-items: flex-start;
}

/* LEFT INTRO */
.faq-label {
  font-size: 12px;
  font-weight: 600;
  color: #197cf3;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 6px;
}

.faq-title {
  margin: 0 0 10px;
  font-size: 26px;
  font-weight: 700;
}

.faq-intro {
  margin: 0;
  font-size: 15px;
  line-height: 1.9;
  color: #4b5563;
}

/* RIGHT: ACCORDION */
.faq-right {
  position: relative;
}

.faq-right::before {
  content: "";
  position: absolute;
  inset: -40px -30px auto auto;
  background: radial-gradient(circle at top right, rgba(25, 124, 243, 0.14), transparent 60%);
  pointer-events: none;
}

/* FAQ item */
.faq-item {
  border-radius: 14px;
  border: 1px solid #e5e7eb;
  margin-bottom: 10px;
  background: #f9fafb;
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.06);
  overflow: hidden;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease,
    background 0.2s ease;
}

.faq-item[open] {
  border-color: rgba(25, 124, 243, 0.8);
  background: #ffffff;
  transform: translateY(-2px);
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.12);
}

/* Summary row */
.faq-item summary {
  list-style: none;
  cursor: pointer;
  padding: 14px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  font-size: 15px;
  font-weight: 600;
  color: #111827;
}

.faq-item summary::-webkit-details-marker {
  display: none;
}

/* Toggle icon (plus/minus) */
.faq-toggle {
  width: 22px;
  height: 22px;
  border-radius: 999px;
  border: 1px solid #d1d5db;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  position: relative;
}

.faq-toggle::before,
.faq-toggle::after {
  content: "";
  position: absolute;
  background: #6b7280;
  transition: transform 0.2s ease, opacity 0.2s ease;
}

.faq-toggle::before {
  width: 10px;
  height: 2px;
}

.faq-toggle::after {
  width: 2px;
  height: 10px;
}

/* when open -> minus icon */
.faq-item[open] .faq-toggle::after {
  opacity: 0;
  transform: scaleY(0);
}

/* Body */
.faq-body {
  padding: 0 18px 14px;
  border-top: 1px dashed #e5e7eb;
  animation: faq-fade 0.22s ease-out;
}

.faq-body p {
  margin: 10px 0 4px;
  font-size: 14px;
  line-height: 1.9;
  color: #374151;
}

/* Hover effect on summary */
.faq-item summary:hover {
  background: #f3f4f6;
}

/* Responsive */
@media (max-width: 900px) {
  .faq-inner {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .faq-section {
    padding: 56px 16px 72px;
  }

  .faq-title {
    font-size: 22px;
  }
}

/* Animations */
@keyframes faq-fade {
  from {
    opacity: 0;
    transform: translateY(-2px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}/* End custom CSS */
/* Start custom CSS for heading, class: .elementor-element-f87cd8e *//* Section base */
.contact-section {
  background: #ffffff;
  padding: 80px 20px;
  display: flex;
  justify-content: center;
}

.contact-inner {
  max-width: 900px;
  text-align: center;
}

/* PREMIUM H2 TITLE */
.contact-title {
  font-size: 2.4rem;                 /* ขนาดหัวเรื่อง H2 */
  font-weight: 800;
  letter-spacing: 0.02em;
  margin-bottom: 20px;

  /* Gradient text */
  background: linear-gradient(90deg, #197cf3, #0f4fa8);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;

  /* Soft glow shadow */
  text-shadow: 0px 3px 12px rgba(25, 124, 243, 0.25);

  position: relative;
}

/* underline bar highlight */
.contact-title::after {
  content: "";
  position: absolute;
  width: 110px;
  height: 4px;
  background: linear-gradient(90deg, #42b4ff, #197cf3);
  box-shadow: 0px 2px 8px rgba(25, 124, 243, 0.35);
  border-radius: 8px;
  bottom: -10px;
  left: 50%;
  transform: translateX(-50%);
}

/* Content text */
.contact-text {
  margin-top: 30px;
  font-size: 1rem;  /* 12pt เท่าที่ต้องการ */
  line-height: 1.75;
  color: #374151;
}

/* Responsive */
@media (max-width: 768px) {
  .contact-title {
    font-size: 2rem;
  }
  .contact-title::after {
    width: 90px;
  }
  .contact-text {
    font-size: 0.95rem;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-3c8de0f *//* Base */
*,
*::before,
*::after {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Sarabun", sans-serif;
  font-size: 12pt;
  background-color: #ffffff;
  color: #111827;
}

/* SECTION */
.contact-actions {
  background-color: #ffffff;
  padding: 32px 16px;
}

.contact-actions-inner {
  max-width: 900px;
  margin: 0 auto;
  display: flex;
  align-items: stretch;
  justify-content: center;
  border: 1px solid #e5e7eb;
  border-radius: 6px;
  overflow: hidden;
}

/* ITEM (Clickable card) */
.contact-item {
  flex: 1;
  padding: 24px 16px;
  text-align: center;
  border-right: 1px solid #e5e7eb;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  background-color: #ffffff;
  transition: 0.25s ease;
  cursor: pointer;
}

.contact-item:last-child {
  border-right: none; /* ใช้ได้กับเคส 2 ปุ่ม: WhatsApp | Email */
}

.contact-item:hover {
  background-color: #f3f4f6;
  transform: translateY(-2px);
}

/* ICON (SVG images) */
.contact-icon img {
  width: 36px;
  height: 36px;
  display: block;
}

/* LABEL */
.contact-label {
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #374151;
}

/* RESPONSIVE 1 COLUMN */
@media (max-width: 768px) {
  .contact-actions-inner {
    flex-direction: column;
  }

  .contact-item {
    border-right: none;
    border-bottom: 1px solid #e5e7eb;
  }

  .contact-item:last-child {
    border-bottom: none;
  }
}/* End custom CSS */