:root {
  --green-950: #03170d;
  --green-900: #05351d;
  --green-800: #084527;
  --green-700: #0c5c34;
  --green-600: #117143;
  --green-100: #e8f6ee;
  --lime: #b9ff66;
  --gold: #ffd166;
  --ink: #142018;
  --muted: #5f6f64;
  --line: rgba(20, 32, 24, 0.12);
  --white: #ffffff;
  --bg: #f7faf7;
  --danger: #e84f3d;
  --shopee: #ee4d2d;
  --messenger: #0877ff;
  --shadow: 0 22px 60px rgba(5, 53, 29, 0.16);
  --radius-lg: 28px;
  --radius-md: 18px;
  --radius-sm: 12px;
  --max: 1160px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--bg);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans Thai", "Helvetica Neue", Arial, sans-serif;
  line-height: 1.7;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; height: auto; }
button, input { font: inherit; }
.container { width: min(var(--max), calc(100% - 32px)); margin: 0 auto; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(247, 250, 247, 0.9);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--line);
}
.nav-bar {
  min-height: 74px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}
.brand { display: flex; align-items: center; gap: 10px; color: var(--green-900); font-weight: 900; letter-spacing: .7px; }
.brand img { width: 44px; height: 44px; border-radius: 14px; object-fit: cover; box-shadow: 0 10px 28px rgba(5, 53, 29, .18); }
.desktop-menu { display: flex; align-items: center; gap: 18px; color: var(--muted); font-weight: 800; font-size: 14px; }
.desktop-menu a:hover { color: var(--green-800); }
.lang-link img { width: 24px; }
.header-cta { display: flex; gap: 10px; align-items: center; }
.menu-button { display: none; width: 44px; height: 44px; border: 0; background: transparent; flex-direction: column; gap: 6px; justify-content: center; align-items: center; cursor: pointer; }
.menu-button span { width: 26px; height: 2px; background: var(--green-900); display: block; }
.mobile-menu { display: none; padding: 10px 20px 18px; border-top: 1px solid var(--line); background: #fff; }
.mobile-menu.open { display: grid; gap: 10px; }
.mobile-menu a { padding: 10px 0; color: var(--green-900); font-weight: 800; border-bottom: 1px solid var(--line); }

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 12px 18px;
  border-radius: 999px;
  border: 0;
  font-weight: 900;
  cursor: pointer;
  transition: transform .16s ease, box-shadow .16s ease, opacity .16s ease;
  white-space: nowrap;
  text-align: center;
}
.btn:hover { transform: translateY(-2px); }
.btn-shopee { background: var(--shopee); color: #fff; box-shadow: 0 12px 26px rgba(238,77,45,.25); }
.btn-messenger { background: var(--messenger); color: #fff; box-shadow: 0 12px 26px rgba(8,119,255,.22); }
.btn-ghost, .btn-outline { background: #fff; color: var(--green-900); border: 1px solid rgba(5,53,29,.16); box-shadow: 0 10px 22px rgba(5,53,29,.08); }
.cta-row { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.cta-row.center { justify-content: center; }

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(185,255,102,.18);
  color: var(--lime);
  font-size: 14px;
  font-weight: 900;
  letter-spacing: .2px;
  border: 1px solid rgba(185,255,102,.28);
}
.eyebrow.dark { background: var(--green-100); color: var(--green-800); border-color: rgba(12,92,52,.12); }

.hero-section {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 15% 12%, rgba(185,255,102,.25), transparent 32%),
    radial-gradient(circle at 90% 4%, rgba(255,209,102,.16), transparent 28%),
    linear-gradient(135deg, var(--green-900), var(--green-800) 58%, var(--green-950));
  color: #fff;
  padding: 68px 0 58px;
}
.hero-overlay { position: absolute; inset: 0; pointer-events: none; background: linear-gradient(90deg, rgba(0,0,0,.08), transparent); }
.hero-grid { position: relative; display: grid; grid-template-columns: .94fr 1.06fr; gap: 44px; align-items: center; }
.hero-copy h1 { margin: 22px 0 16px; font-size: clamp(38px, 5vw, 66px); line-height: 1.08; letter-spacing: -1.5px; }
.hero-copy h1 span { color: var(--lime); }
.lead { max-width: 690px; margin: 0 0 26px; color: rgba(255,255,255,.84); font-size: clamp(17px, 2vw, 21px); }
.trust-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin: 22px 0 4px; max-width: 650px; }
.trust-row div { border: 1px solid rgba(255,255,255,.2); background: rgba(255,255,255,.1); border-radius: 18px; padding: 14px; }
.trust-row strong { display: block; color: var(--lime); font-size: 28px; line-height: 1; }
.trust-row span { display: block; color: rgba(255,255,255,.82); font-weight: 800; font-size: 13px; margin-top: 4px; }
.trust-note { margin: 8px 0 20px; color: rgba(255,255,255,.58); font-size: 13px; }
.hero-bullets { margin: 0 0 28px; padding: 0; display: grid; gap: 10px; list-style: none; }
.hero-bullets li { display: flex; gap: 10px; color: rgba(255,255,255,.92); font-weight: 750; }
.hero-bullets span { display: inline-grid; place-items: center; flex: 0 0 24px; width: 24px; height: 24px; border-radius: 50%; background: rgba(185,255,102,.18); color: var(--lime); margin-top: 2px; }
.hero-image-card { position: relative; border-radius: 34px; padding: 14px; border: 1px solid rgba(255,255,255,.18); background: rgba(255,255,255,.1); box-shadow: 0 30px 90px rgba(0,0,0,.24); }
.hero-image-card img { width: 100%; aspect-ratio: 16/11; object-fit: cover; border-radius: 24px; }
.hero-floating-card { position: absolute; left: -20px; bottom: 34px; width: min(280px, calc(100% - 28px)); background: #fff; color: var(--green-900); border-radius: 18px; padding: 16px; box-shadow: var(--shadow); font-weight: 900; }
.hero-floating-card span { display: block; color: var(--muted); font-weight: 750; font-size: 13px; margin-top: 3px; }
.hero-price-card {
  display: inline-grid;
  gap: 6px;
  padding: 20px 26px;
  margin: 4px 0 24px;
  border-radius: 24px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 18px 50px rgba(0,0,0,.18);
}

.hero-price strong {
  font-size: clamp(54px, 7vw, 86px);
  line-height: .9;
  letter-spacing: -2px;
}

.hero-price span {
  font-size: clamp(20px, 2.4vw, 32px);
  color: rgba(255,255,255,.78);
  font-weight: 900;
}

.section { padding: 74px 0; }
.section-light { background: var(--bg); }
.section-white { background: #fff; }
.section-green-soft { background: #eef6f0; }
.section-dark { background: linear-gradient(135deg, var(--green-950), var(--green-900)); color: #fff; }
.section-title { max-width: 860px; margin: 0 auto 36px; text-align: center; }
.section-title h2 { margin: 14px 0 10px; color: var(--green-900); font-size: clamp(30px, 4vw, 48px); line-height: 1.18; letter-spacing: -1px; }
.section-title p { margin: 0; color: var(--muted); font-size: 18px; }
.section-title.inverted h2 { color: #fff; }
.section-title.inverted p { color: rgba(255,255,255,.76); }

.pain-grid, .features-grid, .modes-grid, .faq-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.pain-grid { grid-template-columns: repeat(2, 1fr); }
.pain-card, .feature-card, .mode-card, .faq-item, .offer-card, .product-card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-md); padding: 24px; box-shadow: 0 12px 36px rgba(5,53,29,.06); }
.pain-card { display: flex; gap: 14px; align-items: flex-start; }
.pain-card span { flex: 0 0 34px; height: 34px; border-radius: 12px; display: grid; place-items: center; background: rgba(232,79,61,.1); color: var(--danger); font-weight: 900; }
.pain-card strong { color: var(--green-900); font-weight: 850; }

.split { display: grid; grid-template-columns: .95fr 1.05fr; gap: 36px; align-items: center; }
.quote-box { background: var(--green-900); color: #fff; border-radius: var(--radius-lg); padding: 42px; box-shadow: var(--shadow); }
.quote-box h2 { margin: 0 0 14px; font-size: clamp(30px, 4vw, 48px); line-height: 1.16; letter-spacing: -1px; }
.quote-box p { margin: 0; color: rgba(255,255,255,.82); font-size: 18px; }
.logic-list { display: grid; gap: 14px; }
.logic-item { padding: 18px; border: 1px solid var(--line); background: var(--bg); border-radius: var(--radius-sm); }
.logic-item strong { color: var(--green-900); }
.logic-item p { margin: 6px 0 0; color: var(--muted); }


.feature-visual {
  margin: 0 0 24px;
  border-radius: 28px;
  overflow: hidden;
  background: var(--green-900);
  border: 1px solid rgba(5, 53, 29, 0.14);
  box-shadow: 0 18px 52px rgba(5, 53, 29, 0.12);
}
.feature-visual picture, .feature-visual img {
  width: 100%;
  display: block;
}

.feature-card .num { width: 42px; height: 42px; display: grid; place-items: center; margin-bottom: 16px; border-radius: 14px; background: var(--green-100); color: var(--green-800); font-weight: 900; }
.feature-card h3, .mode-card h3, .faq-item h3, .offer-card h3 { margin: 0 0 8px; color: var(--green-900); font-size: 22px; line-height: 1.3; }
.feature-card p, .mode-card p, .faq-item p { margin: 0; color: var(--muted); }
.mode-card span { display: inline-flex; padding: 5px 10px; border-radius: 999px; background: var(--green-100); color: var(--green-800); font-size: 13px; font-weight: 900; margin-bottom: 16px; }
.mode-card ul { margin: 16px 0 0; padding-left: 20px; color: var(--muted); font-weight: 700; }

.credential-photo-card { overflow: hidden; border-radius: 24px; background: #01130c; border: 1px solid rgba(255,255,255,.16); box-shadow: 0 24px 70px rgba(0,0,0,.25); margin-bottom: 18px; }
.credential-photo-card img { width: 100%; max-height: 430px; object-fit: contain; background: #01130c; }
.credential-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin: 20px 0 26px; }
.credential-stats div { padding: 20px; border: 1px solid rgba(255,255,255,.16); border-radius: 20px; background: rgba(255,255,255,.08); }
.credential-stats strong { display: block; font-size: 34px; line-height: 1; color: var(--lime); }
.credential-stats span { display: block; margin-top: 8px; font-weight: 900; }
.credential-stats small { color: rgba(255,255,255,.6); }
.pro-quotes-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.pro-quote-card { display: flex; gap: 14px; align-items: center; padding: 18px; border: 1px solid rgba(255,255,255,.14); border-radius: 20px; background: rgba(255,255,255,.08); }
.pro-quote-card img { width: 76px; height: 76px; object-fit: cover; border-radius: 50%; background: rgba(255,255,255,.12); }
.pro-quote-card h3 { margin: 0 0 4px; color: #fff; }
.pro-quote-card p { margin: 0; color: rgba(255,255,255,.76); font-size: 14px; }

.carousel-shell { display: grid; grid-template-columns: auto 1fr auto; gap: 12px; align-items: center; }
.influencer-track { display: grid; grid-auto-flow: column; grid-auto-columns: minmax(240px, 1fr); gap: 16px; overflow-x: auto; overscroll-behavior-inline: contain; scroll-snap-type: inline mandatory; padding: 4px 2px 18px; scrollbar-width: thin; }
.influencer-card { min-height: 220px; border-radius: 22px; padding: 22px; scroll-snap-align: start; display: flex; flex-direction: column; justify-content: space-between; color: #fff; box-shadow: 0 16px 42px rgba(5,53,29,.12); }
.influencer-card.tiktok { background: linear-gradient(135deg, #101010, #223027); }
.influencer-card.instagram { background: linear-gradient(135deg, #4b164c, #a53555 55%, #d98d36); }
.influencer-card span { align-self: flex-start; padding: 5px 10px; border-radius: 999px; background: rgba(255,255,255,.18); font-weight: 900; font-size: 12px; }
.influencer-card h3 { margin: auto 0 8px; font-size: 24px; line-height: 1.1; }
.influencer-card p { margin: 0 0 12px; color: rgba(255,255,255,.76); }
.influencer-card strong { color: var(--lime); }
.embed-layout-note { margin: -10px auto 24px; max-width: 920px; padding: 14px 18px; border: 1px solid rgba(5,53,29,.12); border-radius: 18px; background: linear-gradient(135deg, #fff, #f1f8f3); color: var(--muted); font-size: 14px; box-shadow: 0 12px 30px rgba(5,53,29,.05); }
.embed-layout-note strong { color: var(--green-900); }
.embed-carousel-shell { align-items: start; }
.embed-track { grid-auto-columns: 320px; align-items: start; padding-bottom: 22px; }
.influencer-embed-card { scroll-snap-align: start; min-width: 0; border: 1px solid var(--line); border-radius: 28px; padding: 14px; background: #fff; box-shadow: 0 18px 48px rgba(5,53,29,.1); }
.embed-card-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 12px; }
.embed-card-head span { display: inline-flex; align-items: center; padding: 5px 10px; border-radius: 999px; background: var(--green-100); color: var(--green-800); font-size: 12px; font-weight: 900; }
.embed-card-head strong { color: var(--green-900); font-size: 15px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.embed-media { min-height: 560px; border-radius: 22px; overflow: hidden; background: linear-gradient(135deg, #f5f8f5, #ffffff); display: flex; justify-content: center; align-items: flex-start; }
.embed-media .tiktok-embed, .embed-media .instagram-media { margin: 0 auto !important; width: 100% !important; max-width: 100% !important; min-width: 0 !important; }
.embed-media iframe { width: 100% !important; max-width: 100% !important; border-radius: 16px; }
.instagram-direct-embed { width: 100%; min-height: 650px; border: 0; border-radius: 16px; background: #fff; display: block; }
.embed-fallback-link { display: inline-flex; justify-content: center; align-items: center; width: 100%; margin-top: 10px; padding: 10px 12px; border-radius: 999px; background: var(--green-100); color: var(--green-900); font-weight: 900; font-size: 13px; }
.embed-fallback-link:hover { background: #dff1e6; }
.carousel-btn, .screen-btn { border: 0; width: 44px; height: 44px; border-radius: 50%; background: var(--green-900); color: #fff; font-size: 30px; line-height: 1; display: grid; place-items: center; cursor: pointer; box-shadow: var(--shadow); }

.quickstart-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 34px; align-items: center; }
.quickstart-grid h2 { margin: 14px 0 20px; color: var(--green-900); font-size: clamp(30px, 4vw, 46px); line-height: 1.18; }
.quickstart-list { counter-reset: step; list-style: none; padding: 0; margin: 0 0 26px; display: grid; gap: 12px; }
.quickstart-list li { position: relative; padding: 15px 16px 15px 54px; background: #fff; border: 1px solid var(--line); border-radius: 16px; font-weight: 800; color: var(--green-900); }
.quickstart-list li::before { counter-increment: step; content: counter(step); position: absolute; left: 14px; top: 50%; transform: translateY(-50%); width: 28px; height: 28px; border-radius: 50%; background: var(--green-900); color: #fff; display: grid; place-items: center; }
.product-card img { width: 100%; object-fit: contain; }

.screenshot-carousel { display: grid; grid-template-columns: auto 1fr auto; gap: 12px; align-items: center; max-width: 960px; margin: 0 auto; }
.screen-window { overflow: hidden; border-radius: 24px; border: 1px solid var(--line); background: #fff; box-shadow: var(--shadow); }
.screen-track { display: flex; transition: transform .35s ease; align-items: stretch; }
.screen-slide { width: 100%; flex: 0 0 100%; display: flex; align-items: center; justify-content: center; aspect-ratio: 4 / 3; background: #fff; }
.screen-track img { width: 100%; height: 100%; display: block; object-fit: contain; }
.screen-dots { display: flex; justify-content: center; gap: 8px; margin-top: 18px; }
.screen-dots button { width: 10px; height: 10px; border: 0; border-radius: 50%; background: rgba(5,53,29,.22); cursor: pointer; }
.screen-dots button.active { background: var(--green-900); }

.offer-section { background: radial-gradient(circle at 70% 20%, rgba(185,255,102,.22), transparent 28%), linear-gradient(135deg, #f7faf7, #e9f5ec); }
.offer-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 24px; align-items: start; }
.promo-card { position: sticky; top: 96px; background: var(--green-900); color: #fff; border-radius: var(--radius-lg); padding: 32px; box-shadow: var(--shadow); }
.promo-card .month { display: inline-flex; padding: 6px 12px; border-radius: 999px; color: var(--green-900); background: var(--lime); font-weight: 900; margin-bottom: 16px; }
.promo-card h2 { margin: 0 0 10px; font-size: clamp(30px,4vw,46px); line-height: 1.12; letter-spacing: -1px; }
.promo-card p { color: rgba(255,255,255,.78); margin: 0 0 20px; }
.price { display: flex; align-items: baseline; gap: 10px; margin: 20px 0 6px; }
.price strong { font-size: 44px; line-height: 1; }
.price span { color: rgba(255,255,255,.68); font-weight: 800; }
.promo-list { margin: 20px 0 24px; padding: 0; list-style: none; display: grid; gap: 10px; }
.promo-list li { display: flex; gap: 10px; color: rgba(255,255,255,.86); font-weight: 750; }
.offer-card h3:not(:first-child) { margin-top: 28px; }
.check-list { margin: 0; padding: 0; list-style: none; display: grid; gap: 12px; }
.check-list li { position: relative; padding-left: 34px; color: var(--muted); font-weight: 750; }
.check-list li::before { content: "✓"; position: absolute; left: 0; top: 0; width: 22px; height: 22px; border-radius: 50%; display: grid; place-items: center; background: var(--green-100); color: var(--green-800); font-weight: 900; }

.final-cta { padding: 82px 0; background: radial-gradient(circle at 30% 0%, rgba(185,255,102,.24), transparent 30%), linear-gradient(135deg, var(--green-900), var(--green-950)); color: #fff; text-align: center; }
.final-cta h2 { margin: 0 auto 16px; max-width: 860px; font-size: clamp(34px,5vw,58px); line-height: 1.12; letter-spacing: -1px; }
.final-cta p { margin: 0 auto 28px; max-width: 700px; color: rgba(255,255,255,.78); font-size: 18px; }
.sticky-mobile-cta { position: fixed; left: 0; right: 0; bottom: 0; z-index: 60; padding: 10px; background: rgba(255,255,255,.94); backdrop-filter: blur(14px); border-top: 1px solid var(--line); display: none; gap: 8px; }
.sticky-mobile-cta .btn { flex: 1; min-height: 48px; padding: 10px 12px; font-size: 14px; }
.site-footer { background: #aac1bf; color: #fff; padding: 26px 0; }
.footer-inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.social-row { display: flex; gap: 10px; margin-bottom: 8px; }
.social-row img { width: 24px; height: 24px; }
.site-footer p { margin: 0; font-size: 14px; }
.footer-links { display: flex; gap: 18px; flex-wrap: wrap; font-weight: 800; }
.footer-links a:hover { color: var(--green-900); }

.cookie-wrapper { z-index: 80; box-shadow: 0 22px 60px rgba(0,0,0,.14); }

@media (max-width: 1060px) {
  .desktop-menu { gap: 12px; font-size: 13px; }
  .header-cta .btn { padding-inline: 14px; }
}
@media (max-width: 940px) {
  .desktop-menu, .header-cta { display: none; }
  .menu-button { display: flex; }
  .hero-grid, .split, .quickstart-grid, .offer-grid { grid-template-columns: 1fr; }
  .features-grid, .modes-grid, .credential-stats, .pro-quotes-grid { grid-template-columns: repeat(2, 1fr); }
  .hero-floating-card { left: 26px; }
  .promo-card { position: static; }
}
@media (max-width: 680px) {
  body { padding-bottom: 76px; }
  .container { width: min(100% - 22px, var(--max)); }
  .section { padding: 52px 0; }
  .hero-section { padding: 42px 0; }
  .trust-row, .pain-grid, .features-grid, .modes-grid, .faq-grid, .credential-stats, .pro-quotes-grid { grid-template-columns: 1fr; }
  .feature-visual { overflow-x: auto; border-radius: 20px; -webkit-overflow-scrolling: touch; }
  .feature-visual picture, .feature-visual img { width: auto; min-width: 720px; max-width: none; }
  .hero-image-card { padding: 8px; border-radius: 24px; }
  .hero-image-card img { border-radius: 18px; aspect-ratio: 4/3; }
  .hero-floating-card { position: static; width: 100%; margin-top: 10px; }
  .cta-row .btn, .vertical-mobile .btn { width: 100%; }
  .quote-box, .promo-card { padding: 28px; border-radius: 22px; }
  .carousel-shell, .screenshot-carousel { grid-template-columns: 1fr; }
  .carousel-btn, .screen-btn { display: none; }
  .influencer-track { grid-auto-columns: 82%; }
  .embed-track { grid-auto-columns: min(100%, 320px); justify-content: start; }
  .influencer-embed-card { padding: 10px; border-radius: 22px; }
  .embed-media { min-height: 520px; border-radius: 18px; }
  .instagram-direct-embed { min-height: 620px; }
  .embed-layout-note { text-align: left; margin-bottom: 18px; }
  .sticky-mobile-cta { display: flex; }
  .footer-inner { display: grid; }
  .footer-links { display: grid; gap: 8px; }
}


/* Offer card v2 */
.promo-card-v2 { display: grid; gap: 18px; }
.promo-card-v2 .month { margin-bottom: 0; justify-self: start; }
.promo-buy-line { display: grid; grid-template-columns: auto 1fr; gap: 14px; align-items: center; padding: 16px; border-radius: 22px; background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.16); }
.promo-shopee-price { color: #fff; font-size: clamp(22px, 3vw, 34px); line-height: 1.08; font-weight: 950; letter-spacing: -.7px; }
.promo-direct-box { display: grid; gap: 8px; padding: 20px; border-radius: 24px; background: #fff; color: var(--green-950); box-shadow: 0 18px 50px rgba(0,0,0,.18); }
.promo-period { color: var(--green-700); font-size: 17px; font-weight: 900; }
.promo-discount { color: var(--green-950); font-size: clamp(30px, 4vw, 46px); line-height: 1.04; font-weight: 950; letter-spacing: -1px; }
.promo-direct-price { color: #f15a24; font-size: clamp(30px, 4vw, 48px); line-height: 1.04; font-weight: 950; letter-spacing: -1px; }
.promo-card-v2 > .btn { width: 100%; justify-content: center; }
.promo-card-v2 .promo-list { margin-top: 2px; }
@media (max-width: 680px) {
  .promo-buy-line { grid-template-columns: 1fr; }
  .promo-shopee-price { text-align: center; }
}
