@font-face {
  font-family: "Plus Jakarta Sans Variable";
  font-style: normal;
  font-display: swap;
  font-weight: 200 800;
  src: url("/fonts/plus-jakarta-sans-latin-ext-wght-normal.woff2") format("woff2-variations");
  unicode-range: U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face {
  font-family: "Plus Jakarta Sans Variable";
  font-style: normal;
  font-display: swap;
  font-weight: 200 800;
  src: url("/fonts/plus-jakarta-sans-latin-wght-normal.woff2") format("woff2-variations");
  unicode-range: U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face {
  font-family: "Noto Sans Thai Looped Variable";
  font-style: normal;
  font-display: swap;
  font-weight: 100 900;
  src: url("/fonts/noto-sans-thai-looped-thai-wght-normal.woff2") format("woff2-variations");
  unicode-range: U+0E00-0E7F;
}
:root {
  color-scheme: dark;
  --ink: #050914;
  --navy: #101828;
  --panel: #111a2d;
  --panel-2: #18243a;
  --line: rgba(248, 250, 252, 0.16);
  --line-strong: rgba(224, 200, 107, 0.42);
  --white: #f8fafc;
  --muted: #a8b2c1;
  --gold: #e0c86b;
  --gold-2: #c9a84c;
  --teal: #69b7aa;
  --font: "Plus Jakarta Sans Variable", Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
html:lang(th) {
  --font: "Noto Sans Thai Looped Variable", "Plus Jakarta Sans Variable", ui-sans-serif, system-ui, sans-serif;
}
html:lang(th) h1,
html:lang(th) h2,
html:lang(th) h3 {
  line-height: 1.12;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font);
  color: var(--white);
  background: var(--ink);
  line-height: 1.65;
}
a { color: inherit; }
.shell {
  position: relative;
  min-height: 100vh;
  overflow-x: clip;
  background:
    linear-gradient(rgba(248, 250, 252, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(248, 250, 252, 0.035) 1px, transparent 1px),
    var(--ink);
  background-size: 44px 44px, 44px 44px, auto;
}
.shell::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 74% 28%, rgba(224, 200, 107, 0.12), transparent 28%),
    radial-gradient(circle at 18% 48%, rgba(105, 183, 170, 0.12), transparent 32%),
    linear-gradient(115deg, rgba(5, 9, 20, 0.18), rgba(16, 24, 40, 0.5));
  opacity: 0.8;
}
.nav, .hero, main, .footer {
  position: relative;
  z-index: 1;
}
.nav {
  position: sticky;
  top: 0;
  z-index: 20;
  background: rgba(5, 9, 20, 0.9);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--line);
}
.nav-inner, .container {
  width: min(1160px, calc(100% - 40px));
  margin: 0 auto;
}
.nav-inner {
  min-height: 74px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  font-weight: 800;
}
.brand img { width: 110px; height: auto; display: block; }
.brand span, .nav-links a, .language-pill, .lang-switch a, .button, .micro, .price-label {
  font-size: 0.78rem;
  font-weight: 850;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.brand span { display: none; color: var(--muted); }
.nav-links { display: flex; align-items: center; gap: 2px; }
.nav-links a {
  padding: 10px 12px;
  border-radius: 8px;
  color: rgba(248, 250, 252, 0.78);
  text-decoration: none;
  white-space: nowrap;
}
.nav-links a:hover,
.nav-links a:focus-visible {
  background: rgba(224, 200, 107, 0.12);
  color: var(--gold);
  outline: none;
}
.nav-actions { display: flex; align-items: center; gap: 10px; }
.language-pill {
  display: inline-flex;
  min-width: 58px;
  min-height: 40px;
  align-items: center;
  justify-content: center;
  padding: 8px 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.07);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.14);
  color: #fff;
  font-size: 0.82rem;
  font-weight: 900;
  letter-spacing: 0;
}
.lang-switch {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.06);
}
.lang-switch a {
  display: inline-flex;
  min-width: 38px;
  min-height: 32px;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  color: rgba(248, 250, 252, 0.76);
  text-decoration: none;
  letter-spacing: 0;
}
.lang-switch a.is-active {
  background: rgba(224, 200, 107, 0.18);
  color: var(--gold);
}
.nav-cta {
  display: inline-flex;
  min-height: 40px;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  border: 1px solid var(--gold-2);
  border-radius: 8px;
  background: var(--gold-2);
  color: #111827;
  font-size: 1rem;
  font-weight: 800;
  text-decoration: none;
  white-space: nowrap;
}
.hero {
  position: relative;
  padding: 90px 0 72px;
  background:
    linear-gradient(rgba(248, 250, 252, 0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(248, 250, 252, 0.05) 1px, transparent 1px),
    linear-gradient(135deg, rgba(5, 9, 20, 0.88) 0%, rgba(13, 22, 40, 0.82) 58%, rgba(17, 31, 52, 0.88) 100%);
  background-size: 44px 44px, 44px 44px, auto;
  border-bottom: 1px solid var(--line);
}
.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.86fr);
  gap: 44px;
  align-items: center;
}
h1, h2, h3, p { margin-top: 0; }
h1, h2, h3 { line-height: 1.06; letter-spacing: 0; }
h1 { font-size: 4.8rem; max-width: 840px; margin-bottom: 24px; }
h2 { font-size: 3rem; margin-bottom: 18px; }
h3 { font-size: 1.35rem; margin-bottom: 10px; }
p { color: var(--muted); }
figure { margin: 0; }
.lead { font-size: 1.28rem; max-width: 760px; margin-bottom: 28px; color: #dce5f2; }
.hero-actions, .button-row { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 48px;
  border-radius: 8px;
  padding: 0 18px;
  text-decoration: none;
  background: var(--gold);
  color: #111827;
  border: 1px solid rgba(224, 200, 107, 0.72);
}
.button.secondary {
  color: var(--white);
  background: transparent;
  border-color: var(--line);
}
.button svg { width: 18px; height: 18px; }
.hero-media {
  position: relative;
  overflow: hidden;
  margin: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.06);
  padding: 12px;
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.32);
}
.hero-media::after {
  content: "";
  position: absolute;
  inset: 12px;
  border: 1px solid rgba(224, 200, 107, 0.18);
  border-radius: 50%;
  pointer-events: none;
  transform: scaleX(1.7) rotate(-10deg);
}
.hero-media img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 6px;
}
.offer-panel {
  margin-top: 16px;
  border: 1px solid var(--line-strong);
  border-radius: 8px;
  background: rgba(17, 26, 45, 0.86);
  padding: 18px;
}
.micro { color: var(--gold); display: block; margin-bottom: 8px; }
.offer-price {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 14px 0;
}
.offer-price strong {
  display: block;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.05);
}
.section { padding: 78px 0; }
.section.alt { background: #08101f; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.section-head { max-width: 780px; margin-bottom: 30px; }
.section-head p { font-size: 1.08rem; }
.module-grid, .package-grid, .fit-grid, .faq-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}
.module-card, .package-card, .fit-card, .faq-card, .process-row, .included-panel {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.055);
}
.module-card, .package-card, .fit-card, .faq-card {
  padding: 22px;
}
.module-card svg {
  width: 34px;
  height: 34px;
  color: var(--gold);
  margin-bottom: 18px;
}
.module-card span, .package-card span {
  display: block;
  color: var(--teal);
  font-weight: 900;
  margin-bottom: 8px;
}
.included-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.88fr) minmax(0, 1.12fr);
  gap: 24px;
  align-items: start;
}
.included-panel { padding: 26px; background: rgba(224, 200, 107, 0.08); border-color: var(--line-strong); }
.check-list, .plain-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
.check-list li, .plain-list li {
  display: grid;
  grid-template-columns: 26px minmax(0, 1fr);
  gap: 10px;
  color: #d8e0ec;
}
.check-list svg, .plain-list svg { width: 22px; height: 22px; color: var(--gold); margin-top: 2px; }
.package-card { display: flex; flex-direction: column; }
.package-card strong { color: var(--gold); display: block; margin-bottom: 14px; }
.package-card ul { margin-top: auto; padding-left: 18px; color: #d9e2ef; }
.process-list { display: grid; gap: 14px; }
.process-row {
  display: grid;
  grid-template-columns: 74px minmax(0, 1fr);
  gap: 18px;
  padding: 22px;
  align-items: start;
}
.step {
  width: 54px;
  height: 54px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  background: var(--gold);
  color: #111827;
  font-weight: 900;
}
.fit-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.fit-card.good { border-color: rgba(105, 183, 170, 0.42); }
.fit-card.avoid { border-color: rgba(224, 200, 107, 0.36); }
.faq-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.cta-band {
  padding: 52px 0;
  background: var(--gold);
  color: #111827;
}
.cta-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 28px;
  align-items: center;
}
.cta-band p { color: #2b3140; margin-bottom: 0; }
.cta-band .button { background: #111827; color: #fff; border-color: #111827; }
.footer {
  background: #050914;
  color: #dce4f0;
  padding: 34px 0;
  border-top: 1px solid var(--line);
}
.footer .container { display: flex; justify-content: space-between; gap: 20px; align-items: center; }
.footer a { color: #fff; font-weight: 800; text-decoration: none; }
@media (max-width: 980px) {
  .nav-inner { display: grid; grid-template-columns: auto auto; align-items: center; padding: 12px 0; gap: 10px 14px; }
  .nav-links { grid-column: 1 / -1; overflow-x: auto; flex-wrap: nowrap; gap: 4px 8px; margin-left: 0; padding-bottom: 2px; scrollbar-width: none; }
  .nav-links::-webkit-scrollbar { display: none; }
  .nav-actions { justify-self: end; }
  .nav-cta { display: none; }
  .hero-grid, .included-grid, .cta-grid { grid-template-columns: 1fr; }
  .module-grid, .package-grid { grid-template-columns: 1fr; }
  .cta-grid { align-items: start; }
}
@media (max-width: 760px) {
  .nav-inner, .container { width: min(100% - 28px, 1160px); }
  .hero { padding: 58px 0 50px; }
  h1 { font-size: 3rem; }
  h2 { font-size: 2.1rem; }
  .lead { font-size: 1.08rem; }
  .section { padding: 54px 0; }
  .offer-price, .fit-grid, .faq-grid, .process-row { grid-template-columns: 1fr; }
  .process-row { gap: 12px; }
  .footer .container { align-items: flex-start; flex-direction: column; }
}
.lang-switch { display: inline-flex; gap: 2px; padding: 2px; border: 1px solid var(--line); border-radius: 9px; background: rgba(255, 255, 255, 0.06); }
.lang-switch a { display: inline-flex; align-items: center; justify-content: center; min-width: 40px; min-height: 36px; padding: 6px 10px; border-radius: 7px; color: rgba(248, 250, 252, 0.78); text-decoration: none; font-size: 0.82rem; font-weight: 900; letter-spacing: 0; }
.lang-switch a:hover, .lang-switch a:focus-visible { background: rgba(224, 200, 107, 0.14); color: var(--gold); outline: none; }
.lang-switch a.is-active { background: var(--gold-2); color: #111827; }
.skip-link { position: absolute; left: 16px; top: -50px; z-index: 1000; padding: 10px 14px; border-radius: 6px; background: var(--gold-2, var(--gold)); color: #171309; transition: top 160ms ease; }
.skip-link:focus { top: 14px; }
.site-header { position: sticky; top: 0; z-index: 80; border-bottom: 1px solid var(--line-dark, var(--line)); background: rgba(5, 9, 20, 0.88); backdrop-filter: blur(18px); }
.site-header .nav-bar { min-height: 74px; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.site-header .brand { display: flex; align-items: center; gap: 12px; min-width: 0; text-decoration: none; font-weight: 800; }
.site-header .brand img { width: 110px; height: auto; display: block; }
.site-header .brand span { display: none; color: var(--muted); font-size: 0.78rem; font-weight: 850; letter-spacing: 0.08em; text-transform: uppercase; white-space: nowrap; }
.site-header .nav-links { display: flex; align-items: center; gap: 2px; }
.site-header .nav-links a { padding: 10px 12px; border-radius: 8px; color: rgba(248, 250, 252, 0.78); text-decoration: none; font-size: 0.78rem; font-weight: 850; letter-spacing: 0.08em; text-transform: uppercase; white-space: nowrap; transition: background 160ms ease, color 160ms ease; }
.site-header .nav-links a:hover, .site-header .nav-links a:focus-visible { background: rgba(224, 200, 107, 0.12); color: var(--gold-2, var(--gold)); outline: none; }
.site-header .nav-actions { display: flex; align-items: center; gap: 10px; }
.site-header .nav-actions .btn, .site-header .nav-cta { min-height: 40px; padding: 10px 14px; white-space: nowrap; }
.site-header .nav-cta { display: inline-flex; align-items: center; justify-content: center; border-radius: 8px; font-size: 1rem; font-weight: 800; text-decoration: none; }
.site-header .btn-dark { border: 1px solid var(--gold-2, var(--gold)); background: var(--gold-2, var(--gold)); color: #171309; }
.language-switcher { position: relative; z-index: 20; }
.language-trigger { display: inline-flex; min-width: 58px; min-height: 40px; align-items: center; justify-content: center; gap: 8px; padding: 8px 14px; border: 1px solid var(--line-dark, var(--line)); border-radius: 8px; background: rgba(255, 255, 255, 0.07); box-shadow: 0 10px 28px rgba(0, 0, 0, 0.14); color: #fff; cursor: pointer; font-size: 0.82rem; font-weight: 900; letter-spacing: 0; transition: background 160ms ease, border-color 160ms ease, color 160ms ease; }
.language-trigger:hover, .language-trigger:focus-visible, .language-switcher.is-open .language-trigger { background: rgba(224, 200, 107, 0.12); border-color: rgba(224, 200, 107, 0.4); color: var(--gold-2, var(--gold)); outline: none; }
.language-menu { position: absolute; top: calc(100% + 8px); right: 0; display: grid; width: 210px; gap: 4px; padding: 6px; border: 1px solid var(--line-dark, var(--line)); border-radius: 8px; background: rgba(8, 16, 31, 0.98); box-shadow: 0 22px 60px rgba(0, 0, 0, 0.34); opacity: 0; pointer-events: none; transform: translateY(-8px); transition: opacity 160ms ease, transform 160ms ease, visibility 160ms ease; visibility: hidden; }
.language-switcher.is-open .language-menu { opacity: 1; pointer-events: auto; transform: translateY(0); visibility: visible; }
.language-menu a { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 10px; align-items: center; padding: 9px 10px; border: 0; border-radius: 6px; background: transparent; color: #fff; text-decoration: none; text-align: left; }
.language-menu a:hover, .language-menu a:focus-visible { background: rgba(224, 200, 107, 0.12); outline: none; }
.language-menu a.is-active { background: var(--gold-2, var(--gold)); color: #171309; }
.language-menu a span { overflow: hidden; font-size: 0.9rem; font-weight: 850; text-overflow: ellipsis; white-space: nowrap; }
.language-menu a small { font-size: 0.74rem; font-weight: 900; opacity: 0.74; }
.menu-button { display: none; width: 44px; height: 44px; align-items: center; justify-content: center; flex-direction: column; gap: 5px; border: 1px solid var(--line-dark, var(--line)); border-radius: 8px; background: rgba(255, 255, 255, 0.07); cursor: pointer; }
.menu-button span { width: 19px; height: 2px; background: #fff; }
.menu-button:focus-visible { outline: 3px solid rgba(201, 168, 76, 0.45); outline-offset: 3px; }
@media (max-width: 1040px) {
  .site-header .nav-links, .site-header .nav-actions .nav-cta { display: none; }
  .site-header .menu-button { display: inline-flex; }
  .site-header .nav-links { position: fixed; inset: 74px 14px auto; flex-direction: column; align-items: stretch; gap: 0; padding: 8px; border: 1px solid var(--line-dark, var(--line)); border-radius: 8px; background: rgba(8, 16, 31, 0.98); box-shadow: 0 22px 60px rgba(0, 0, 0, 0.34); }
  .site-header .nav-links.is-open { display: flex; }
  .site-header .nav-links a { padding: 15px; }
}
@media (max-width: 480px) {
  .site-header .nav-bar { gap: 10px; }
  .site-header .brand img { width: 96px; }
  .language-trigger { min-height: 38px; gap: 7px; padding: 8px 9px; font-size: 0.72rem; }
  .language-menu { right: -48px; width: min(210px, calc(100vw - 28px)); }
}
.reveal { opacity: 0; transform: translateY(52px) scale(0.965); transition: opacity 0.72s cubic-bezier(0.16, 1, 0.3, 1), transform 0.84s cubic-bezier(0.16, 1, 0.3, 1); transition-delay: calc(var(--reveal-stagger, 0) * 85ms); }
.reveal.from-top { transform: translateY(-52px) scale(0.965); }
.reveal.is-visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal, .reveal.from-top { opacity: 1; transform: none; transition: none; }
}
@font-face {
  font-family: "Noto Sans Thai Looped";
  font-style: normal;
  font-display: swap;
  font-weight: 200 800;
  src: url("/fonts/noto-sans-thai-looped-thai-wght-normal.woff2") format("woff2-variations");
  unicode-range: U+0E01-0E5B, U+200C-200D, U+25CC;
}
html:lang(th) {
  --font: "Noto Sans Thai Looped", "Plus Jakarta Sans Variable", Inter, ui-sans-serif, system-ui, sans-serif;
}
html:lang(th) body { line-height: 1.8; }
