/* v0.1.7 - ThaiFly CSS bridge
   Existing project CSS found:
   - tte-frontend: thaifly-tour-engine/assets/css/frontend.css
   - thaifly-tour-homepage-hotfix: thaifly-tour-homepage-hotfix/assets/homepage-hotfix.css
   This file now acts as an app-shell adapter, not a full theme replacement.
*/

/* Fullscreen mode: hide theme shell when this shortcode is used */
body.tf-ltu-fullscreen {
  margin: 0 !important;
  overflow: hidden !important;
  background: #f4f5f7 !important;
}

body.tf-ltu-fullscreen > header,
body.tf-ltu-fullscreen > footer,
body.tf-ltu-fullscreen .wp-site-blocks > header,
body.tf-ltu-fullscreen .wp-site-blocks > footer,
body.tf-ltu-fullscreen .site-header,
body.tf-ltu-fullscreen .site-footer,
body.tf-ltu-fullscreen .wp-block-template-part,
body.tf-ltu-fullscreen .entry-header,
body.tf-ltu-fullscreen .page-header,
body.tf-ltu-fullscreen .wp-block-post-title,
body.tf-ltu-fullscreen h1.wp-block-post-title {
  display: none !important;
}

body.tf-ltu-fullscreen .wp-site-blocks,
body.tf-ltu-fullscreen .site,
body.tf-ltu-fullscreen #page,
body.tf-ltu-fullscreen #content,
body.tf-ltu-fullscreen .site-content,
body.tf-ltu-fullscreen main,
body.tf-ltu-fullscreen .entry-content,
body.tf-ltu-fullscreen .wp-block-post-content {
  margin: 0 !important;
  padding: 0 !important;
  max-width: none !important;
  width: 100% !important;
}

body.tf-ltu-fullscreen .wp-block-group,
body.tf-ltu-fullscreen .wp-block-group__inner-container {
  max-width: none !important;
}

body.tf-ltu-fullscreen .tf-ltu-app {
  position: fixed;
  inset: 0;
  z-index: 999999;
  width: 100%;
  height: 100dvh;
  overflow: hidden;
}

body.admin-bar.tf-ltu-fullscreen .tf-ltu-app {
  top: 32px;
  height: calc(100dvh - 32px);
}

@media (max-width: 782px) {
  body.admin-bar.tf-ltu-fullscreen .tf-ltu-app {
    top: 46px;
    height: calc(100dvh - 46px);
  }
}


* {
  box-sizing: border-box;
}

.tf-ltu-app {
  --tf-blue: var(--tfh-blue, var(--tte-tv-blue, #0a84ff));
  --tf-text: var(--tfh-ink, #111827);
  --tf-muted: var(--tfh-muted, #8a8f98);
  --tf-line: var(--tfh-border, #e5e7eb);
  --tf-bg: var(--tfh-soft, #f4f5f7);
  --tf-radius: var(--tfh-radius, 22px);

  min-height: 100dvh;
  background: var(--tf-bg);
  color: var(--tf-text);
  font-family: "Noto Sans Thai", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

/* Fixed Header */
.tf-ltu-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 9999;
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--tf-line);
}

.admin-bar .tf-ltu-header {
  top: 32px;
}

.tf-ltu-header-top {
  height: 72px;
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 22px;
  display: flex;
  align-items: center;
  gap: 22px;
}

.tf-ltu-logo {
  flex: 0 0 auto;
  color: #050505;
  font-size: 28px;
  line-height: 1;
  font-weight: 900;
  letter-spacing: 0.5px;
  text-decoration: none;
  white-space: nowrap;
}

.tf-ltu-search {
  flex: 1;
  max-width: 520px;
  margin: 0 auto;
  position: relative;
}

.tf-ltu-search input {
  width: 100%;
  height: 42px;
  border: 0;
  outline: none;
  border-radius: 999px;
  background: #f2f3f5;
  padding: 0 48px 0 22px;
  font-size: 15px;
}

.tf-ltu-search button {
  position: absolute;
  right: 6px;
  top: 5px;
  width: 32px;
  height: 32px;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: #60646c;
  cursor: pointer;
}

.tf-ltu-actions {
  display: flex;
  align-items: center;
  gap: 14px;
}

.tf-ltu-actions a {
  width: 38px;
  height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #111827;
  text-decoration: none;
  font-size: 22px;
  border-radius: 999px;
}

.tf-ltu-actions a:hover {
  background: #f3f4f6;
}

.tf-ltu-tabs {
  height: 52px;
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 22px;
  display: flex;
  align-items: center;
  gap: 30px;
  overflow-x: auto;
  overflow-y: hidden;
  white-space: nowrap;
  scrollbar-width: none;
}

.tf-ltu-tabs::-webkit-scrollbar {
  display: none;
}

.tf-ltu-tabs a {
  position: relative;
  color: #9ca3af;
  text-decoration: none;
  font-size: 18px;
  font-weight: 700;
  padding: 15px 0;
}

.tf-ltu-tabs a::after {
  content: "";
  position: absolute;
  top: 10px;
  right: -10px;
  width: 8px;
  height: 8px;
  background: #22c55e;
  border-radius: 999px;
}

.tf-ltu-tabs a.is-active {
  color: #111827;
  font-weight: 900;
}

.tf-ltu-tabs a.is-active::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 3px;
  background: #111827;
  border-radius: 999px;
}

.tf-ltu-more {
  flex: 0 0 auto;
  width: 34px;
  height: 34px;
  border: 0;
  border-left: 1px solid #eceff3;
  background: #fff;
  color: #111827;
  font-size: 20px;
  cursor: pointer;
}

/* Scroll Content */
.tf-ltu-main {
  min-height: 100dvh;
  padding: 148px 20px 98px;
}

.admin-bar .tf-ltu-main {
  padding-top: 180px;
}

/* Sections */
.tf-ltu-section {
  max-width: 1180px;
  margin: 0 auto 34px;
  background: #fff;
  border-radius: var(--tf-radius);
  overflow: hidden;
  box-shadow: 0 14px 38px rgba(15, 23, 42, 0.07);
}

.tf-ltu-section-head {
  position: relative;
  min-height: 104px;
  padding: 24px 28px 18px;
  color: #fff;
}

.tf-ltu-section-head > a:first-child {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #fff;
  text-decoration: none;
  font-size: 28px;
  font-weight: 900;
  line-height: 1.2;
}

.tf-ltu-section-head p {
  margin: 7px 0 0;
  color: rgba(255, 255, 255, 0.88);
  font-size: 16px;
  line-height: 1.45;
}

.tf-ltu-see-all {
  position: absolute;
  top: 26px;
  right: 28px;
  border: 1px solid rgba(255, 255, 255, 0.35);
  padding: 8px 14px;
  border-radius: 8px;
  color: #fff;
  text-decoration: none;
  font-weight: 700;
  font-size: 14px;
}

.tf-ltu-theme-purple .tf-ltu-section-head {
  background: #37347d;
}

.tf-ltu-theme-gold .tf-ltu-section-head {
  background: #aa8f68;
}

.tf-ltu-theme-yellow .tf-ltu-section-head {
  background: #ffe928;
  color: #111827;
}

.tf-ltu-theme-yellow .tf-ltu-section-head > a:first-child,
.tf-ltu-theme-yellow .tf-ltu-section-head p,
.tf-ltu-theme-yellow .tf-ltu-see-all {
  color: #111827;
}

.tf-ltu-theme-yellow .tf-ltu-see-all {
  border-color: rgba(17, 24, 39, 0.2);
}


.tf-ltu-theme-blue .tf-ltu-section-head {
  background: #0d66d0;
}

.tf-ltu-theme-red .tf-ltu-section-head {
  background: linear-gradient(135deg, #e11d48 0%, #f97316 100%);
}

/* Grid cards */
.tf-ltu-grid {
  padding: 26px 28px 30px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 24px;
}

.tf-ltu-card {
  min-width: 0;
}

.tf-ltu-card a {
  color: inherit;
  text-decoration: none;
  display: block;
}

.tf-ltu-card img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  display: block;
  background: #edf0f3;
  border-radius: 13px;
}

.tf-ltu-card h3 {
  margin: 12px 0 6px;
  font-size: 18px;
  line-height: 1.45;
  font-weight: 800;
  letter-spacing: -0.01em;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.tf-ltu-card p {
  margin: 0;
  color: var(--tf-muted);
  font-size: 14px;
}

/* Feature section */
.tf-ltu-feature {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  min-height: 320px;
}

.tf-ltu-feature-img {
  display: block;
  min-width: 0;
}

.tf-ltu-feature-img img {
  width: 100%;
  height: 100%;
  min-height: 320px;
  object-fit: cover;
  display: block;
  background: #edf0f3;
}

.tf-ltu-feature-body {
  padding: 46px 40px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.tf-ltu-feature-body h2 {
  margin: 0 0 18px;
  font-size: 28px;
  line-height: 1.45;
  font-weight: 900;
  letter-spacing: -0.02em;
}

.tf-ltu-feature-body h2 a {
  color: inherit;
  text-decoration: none;
}

.tf-ltu-feature-body p {
  margin: 0 0 26px;
  color: var(--tf-muted);
  font-size: 15px;
}

.tf-ltu-read-more {
  color: #111827;
  text-decoration: none;
  font-weight: 800;
}

/* Fixed Mobile Footer */
.tf-ltu-footer {
  position: fixed;
  inset: auto 0 0 0;
  z-index: 9999;
  min-height: 78px;
  padding-bottom: env(safe-area-inset-bottom);
  background: rgba(255, 255, 255, 0.97);
  backdrop-filter: blur(18px);
  border-top: 1px solid var(--tf-line);
  display: flex;
  align-items: center;
  justify-content: space-around;
}

.tf-ltu-footer a {
  flex: 1;
  height: 68px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 5px;
  color: #8a8f98;
  text-decoration: none;
}

.tf-ltu-footer span {
  font-size: 23px;
  line-height: 1;
}

.tf-ltu-footer small {
  font-size: 12px;
  line-height: 1;
}

.tf-ltu-footer a.is-active {
  color: var(--tf-blue);
}

/* Desktop footer smaller */
@media (min-width: 1025px) {
  .tf-ltu-footer {
    max-width: 1180px;
    left: 50%;
    right: auto;
    transform: translateX(-50%);
    border-left: 1px solid var(--tf-line);
    border-right: 1px solid var(--tf-line);
    border-radius: 18px 18px 0 0;
  }
}

/* Tablet */
@media (max-width: 1024px) {
  .tf-ltu-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .tf-ltu-section {
    border-radius: 18px;
  }

  .tf-ltu-feature {
    grid-template-columns: 1fr 1fr;
  }
}

/* Mobile: LINE TODAY feeling */
@media (max-width: 768px) {
  .tf-ltu-app {
    background: #fff;
  }

  .tf-ltu-header-top {
    height: 74px;
    padding: 0 18px;
    gap: 12px;
  }

  .tf-ltu-logo {
    font-size: 27px;
    letter-spacing: 0.5px;
  }

  .tf-ltu-search {
    display: none;
  }

  .tf-ltu-actions {
    margin-left: auto;
    gap: 9px;
  }

  .tf-ltu-actions a {
    width: 34px;
    height: 34px;
    color: var(--tf-blue);
    font-size: 22px;
  }

  .tf-ltu-tabs {
    height: 52px;
    padding: 0 18px;
    gap: 28px;
    border-top: 1px solid #f1f2f4;
  }

  .tf-ltu-tabs a {
    font-size: 19px;
  }

  .tf-ltu-main {
    padding: 146px 0 calc(92px + env(safe-area-inset-bottom));
  }

  .admin-bar .tf-ltu-header {
    top: 46px;
  }

  .admin-bar .tf-ltu-main {
    padding-top: 192px;
  }

  .tf-ltu-section {
    margin: 0 16px 22px;
    border-radius: 6px;
    box-shadow: none;
    border: 1px solid #f1f2f4;
  }

  .tf-ltu-section-head {
    min-height: 112px;
    padding: 22px 20px 16px;
  }

  .tf-ltu-section-head > a:first-child {
    font-size: 26px;
  }

  .tf-ltu-section-head p {
    font-size: 16px;
  }

  .tf-ltu-see-all {
    top: 22px;
    right: 18px;
    padding: 7px 10px;
    font-size: 12px;
  }

  .tf-ltu-grid {
    padding: 22px 20px 26px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 26px 20px;
  }

  .tf-ltu-card img {
    border-radius: 5px;
  }

  .tf-ltu-card h3 {
    margin-top: 11px;
    font-size: 19px;
    line-height: 1.5;
    -webkit-line-clamp: 3;
  }

  .tf-ltu-card p {
    font-size: 15px;
  }

  .tf-ltu-feature {
    display: block;
  }

  .tf-ltu-feature-img img {
    min-height: auto;
    aspect-ratio: 16 / 9;
  }

  .tf-ltu-feature-body {
    padding: 22px 20px 26px;
  }

  .tf-ltu-feature-body h2 {
    font-size: 23px;
    line-height: 1.45;
  }
}

/* Small mobile */
@media (max-width: 390px) {
  .tf-ltu-logo {
    font-size: 23px;
  }

  .tf-ltu-actions {
    gap: 4px;
  }

  .tf-ltu-tabs a {
    font-size: 17px;
  }

  .tf-ltu-grid {
    gap: 22px 15px;
  }

  .tf-ltu-card h3 {
    font-size: 17px;
  }
}


/* v0.1.2 - Strong app-like layout override */
body.tf-ltu-fullscreen,
body.tf-ltu-fullscreen html {
  width: 100% !important;
  height: 100% !important;
}

body.tf-ltu-fullscreen .tf-ltu-app {
  font-family: "Noto Sans Thai", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  background: #f4f5f7 !important;
}

body.tf-ltu-fullscreen .tf-ltu-header {
  width: 100vw !important;
}

body.tf-ltu-fullscreen .tf-ltu-header-top,
body.tf-ltu-fullscreen .tf-ltu-tabs {
  width: min(1180px, calc(100vw - 64px)) !important;
  max-width: none !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

body.tf-ltu-fullscreen .tf-ltu-main {
  position: absolute !important;
  inset: 125px 0 78px 0 !important;
  min-height: 0 !important;
  height: auto !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding: 26px 0 42px !important;
  -webkit-overflow-scrolling: touch;
}

body.admin-bar.tf-ltu-fullscreen .tf-ltu-main {
  inset-top: 125px !important;
}

body.tf-ltu-fullscreen .tf-ltu-section {
  width: min(1180px, calc(100vw - 64px)) !important;
  max-width: none !important;
  margin: 0 auto 34px !important;
}

body.tf-ltu-fullscreen .tf-ltu-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 24px !important;
}

body.tf-ltu-fullscreen .tf-ltu-card img {
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 16 / 9 !important;
  object-fit: cover !important;
}

body.tf-ltu-fullscreen .tf-ltu-footer {
  width: 100vw !important;
  max-width: none !important;
  left: 0 !important;
  right: 0 !important;
  transform: none !important;
  border-radius: 0 !important;
}

/* Make desktop feel like the mockup: wide top sections and readable cards */
@media (min-width: 1025px) {
  body.tf-ltu-fullscreen .tf-ltu-main {
    inset: 125px 0 78px 0 !important;
    padding-top: 28px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-section-head {
    min-height: 104px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-card h3 {
    font-size: 18px !important;
    min-height: 52px;
  }
}

/* Tablet */
@media (max-width: 1024px) {
  body.tf-ltu-fullscreen .tf-ltu-header-top,
  body.tf-ltu-fullscreen .tf-ltu-tabs,
  body.tf-ltu-fullscreen .tf-ltu-section {
    width: calc(100vw - 36px) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

/* Mobile: closer to LINE TODAY screenshot */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-app {
    background: #fff !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-header-top,
  body.tf-ltu-fullscreen .tf-ltu-tabs {
    width: 100% !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-main {
    inset: 126px 0 calc(78px + env(safe-area-inset-bottom)) 0 !important;
    padding: 22px 0 24px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-section {
    width: calc(100vw - 32px) !important;
    margin-bottom: 22px !important;
    border-radius: 6px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 26px 20px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-footer {
    min-height: 78px !important;
  }
}

@media (max-width: 390px) {
  body.tf-ltu-fullscreen .tf-ltu-section {
    width: calc(100vw - 24px) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-grid {
    gap: 22px 14px !important;
  }
}


/* v0.1.3 tweaks */
body.tf-ltu-fullscreen .tf-ltu-actions {
  gap: 18px !important;
}

body.tf-ltu-fullscreen .tf-ltu-actions a {
  font-size: 21px !important;
}

@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-actions {
    gap: 10px !important;
  }
}


/* v0.1.5 - Mobile overflow hard fix */
html,
body,
body.tf-ltu-fullscreen,
body.tf-ltu-fullscreen .tf-ltu-app {
  max-width: 100% !important;
  overflow-x: hidden !important;
}

body.tf-ltu-fullscreen .tf-ltu-app,
body.tf-ltu-fullscreen .tf-ltu-header,
body.tf-ltu-fullscreen .tf-ltu-footer {
  width: 100% !important;
  max-width: 100% !important;
}

body.tf-ltu-fullscreen .tf-ltu-main {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

body.tf-ltu-fullscreen .tf-ltu-section,
body.tf-ltu-fullscreen .tf-ltu-section *,
body.tf-ltu-fullscreen .tf-ltu-card,
body.tf-ltu-fullscreen .tf-ltu-card a,
body.tf-ltu-fullscreen .tf-ltu-feature,
body.tf-ltu-fullscreen .tf-ltu-feature * {
  min-width: 0 !important;
  box-sizing: border-box !important;
}

body.tf-ltu-fullscreen img {
  max-width: 100% !important;
}

/* Mobile only: remove 100vw overflow and make header fit */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-app {
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    height: 100dvh !important;
    overflow: hidden !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-header,
  body.tf-ltu-fullscreen .tf-ltu-footer {
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-header-top {
    width: 100% !important;
    max-width: 100% !important;
    height: 68px !important;
    padding: 0 12px !important;
    gap: 8px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-logo {
    flex: 1 1 auto !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    font-size: clamp(18px, 5.2vw, 24px) !important;
    letter-spacing: 0.4px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-actions {
    flex: 0 0 auto !important;
    gap: 6px !important;
    margin-left: 4px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-actions a {
    width: 28px !important;
    height: 28px !important;
    font-size: 17px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-tabs {
    width: 100% !important;
    max-width: 100% !important;
    height: 48px !important;
    padding: 0 12px !important;
    gap: 22px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-tabs a {
    font-size: 16px !important;
    flex: 0 0 auto !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-more {
    width: 28px !important;
    min-width: 28px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-main {
    inset: 116px 0 calc(72px + env(safe-area-inset-bottom)) 0 !important;
    padding: 12px 0 18px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-section {
    width: calc(100% - 24px) !important;
    max-width: calc(100% - 24px) !important;
    margin-left: 12px !important;
    margin-right: 12px !important;
    margin-bottom: 18px !important;
    overflow: hidden !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-section-head {
    min-height: 92px !important;
    padding: 16px 14px 13px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-section-head > a:first-child {
    max-width: calc(100% - 74px) !important;
    font-size: clamp(20px, 5.2vw, 24px) !important;
    line-height: 1.2 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-section-head p {
    max-width: 100% !important;
    font-size: 13px !important;
    line-height: 1.35 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-see-all {
    top: 16px !important;
    right: 12px !important;
    padding: 5px 8px !important;
    font-size: 11px !important;
    max-width: 64px !important;
    white-space: nowrap !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-grid {
    width: 100% !important;
    max-width: 100% !important;
    padding: 14px 12px 18px !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 18px 12px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-card img {
    border-radius: 6px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-card h3 {
    font-size: 14px !important;
    line-height: 1.38 !important;
    margin: 8px 0 4px !important;
    min-height: auto !important;
    -webkit-line-clamp: 2 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-card p {
    font-size: 12px !important;
    line-height: 1.3 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-feature-body {
    padding: 16px 14px 18px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-feature-body h2 {
    font-size: 18px !important;
    line-height: 1.42 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-footer {
    min-height: 72px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-footer a {
    height: 62px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-footer span {
    font-size: 20px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-footer small {
    font-size: 11px !important;
  }
}

/* Very small devices */
@media (max-width: 390px) {
  body.tf-ltu-fullscreen .tf-ltu-header-top {
    padding: 0 10px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-logo {
    font-size: clamp(16px, 5vw, 21px) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-actions a {
    width: 24px !important;
    font-size: 15px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-tabs {
    padding: 0 10px !important;
    gap: 18px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-tabs a {
    font-size: 15px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-section {
    width: calc(100% - 20px) !important;
    max-width: calc(100% - 20px) !important;
    margin-left: 10px !important;
    margin-right: 10px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-grid {
    gap: 16px 10px !important;
    padding-left: 10px !important;
    padding-right: 10px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-card h3 {
    font-size: 13px !important;
  }
}


/* v0.1.6 - Desktop: no fixed footer, more usable height */
@media (min-width: 769px) {
  body.tf-ltu-fullscreen .tf-ltu-footer {
    display: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-main {
    inset: 125px 0 0 0 !important;
    padding-bottom: 48px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-section:last-child {
    margin-bottom: 48px !important;
  }
}

/* Mobile keeps fixed bottom app footer */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-footer {
    display: flex !important;
  }
}


/* v0.1.7 - use ThaiFly project design tokens */
body.tf-ltu-fullscreen .tf-ltu-app {
  --tf-blue: var(--tfh-blue, var(--tte-tv-blue, #0A8CFF));
  --tf-text: var(--tfh-ink, #061B33);
  --tf-muted: var(--tfh-muted, #64748B);
  --tf-line: var(--tfh-border, #D9EBFA);
  --tf-bg: var(--tfh-soft, #F4FAFF);
  --tf-card-shadow: var(--tfh-shadow, 0 18px 48px rgba(8,88,160,.12));
  font-family: var(--tfh-font, var(--tte-font-thai, "Noto Sans Thai", -apple-system, BlinkMacSystemFont, "Segoe UI", Tahoma, sans-serif)) !important;
  background: var(--tf-bg) !important;
}

body.tf-ltu-fullscreen .tf-ltu-header {
  border-bottom-color: rgba(181,221,250,.72) !important;
  box-shadow: 0 10px 30px rgba(6,27,51,.05) !important;
}

body.tf-ltu-fullscreen .tf-ltu-search input {
  background: #F1F7FC !important;
  color: var(--tf-text) !important;
}

body.tf-ltu-fullscreen .tf-ltu-section {
  box-shadow: var(--tf-card-shadow) !important;
  border: 1px solid rgba(217,235,250,.88) !important;
}

body.tf-ltu-fullscreen .tf-ltu-card img {
  background: #EAF3FB !important;
}

body.tf-ltu-fullscreen .tf-ltu-card h3 {
  color: #132B42 !important;
}

body.tf-ltu-fullscreen .tf-ltu-card p {
  color: var(--tf-muted) !important;
}

/* Desktop/tablet: footer stays hidden */
@media (min-width: 769px) {
  body.tf-ltu-fullscreen .tf-ltu-footer {
    display: none !important;
  }
}

/* Mobile: footer remains app-like */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-footer {
    display: flex !important;
  }
}


/* v0.1.8 - real ThaiFly data/menu/card adapter */
.tf-ltu-tab-item {
  position: relative;
  display: inline-flex;
  align-items: center;
  height: 100%;
  flex: 0 0 auto;
}

.tf-ltu-tab-item > a {
  position: relative;
  color: #9ca3af;
  text-decoration: none;
  font-size: 18px;
  font-weight: 700;
  padding: 15px 0;
}

.tf-ltu-tab-item > a::after {
  content: "";
  position: absolute;
  top: 10px;
  right: -10px;
  width: 8px;
  height: 8px;
  background: #22c55e;
  border-radius: 999px;
}

.tf-ltu-tab-item > a.is-active {
  color: #111827;
  font-weight: 900;
}

.tf-ltu-tab-item > a.is-active::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 3px;
  background: #111827;
  border-radius: 999px;
}

.tf-ltu-mega-panel {
  position: fixed;
  top: 124px;
  left: 50%;
  z-index: 10010;
  width: min(920px, calc(100vw - 48px));
  transform: translateX(-50%) translateY(10px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: .16s ease;
}

.tf-ltu-tab-item:hover .tf-ltu-mega-panel,
.tf-ltu-tab-item:focus-within .tf-ltu-mega-panel {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

.tf-ltu-mega-panel-inner {
  background: rgba(255,255,255,.98);
  border: 1px solid rgba(217,235,250,.95);
  border-radius: 22px;
  box-shadow: 0 24px 70px rgba(6,27,51,.18);
  padding: 20px;
}

.tf-ltu-mega-title {
  font-weight: 900;
  color: var(--tf-text, #111827);
  margin-bottom: 14px;
  font-size: 18px;
}

.tf-ltu-mega-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.tf-ltu-mega-link {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 10px 12px;
  color: #132B42;
  text-decoration: none;
  border-radius: 14px;
  background: #f7fbff;
  border: 1px solid rgba(217,235,250,.75);
  min-width: 0;
}

.tf-ltu-mega-link:hover {
  background: #eef7ff;
  color: var(--tf-blue, #0a84ff);
}

.tf-ltu-mega-link span {
  width: 24px;
  flex: 0 0 auto;
  text-align: center;
}

.tf-ltu-mega-link strong {
  display: block;
  min-width: 0;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  font-size: 14px;
}

.tf-ltu-card-img-wrap {
  display: block;
  position: relative;
  overflow: hidden;
  border-radius: 13px;
  background: #edf0f3;
}

.tf-ltu-card-img-wrap img {
  border-radius: 0 !important;
}

.tf-ltu-card-img-wrap em {
  position: absolute;
  left: 10px;
  top: 10px;
  z-index: 2;
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(225,29,72,.95);
  color: #fff;
  font-size: 11px;
  font-style: normal;
  font-weight: 800;
}

.tf-ltu-tour-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin: 6px 0 6px;
}

.tf-ltu-tour-meta span {
  display: inline-flex;
  align-items: center;
  min-width: 0;
  max-width: 100%;
  padding: 3px 7px;
  border-radius: 999px;
  background: #f1f7fc;
  color: #64748b;
  font-size: 11px;
  line-height: 1.25;
}

.tf-ltu-tour-card p {
  color: #0a84ff !important;
  font-weight: 800;
}

@media (max-width: 768px) {
  .tf-ltu-mega-panel {
    display: none !important;
  }

  .tf-ltu-tab-item > a {
    font-size: 16px !important;
    flex: 0 0 auto !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-tour-meta {
    gap: 4px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-tour-meta span {
    font-size: 10px !important;
    padding: 2px 5px !important;
  }
}

@media (max-width: 1024px) and (min-width: 769px) {
  .tf-ltu-mega-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}


/* v0.1.9 - Desktop footer like ThaiFly mockup, mobile keeps fixed nav */
.tf-ltu-desktop-footer {
  display: none;
}

@media (min-width: 769px) {
  body.tf-ltu-fullscreen .tf-ltu-app {
    overflow: hidden !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-main {
    inset: 125px 0 0 0 !important;
    padding-bottom: 0 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-footer-mobile,
  body.tf-ltu-fullscreen .tf-ltu-footer {
    display: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-desktop-footer {
    display: block !important;
    width: 100% !important;
    margin: 72px 0 0 !important;
    color: #fff !important;
    font-family: var(--tfh-font, "Noto Sans Thai", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif) !important;
  }

  .tf-ltu-footer-cta {
    width: min(1280px, calc(100% - 80px));
    margin: 0 auto 64px;
    min-height: 150px;
    padding: 34px 44px;
    border-radius: 28px;
    background: linear-gradient(115deg, #0877f2 0%, #09aeea 52%, #31d07d 100%);
    box-shadow: 0 28px 70px rgba(11, 104, 202, .22);
    display: grid;
    grid-template-columns: 88px minmax(0, 1fr) auto;
    align-items: center;
    gap: 28px;
  }

  .tf-ltu-line-badge {
    width: 72px;
    height: 72px;
    border-radius: 22px;
    background: #fff;
    color: #22c55e;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 900;
    font-size: 19px;
    letter-spacing: .5px;
  }

  .tf-ltu-footer-cta-text h2 {
    margin: 0 0 8px !important;
    color: #fff !important;
    font-size: clamp(26px, 2.15vw, 38px) !important;
    line-height: 1.22 !important;
    font-weight: 900 !important;
    letter-spacing: -.02em !important;
  }

  .tf-ltu-footer-cta-text p {
    margin: 0 !important;
    color: rgba(255,255,255,.88) !important;
    font-size: clamp(16px, 1.2vw, 21px) !important;
    line-height: 1.65 !important;
    font-weight: 600 !important;
  }

  .tf-ltu-footer-cta-btn {
    min-width: 220px;
    height: 58px;
    padding: 0 28px;
    border-radius: 18px;
    background: #fff;
    color: #0f73d4 !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    text-decoration: none !important;
    font-size: 20px;
    font-weight: 900;
    white-space: nowrap;
    box-shadow: 0 16px 30px rgba(0,0,0,.08);
  }

  .tf-ltu-footer-cta-btn span {
    font-size: 26px;
    line-height: 1;
  }

  .tf-ltu-trust-row {
    width: 100%;
    padding: 30px max(40px, calc((100% - 1280px) / 2)) 32px;
    background: #eef8ff;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
  }

  .tf-ltu-trust-card {
    min-height: 90px;
    padding: 22px 24px;
    border-radius: 18px;
    background: #fff;
    border: 1px solid #dceefa;
    box-shadow: 0 14px 34px rgba(8, 88, 160, .06);
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    column-gap: 16px;
    align-items: center;
  }

  .tf-ltu-trust-card span {
    grid-row: 1 / span 2;
    width: 42px;
    height: 42px;
    border-radius: 16px;
    background: #edf8ff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .tf-ltu-trust-card strong {
    color: #0f2238;
    font-size: 15px;
    line-height: 1.35;
    font-weight: 900;
  }

  .tf-ltu-trust-card p {
    margin: 5px 0 0 !important;
    color: #61738a !important;
    font-size: 15px;
    line-height: 1.5;
    font-weight: 600;
  }

  .tf-ltu-footer-main {
    width: 100%;
    padding: 46px max(40px, calc((100% - 1280px) / 2)) 34px;
    background: linear-gradient(180deg, #0858d6 0%, #0042a7 100%);
    display: grid;
    grid-template-columns: 1.5fr .75fr .85fr 1fr;
    gap: 54px;
  }

  .tf-ltu-footer-brand p,
  .tf-ltu-footer-col p {
    color: rgba(255,255,255,.70) !important;
    font-size: 18px !important;
    line-height: 1.8 !important;
    margin: 22px 0 0 !important;
    font-weight: 400 !important;
  }

  .tf-ltu-footer-logo {
    display: flex;
    align-items: center;
    gap: 14px;
  }

  .tf-ltu-footer-logo span {
    width: 48px;
    height: 48px;
    border-radius: 18px;
    background: #16a5ff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 900;
    font-size: 18px;
  }

  .tf-ltu-footer-logo strong {
    display: block;
    color: #fff;
    font-size: 28px;
    line-height: 1;
    font-weight: 900;
    letter-spacing: .02em;
  }

  .tf-ltu-footer-logo small {
    display: block;
    margin-top: 10px;
    color: rgba(255,255,255,.68);
    font-size: 13px;
    letter-spacing: .2em;
    font-weight: 800;
  }

  .tf-ltu-footer-col h3 {
    margin: 0 0 22px !important;
    color: #fff !important;
    font-size: 23px !important;
    line-height: 1.25 !important;
    font-weight: 900 !important;
  }

  .tf-ltu-footer-col a {
    display: block;
    width: fit-content;
    color: #fff !important;
    text-decoration: none !important;
    font-size: 20px;
    line-height: 1.4;
    font-weight: 900;
    margin: 0 0 15px;
  }

  .tf-ltu-footer-col a:hover {
    opacity: .82;
  }

  .tf-ltu-footer-bottom {
    width: 100%;
    padding: 18px max(40px, calc((100% - 1280px) / 2)) 24px;
    background: #0042a7;
    color: rgba(255,255,255,.85);
    border-top: 1px solid rgba(255,255,255,.18);
    text-align: center;
    font-size: 14px;
    font-weight: 800;
  }

  body.tf-ltu-fullscreen .tf-ltu-section:last-of-type {
    margin-bottom: 0 !important;
  }
}

@media (max-width: 1180px) and (min-width: 769px) {
  .tf-ltu-footer-cta {
    width: calc(100% - 48px);
    grid-template-columns: 76px minmax(0, 1fr);
  }

  .tf-ltu-footer-cta-btn {
    grid-column: 2;
    width: fit-content;
  }

  .tf-ltu-trust-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    padding-left: 24px;
    padding-right: 24px;
  }

  .tf-ltu-footer-main {
    grid-template-columns: 1fr 1fr;
    padding-left: 24px;
    padding-right: 24px;
  }
}

@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-desktop-footer {
    display: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-footer-mobile,
  body.tf-ltu-fullscreen .tf-ltu-footer {
    display: flex !important;
  }
}


/* v0.2.0 - Safe footer flow fix
   Desktop footer must live inside the scroll content flow.
   Do not layer it behind cards/sections.
*/
@media (min-width: 769px) {
  body.tf-ltu-fullscreen .tf-ltu-main {
    z-index: 1 !important;
    background: var(--tf-bg, #f4f5f7) !important;
    padding-bottom: 0 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-desktop-footer {
    position: relative !important;
    z-index: 0 !important;
    clear: both !important;
    margin: 72px 0 0 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-section {
    position: relative !important;
    z-index: 2 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-footer-cta,
  body.tf-ltu-fullscreen .tf-ltu-trust-row,
  body.tf-ltu-fullscreen .tf-ltu-footer-main,
  body.tf-ltu-fullscreen .tf-ltu-footer-bottom {
    position: relative !important;
    z-index: 1 !important;
  }
}

/* Mobile keeps only the app bottom navigation */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-desktop-footer {
    display: none !important;
  }
}


/* v0.2.1 - exact existing mega menu structure + remove green dots */
body.tf-ltu-fullscreen .tf-ltu-tabs a::after,
body.tf-ltu-fullscreen .tf-ltu-tab-item > a::after,
body.tf-ltu-fullscreen .tte-mega-trigger::after,
body.tf-ltu-fullscreen .tte-header-link::after {
  display: none !important;
  content: none !important;
}

body.tf-ltu-fullscreen .tf-ltu-header-real-mega {
  overflow: visible !important;
  z-index: 1000000 !important;
}

body.tf-ltu-fullscreen .tf-ltu-real-mega-nav {
  height: 54px !important;
  overflow: visible !important;
  background: rgba(255,255,255,.98) !important;
  border-top: 1px solid rgba(226,232,240,.72) !important;
  border-bottom: 1px solid rgba(226,232,240,.9) !important;
  box-shadow: 0 10px 30px rgba(6,27,51,.04) !important;
}

body.tf-ltu-fullscreen .tf-ltu-real-mega-row {
  width: min(1180px, calc(100vw - 64px)) !important;
  max-width: none !important;
  height: 54px !important;
  min-height: 54px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 46px !important;
  overflow: visible !important;
}

body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-item {
  position: static !important;
  height: 54px !important;
  display: flex !important;
  align-items: center !important;
  flex: 0 0 auto !important;
}

body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-trigger,
body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-header-link {
  height: 54px !important;
  display: inline-flex !important;
  align-items: center !important;
  position: relative !important;
  padding: 0 !important;
  color: #0f2238 !important;
  text-decoration: none !important;
  font-size: 18px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  border: 0 !important;
}

body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-trigger.is-active,
body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-header-link.is-active,
body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-trigger:hover,
body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-header-link:hover {
  color: #0798e8 !important;
}

body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-trigger.is-active::before,
body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-header-link.is-active::before,
body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-item:hover > .tte-mega-trigger::before,
body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-item:hover > .tte-header-link::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  bottom: -1px !important;
  height: 4px !important;
  border-radius: 999px 999px 0 0 !important;
  background: #10c8e8 !important;
}

/* make existing mega panels sit exactly under this app header */
body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-panel {
  position: absolute !important;
  top: 54px !important;
  left: 50% !important;
  right: auto !important;
  z-index: 1000001 !important;
  transform: translateX(-50%) translateY(10px) !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  transition: opacity .18s ease, transform .18s ease, visibility .18s ease !important;
}

body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-item:hover > .tte-mega-panel,
body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-item:focus-within > .tte-mega-panel {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: translateX(-50%) translateY(0) !important;
}

body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-panel-country {
  width: min(1040px, calc(100vw - 64px)) !important;
}

body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-panel-city {
  width: min(760px, calc(100vw - 64px)) !important;
}

body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-country-mega-wrap,
body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-city-mega-wrap {
  background: rgba(255,255,255,.985) !important;
  border: 1px solid #e5eaf2 !important;
  box-shadow: 0 26px 70px rgba(15,23,42,.16) !important;
  backdrop-filter: blur(18px) !important;
  border-radius: 24px !important;
  overflow: hidden !important;
}

body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-country-mega-wrap {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 0 !important;
}

body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-city-mega-wrap {
  display: block !important;
}

body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-country-col,
body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-city-col-main {
  padding: 24px 30px 26px !important;
}

body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-country-col + .tte-country-col {
  border-left: 1px solid #e5eaf2 !important;
}

body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-country-col h3,
body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-city-col-main h3 {
  margin: 0 0 18px !important;
  padding-bottom: 12px !important;
  border-bottom: 1px solid #e5eaf2 !important;
  color: #071116 !important;
  font-size: 20px !important;
  font-weight: 900 !important;
  line-height: 1.25 !important;
}

body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-country-list {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 9px 14px !important;
}

body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-country-menu-link {
  min-height: 38px !important;
  padding: 7px 9px !important;
  display: flex !important;
  align-items: center !important;
  gap: 9px !important;
  border-radius: 12px !important;
  color: #0f2238 !important;
  text-decoration: none !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  line-height: 1.25 !important;
  white-space: nowrap !important;
  min-width: 0 !important;
}

body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-country-menu-link:hover {
  background: #f4fbfb !important;
  color: #007f7a !important;
}

body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-country-flag {
  width: 22px !important;
  height: 22px !important;
  flex: 0 0 22px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 16px !important;
}

body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-city-menu-icon {
  width: 26px !important;
  height: 26px !important;
  flex-basis: 26px !important;
  border-radius: 999px !important;
  background: #f7fbfd !important;
  border: 1px solid rgba(10,186,181,.18) !important;
  box-shadow: 0 6px 18px rgba(15,23,42,.05) !important;
  color: inherit !important;
}

/* Mobile: keep horizontal nav, no desktop mega panel */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-real-mega-nav {
    height: 48px !important;
    overflow: hidden !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-real-mega-row {
    width: 100% !important;
    height: 48px !important;
    min-height: 48px !important;
    padding: 0 12px !important;
    gap: 24px !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    scrollbar-width: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-real-mega-row::-webkit-scrollbar {
    display: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-item {
    height: 48px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-trigger,
  body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-header-link {
    height: 48px !important;
    font-size: 16px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-panel {
    display: none !important;
  }
}


/* v0.2.2 - bring mobile menu back in LINE TODAY style */
.tf-ltu-mobile-tabs {
  display: none;
}

@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-real-mega-nav {
    display: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-mobile-tabs {
    display: block !important;
    width: 100% !important;
    height: 52px !important;
    border-top: 1px solid #f1f2f4 !important;
    border-bottom: 1px solid #e9edf2 !important;
    background: rgba(255,255,255,.98) !important;
    overflow: hidden !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-mobile-tabs-scroll {
    width: 100% !important;
    height: 52px !important;
    padding: 0 12px !important;
    display: flex !important;
    align-items: center !important;
    gap: 26px !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    white-space: nowrap !important;
    scrollbar-width: none !important;
    -webkit-overflow-scrolling: touch !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-mobile-tabs-scroll::-webkit-scrollbar {
    display: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-mobile-tabs-scroll a,
  body.tf-ltu-fullscreen .tf-ltu-mobile-more {
    position: relative !important;
    flex: 0 0 auto !important;
    height: 52px !important;
    display: inline-flex !important;
    align-items: center !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    color: #9ca3af !important;
    text-decoration: none !important;
    font-size: 17px !important;
    line-height: 1 !important;
    font-weight: 800 !important;
    white-space: nowrap !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-mobile-tabs-scroll a.is-active {
    color: #111827 !important;
    font-weight: 900 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-mobile-tabs-scroll a.is-active::before {
    content: "" !important;
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    height: 3px !important;
    background: #111827 !important;
    border-radius: 999px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-mobile-more {
    font-size: 20px !important;
    color: #111827 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-main {
    inset: 116px 0 calc(72px + env(safe-area-inset-bottom)) 0 !important;
  }
}

/* Desktop keeps mega nav only */
@media (min-width: 769px) {
  body.tf-ltu-fullscreen .tf-ltu-mobile-tabs {
    display: none !important;
  }
}


/* v0.2.3 - ThaiFly logo */
body.tf-ltu-fullscreen .tf-ltu-logo-brand {
  display: inline-flex !important;
  align-items: center !important;
  gap: 14px !important;
  color: #101c2d !important;
  text-decoration: none !important;
  min-width: 0 !important;
}

body.tf-ltu-fullscreen .tf-ltu-logo-mark {
  width: 52px !important;
  height: 52px !important;
  flex: 0 0 52px !important;
  border-radius: 16px !important;
  background: linear-gradient(135deg, #0877f2 0%, #16a5ff 100%) !important;
  color: #fff !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 20px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  letter-spacing: .02em !important;
  box-shadow: 0 14px 26px rgba(8,119,242,.18) !important;
}

body.tf-ltu-fullscreen .tf-ltu-logo-text {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  min-width: 0 !important;
}

body.tf-ltu-fullscreen .tf-ltu-logo-text strong {
  display: block !important;
  color: #111827 !important;
  font-size: 28px !important;
  line-height: .95 !important;
  font-weight: 900 !important;
  letter-spacing: .01em !important;
  white-space: nowrap !important;
}

body.tf-ltu-fullscreen .tf-ltu-logo-text small {
  display: block !important;
  margin-top: 8px !important;
  color: #667085 !important;
  font-size: 13px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  letter-spacing: .23em !important;
  white-space: nowrap !important;
}

/* keep old logo rules from shrinking the new logo incorrectly */
body.tf-ltu-fullscreen .tf-ltu-logo {
  font-size: 0 !important;
  letter-spacing: 0 !important;
}

@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-logo-brand {
    gap: 10px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-logo-mark {
    width: 42px !important;
    height: 42px !important;
    flex-basis: 42px !important;
    border-radius: 13px !important;
    font-size: 16px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-logo-text strong {
    font-size: 22px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-logo-text small {
    margin-top: 6px !important;
    font-size: 10px !important;
    letter-spacing: .22em !important;
  }
}

@media (max-width: 390px) {
  body.tf-ltu-fullscreen .tf-ltu-logo-brand {
    gap: 8px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-logo-mark {
    width: 38px !important;
    height: 38px !important;
    flex-basis: 38px !important;
    border-radius: 12px !important;
    font-size: 15px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-logo-text strong {
    font-size: 20px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-logo-text small {
    font-size: 9px !important;
  }
}


/* v0.2.4 - menu no default active state */
body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-trigger.is-active,
body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-header-link.is-active {
  color: #0f2238 !important;
}

body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-trigger.is-active::before,
body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-header-link.is-active::before {
  display: none !important;
  content: none !important;
}

body.tf-ltu-fullscreen .tf-ltu-mobile-tabs-scroll a.is-active {
  color: #9ca3af !important;
  font-weight: 800 !important;
}

body.tf-ltu-fullscreen .tf-ltu-mobile-tabs-scroll a.is-active::before {
  display: none !important;
  content: none !important;
}

/* keep hover underline on desktop only */
@media (min-width: 769px) {
  body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-item:hover > .tte-mega-trigger::before,
  body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-item:hover > .tte-header-link::before {
    display: block !important;
    content: "" !important;
  }
}


/* v0.2.5 - LINE TODAY style Hero Slide only */
.tf-ltu-hero-slider {
  width: min(1180px, calc(100vw - 64px));
  max-width: none;
  margin: 0 auto 34px;
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  background: #e8eef5;
  box-shadow: 0 18px 48px rgba(8,88,160,.10);
}

.tf-ltu-hero-track {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 7.4;
  min-height: 360px;
  overflow: hidden;
}

.tf-ltu-hero-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  visibility: hidden;
  transition: opacity .35s ease, visibility .35s ease;
}

.tf-ltu-hero-slide.is-active {
  opacity: 1;
  visibility: visible;
}

.tf-ltu-hero-link {
  display: block;
  width: 100%;
  height: 100%;
  color: inherit;
  text-decoration: none;
  position: relative;
}

.tf-ltu-hero-link img {
  width: 100% !important;
  height: 100% !important;
  display: block;
  object-fit: cover;
  background: #d7dee8;
}

.tf-ltu-hero-link::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 45%;
  background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.28) 100%);
  pointer-events: none;
}

.tf-ltu-hero-overlay {
  position: absolute;
  left: 42px;
  right: 42px;
  bottom: 34px;
  z-index: 2;
  max-width: 820px;
  padding: 22px 26px;
  border-radius: 18px;
  background: rgba(255,255,255,.96);
  box-shadow: 0 18px 45px rgba(15,23,42,.14);
  backdrop-filter: blur(14px);
}

.tf-ltu-hero-title-row {
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

.tf-ltu-hero-badge {
  flex: 0 0 auto;
  min-width: 42px;
  height: 34px;
  padding: 0 12px;
  border-radius: 8px;
  background: #6b7280;
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  line-height: 1;
  font-weight: 900;
}

.tf-ltu-hero-overlay h2 {
  margin: 0 !important;
  color: #111827 !important;
  font-size: clamp(26px, 2.7vw, 42px) !important;
  line-height: 1.25 !important;
  font-weight: 900 !important;
  letter-spacing: -.02em !important;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.tf-ltu-hero-overlay p {
  margin: 9px 0 0 !important;
  color: #6b7280 !important;
  font-size: 16px !important;
  line-height: 1.35 !important;
  font-weight: 700 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase;
}

.tf-ltu-hero-dots {
  position: absolute;
  left: 42px;
  right: 42px;
  bottom: 18px;
  z-index: 3;
  display: flex;
  gap: 7px;
  pointer-events: auto;
}

.tf-ltu-hero-dots button {
  width: 48px;
  height: 3px;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.55);
  cursor: pointer;
}

.tf-ltu-hero-dots button.is-active {
  background: #fff;
}

/* Tablet */
@media (max-width: 1024px) and (min-width: 769px) {
  .tf-ltu-hero-slider {
    width: calc(100vw - 36px);
  }

  .tf-ltu-hero-track {
    min-height: 300px;
  }

  .tf-ltu-hero-overlay {
    left: 28px;
    right: 28px;
    bottom: 28px;
  }
}

/* Mobile: match LINE TODAY hero feeling */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-slider {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 0 22px !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    overflow: visible !important;
    background: #fff !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    width: 100% !important;
    aspect-ratio: 414 / 252 !important;
    min-height: 252px !important;
    overflow: hidden !important;
    background: #d7dee8 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-link img {
    object-fit: cover !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-link::after {
    height: 38% !important;
    background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.18) 100%) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-overlay {
    left: 16px !important;
    right: 16px !important;
    bottom: -42px !important;
    max-width: none !important;
    padding: 14px 14px 16px !important;
    border-radius: 9px !important;
    background: #fff !important;
    box-shadow: 0 10px 26px rgba(15,23,42,.12) !important;
    backdrop-filter: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-title-row {
    gap: 10px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-badge {
    min-width: 38px !important;
    height: 30px !important;
    padding: 0 9px !important;
    border-radius: 6px !important;
    font-size: 16px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-overlay h2 {
    font-size: 22px !important;
    line-height: 1.35 !important;
    -webkit-line-clamp: 2 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-overlay p {
    margin-top: 8px !important;
    font-size: 13px !important;
    letter-spacing: .06em !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-dots {
    left: 18px !important;
    right: 18px !important;
    bottom: 14px !important;
    gap: 5px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-dots button {
    flex: 1 1 auto !important;
    width: auto !important;
    height: 3px !important;
    background: rgba(255,255,255,.45) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-dots button.is-active {
    background: rgba(255,255,255,.95) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slider + .tf-ltu-section {
    margin-top: 62px !important;
  }
}

@media (max-width: 390px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    min-height: 238px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-overlay h2 {
    font-size: 20px !important;
  }
}


/* v0.2.6 - Hero fullscreen / full-bleed only */
@media (min-width: 769px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-slider {
    width: 100% !important;
    max-width: none !important;
    margin: 0 0 42px !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    background: #e8eef5 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    width: 100% !important;
    aspect-ratio: auto !important;
    min-height: clamp(430px, 52vh, 680px) !important;
    height: clamp(430px, 52vh, 680px) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-link img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-link::after {
    height: 58% !important;
    background:
      linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.36) 100%),
      linear-gradient(90deg, rgba(0,0,0,.24) 0%, rgba(0,0,0,0) 58%) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-overlay {
    left: max(40px, calc((100% - 1180px) / 2)) !important;
    right: auto !important;
    bottom: 52px !important;
    width: min(760px, calc(100% - 80px)) !important;
    max-width: 760px !important;
    padding: 24px 28px !important;
    border-radius: 18px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-dots {
    left: max(40px, calc((100% - 1180px) / 2)) !important;
    right: auto !important;
    bottom: 28px !important;
    width: min(520px, calc(100% - 80px)) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-dots button {
    flex: 1 1 auto !important;
    width: auto !important;
  }
}

/* Tablet keeps full width but slightly shorter */
@media (max-width: 1024px) and (min-width: 769px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    min-height: 390px !important;
    height: 46vh !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-overlay {
    left: 32px !important;
    width: min(700px, calc(100% - 64px)) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-dots {
    left: 32px !important;
    width: min(500px, calc(100% - 64px)) !important;
  }
}

/* Mobile remains LINE TODAY full-width hero */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-slider {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    border-radius: 0 !important;
  }
}


/* v0.2.7 - Hero must start immediately under menu and fill viewport width */
@media (min-width: 769px) {
  body.tf-ltu-fullscreen .tf-ltu-main {
    inset: 126px 0 0 0 !important;
    padding-top: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    background: var(--tf-bg, #f4f5f7) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slider {
    width: 100% !important;
    max-width: none !important;
    margin: 0 0 42px 0 !important;
    border-radius: 0 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    width: 100% !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-link,
  body.tf-ltu-fullscreen .tf-ltu-hero-link img {
    width: 100% !important;
  }
}

/* Tablet also no gap under menu */
@media (max-width: 1024px) and (min-width: 769px) {
  body.tf-ltu-fullscreen .tf-ltu-main {
    padding-top: 0 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slider {
    width: 100% !important;
    margin-top: 0 !important;
  }
}

/* Mobile keeps LINE TODAY spacing */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-main {
    padding-top: 0 !important;
  }
}


/* v0.2.8 - fix remaining hero gap + rounded top image */
body.tf-ltu-fullscreen .tf-ltu-main > .tf-ltu-hero-slider:first-child {
  margin-top: 0 !important;
}

body.tf-ltu-fullscreen .tf-ltu-hero-slider {
  overflow: visible !important;
}

body.tf-ltu-fullscreen .tf-ltu-hero-track {
  overflow: hidden !important;
}

/* Desktop: no gap under menu, keep full-bleed hero */
@media (min-width: 769px) {
  body.tf-ltu-fullscreen .tf-ltu-main {
    inset: 124px 0 0 0 !important;
    padding: 0 0 0 0 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slider {
    width: 100vw !important;
    max-width: 100vw !important;
    margin: 0 0 42px 50% !important;
    transform: translateX(-50%) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    border-radius: 0 0 26px 26px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-link img {
    border-radius: 0 0 26px 26px !important;
  }
}

/* Mobile: break out of content padding so hero becomes true fullscreen */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-main {
    padding-top: 0 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slider {
    width: calc(100% + 48px) !important;
    max-width: none !important;
    margin: 0 -24px 22px !important;
    transform: none !important;
    border-radius: 0 !important;
    overflow: visible !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    width: 100% !important;
    min-height: 252px !important;
    border-radius: 20px 20px 0 0 !important;
    overflow: hidden !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-link img {
    border-radius: 20px 20px 0 0 !important;
    display: block !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-overlay {
    left: 16px !important;
    right: 16px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slider + .tf-ltu-section {
    margin-top: 62px !important;
  }
}

/* Smaller phones */
@media (max-width: 390px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-slider {
    width: calc(100% + 40px) !important;
    margin-left: -20px !important;
    margin-right: -20px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-track,
  body.tf-ltu-fullscreen .tf-ltu-hero-link img {
    border-radius: 18px 18px 0 0 !important;
  }
}


/* v0.2.9 - final mobile gap killer under menu */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-header {
    height: 121px !important;
    max-height: 121px !important;
    overflow: visible !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-header-top {
    height: 68px !important;
    min-height: 68px !important;
    max-height: 68px !important;
    margin: 0 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-mobile-tabs {
    height: 52px !important;
    min-height: 52px !important;
    max-height: 52px !important;
    margin: 0 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-mobile-tabs-scroll {
    height: 52px !important;
    min-height: 52px !important;
    max-height: 52px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-main {
    top: 121px !important;
    bottom: calc(72px + env(safe-area-inset-bottom)) !important;
    left: 0 !important;
    right: 0 !important;
    inset: 121px 0 calc(72px + env(safe-area-inset-bottom)) 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    background: #fff !important;
    line-height: normal !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-main::before,
  body.tf-ltu-fullscreen .tf-ltu-main > p:empty {
    display: none !important;
    content: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-main > .tf-ltu-hero-slider:first-child,
  body.tf-ltu-fullscreen .tf-ltu-hero-slider {
    display: block !important;
    position: relative !important;
    top: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 0 22px 0 !important;
    padding: 0 !important;
    transform: none !important;
    background: transparent !important;
    border: 0 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    margin: 0 !important;
    border-radius: 18px 18px 0 0 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-link,
  body.tf-ltu-fullscreen .tf-ltu-hero-link img {
    display: block !important;
    margin: 0 !important;
  }
}

/* very small mobile */
@media (max-width: 390px) {
  body.tf-ltu-fullscreen .tf-ltu-main > .tf-ltu-hero-slider:first-child,
  body.tf-ltu-fullscreen .tf-ltu-hero-slider {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
}


/* v0.3.0 - Professional image-only hero banner
   No dots, no overlay. Use wide banner ratio like global travel sites.
   Recommended image: 1920x720 or 1600x600 WebP, object-fit cover.
*/
body.tf-ltu-fullscreen .tf-ltu-hero-overlay,
body.tf-ltu-fullscreen .tf-ltu-hero-dots,
body.tf-ltu-fullscreen .tf-ltu-hero-link::after {
  display: none !important;
  content: none !important;
}

body.tf-ltu-fullscreen .tf-ltu-hero-slider {
  background: transparent !important;
}

/* Desktop: full-width cinematic banner, not 16:9 */
@media (min-width: 1025px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-slider {
    width: 100vw !important;
    max-width: 100vw !important;
    margin: 0 0 42px 50% !important;
    transform: translateX(-50%) !important;
    border-radius: 0 !important;
    overflow: hidden !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    width: 100% !important;
    height: clamp(360px, 37.5vw, 560px) !important;
    min-height: 360px !important;
    max-height: 560px !important;
    aspect-ratio: auto !important;
    border-radius: 0 0 28px 28px !important;
    overflow: hidden !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-link,
  body.tf-ltu-fullscreen .tf-ltu-hero-link img {
    width: 100% !important;
    height: 100% !important;
    display: block !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-link img {
    object-fit: cover !important;
    object-position: center center !important;
    border-radius: 0 0 28px 28px !important;
  }
}

/* Tablet: slightly taller to keep visual impact */
@media (max-width: 1024px) and (min-width: 769px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-slider {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 0 34px 0 !important;
    transform: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    height: clamp(300px, 44vw, 440px) !important;
    min-height: 300px !important;
    aspect-ratio: auto !important;
    border-radius: 0 0 24px 24px !important;
    overflow: hidden !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-link img {
    object-fit: cover !important;
    object-position: center center !important;
    border-radius: 0 0 24px 24px !important;
  }
}

/* Mobile: app-style top banner, image-only */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-slider {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 0 20px 0 !important;
    padding: 0 !important;
    transform: none !important;
    overflow: hidden !important;
    border-radius: 0 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    width: 100% !important;
    height: clamp(190px, 54vw, 260px) !important;
    min-height: 190px !important;
    aspect-ratio: auto !important;
    border-radius: 0 0 18px 18px !important;
    overflow: hidden !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-link,
  body.tf-ltu-fullscreen .tf-ltu-hero-link img {
    width: 100% !important;
    height: 100% !important;
    display: block !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-link img {
    object-fit: cover !important;
    object-position: center center !important;
    border-radius: 0 0 18px 18px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slider + .tf-ltu-section {
    margin-top: 0 !important;
  }
}


/* v0.3.1 - bring card + text back, but keep overlay/dots removed */
body.tf-ltu-fullscreen .tf-ltu-hero-link::after,
body.tf-ltu-fullscreen .tf-ltu-hero-dots {
  display: none !important;
  content: none !important;
}

body.tf-ltu-fullscreen .tf-ltu-hero-overlay {
  display: block !important;
  position: absolute !important;
  z-index: 2 !important;
  background: rgba(255,255,255,.97) !important;
  box-shadow: 0 18px 45px rgba(15,23,42,.14) !important;
  backdrop-filter: blur(10px) !important;
}

body.tf-ltu-fullscreen .tf-ltu-hero-title-row {
  display: flex !important;
  align-items: flex-start !important;
  gap: 14px !important;
}

body.tf-ltu-fullscreen .tf-ltu-hero-badge {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 42px !important;
  height: 34px !important;
  padding: 0 12px !important;
  border-radius: 8px !important;
  background: #6b7280 !important;
  color: #fff !important;
  font-size: 18px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  flex: 0 0 auto !important;
}

body.tf-ltu-fullscreen .tf-ltu-hero-overlay h2 {
  margin: 0 !important;
  color: #111827 !important;
  font-weight: 900 !important;
  letter-spacing: -.02em !important;
  overflow: hidden !important;
  display: -webkit-box !important;
  -webkit-box-orient: vertical !important;
  -webkit-line-clamp: 2 !important;
}

body.tf-ltu-fullscreen .tf-ltu-hero-overlay p {
  margin: 10px 0 0 !important;
  color: #6b7280 !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
}

/* Desktop / large tablet */
@media (min-width: 769px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-overlay {
    left: max(40px, calc((100% - 1180px) / 2)) !important;
    bottom: 34px !important;
    width: min(760px, calc(100% - 80px)) !important;
    max-width: 760px !important;
    padding: 22px 26px !important;
    border-radius: 18px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-overlay h2 {
    font-size: clamp(26px, 2.7vw, 42px) !important;
    line-height: 1.22 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-overlay p {
    font-size: 16px !important;
    line-height: 1.35 !important;
  }
}

/* Mobile */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-overlay {
    left: 14px !important;
    right: 14px !important;
    bottom: 14px !important;
    width: auto !important;
    max-width: none !important;
    padding: 14px 14px 16px !important;
    border-radius: 10px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-title-row {
    gap: 10px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-badge {
    min-width: 38px !important;
    height: 30px !important;
    padding: 0 10px !important;
    border-radius: 7px !important;
    font-size: 16px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-overlay h2 {
    font-size: 20px !important;
    line-height: 1.32 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-overlay p {
    font-size: 12px !important;
    line-height: 1.3 !important;
    margin-top: 8px !important;
  }
}


/* v0.3.2 - Hero layout refinement
   1) Desktop: normal content section, 16:9, card on right
   2) Mobile: fullscreen 16:9, card centered
   3) Keep card + text + badge
   4) Keep no dot pagination and no dark image overlay
*/
body.tf-ltu-fullscreen .tf-ltu-hero-link::after,
body.tf-ltu-fullscreen .tf-ltu-hero-dots {
  display: none !important;
  content: none !important;
}

body.tf-ltu-fullscreen .tf-ltu-hero-slider {
  background: transparent !important;
}

body.tf-ltu-fullscreen .tf-ltu-hero-track {
  overflow: hidden !important;
}

body.tf-ltu-fullscreen .tf-ltu-hero-link,
body.tf-ltu-fullscreen .tf-ltu-hero-link img {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
}

body.tf-ltu-fullscreen .tf-ltu-hero-link img {
  object-fit: cover !important;
  object-position: center center !important;
}

body.tf-ltu-fullscreen .tf-ltu-hero-overlay {
  display: block !important;
  position: absolute !important;
  z-index: 2 !important;
  background: rgba(255,255,255,.97) !important;
  box-shadow: 0 18px 45px rgba(15,23,42,.14) !important;
  backdrop-filter: blur(10px) !important;
}

body.tf-ltu-fullscreen .tf-ltu-hero-title-row {
  display: flex !important;
  align-items: flex-start !important;
  gap: 14px !important;
}

body.tf-ltu-fullscreen .tf-ltu-hero-badge {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 42px !important;
  height: 34px !important;
  padding: 0 12px !important;
  border-radius: 8px !important;
  background: #6b7280 !important;
  color: #fff !important;
  font-size: 18px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  flex: 0 0 auto !important;
}

body.tf-ltu-fullscreen .tf-ltu-hero-overlay h2 {
  margin: 0 !important;
  color: #111827 !important;
  font-weight: 900 !important;
  letter-spacing: -.02em !important;
  display: -webkit-box !important;
  -webkit-box-orient: vertical !important;
  -webkit-line-clamp: 2 !important;
  overflow: hidden !important;
}

body.tf-ltu-fullscreen .tf-ltu-hero-overlay p {
  margin: 10px 0 0 !important;
  color: #6b7280 !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
}

/* DESKTOP / LARGE TABLET
   - normal section content
   - 16:9 banner
   - content card on RIGHT
*/
@media (min-width: 769px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-slider {
    width: min(1180px, calc(100vw - 64px)) !important;
    max-width: none !important;
    margin: 0 auto 34px !important;
    transform: none !important;
    border-radius: 24px !important;
    overflow: hidden !important;
    box-shadow: 0 18px 48px rgba(8,88,160,.10) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    width: 100% !important;
    aspect-ratio: 16 / 9 !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    border-radius: 24px !important;
    overflow: hidden !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-link img {
    border-radius: 24px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-overlay {
    left: auto !important;
    right: 28px !important;
    bottom: 28px !important;
    width: min(520px, calc(100% - 56px)) !important;
    max-width: 520px !important;
    padding: 22px 24px !important;
    border-radius: 18px !important;
    text-align: left !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-overlay h2 {
    font-size: clamp(24px, 2.2vw, 36px) !important;
    line-height: 1.24 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-overlay p {
    font-size: 15px !important;
    line-height: 1.35 !important;
  }
}

/* MOBILE
   - full-width / fullscreen style
   - 16:9
   - card centered
*/
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-main {
    top: 121px !important;
    bottom: calc(72px + env(safe-area-inset-bottom)) !important;
    left: 0 !important;
    right: 0 !important;
    inset: 121px 0 calc(72px + env(safe-area-inset-bottom)) 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    background: #fff !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slider {
    width: 100vw !important;
    max-width: 100vw !important;
    margin: 0 0 22px 50% !important;
    transform: translateX(-50%) !important;
    border-radius: 0 !important;
    overflow: visible !important;
    box-shadow: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    width: 100% !important;
    aspect-ratio: 16 / 9 !important;
    height: auto !important;
    min-height: 0 !important;
    border-radius: 0 0 18px 18px !important;
    overflow: hidden !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-link img {
    border-radius: 0 0 18px 18px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-overlay {
    left: 50% !important;
    right: auto !important;
    bottom: 14px !important;
    transform: translateX(-50%) !important;
    width: min(330px, calc(100vw - 28px)) !important;
    max-width: calc(100vw - 28px) !important;
    padding: 14px 14px 16px !important;
    border-radius: 10px !important;
    text-align: center !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-title-row {
    justify-content: center !important;
    align-items: center !important;
    gap: 10px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-badge {
    min-width: 38px !important;
    height: 30px !important;
    padding: 0 10px !important;
    border-radius: 7px !important;
    font-size: 16px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-overlay h2 {
    font-size: 20px !important;
    line-height: 1.32 !important;
    text-align: center !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-overlay p {
    font-size: 12px !important;
    line-height: 1.3 !important;
    margin-top: 8px !important;
    text-align: center !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slider + .tf-ltu-section {
    margin-top: 0 !important;
  }
}

/* Very small phones */
@media (max-width: 390px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-overlay {
    width: calc(100vw - 22px) !important;
    max-width: calc(100vw - 22px) !important;
    bottom: 12px !important;
    padding: 12px 12px 14px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-overlay h2 {
    font-size: 18px !important;
  }
}


/* v0.3.3 - desktop hero height cap
   Professional approach:
   - source image can still be 16:9
   - desktop display frame is capped shorter for better first-screen UX
   - use object-fit: cover to crop elegantly instead of stretching
*/
@media (min-width: 769px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-slider {
    width: min(1180px, calc(100vw - 64px)) !important;
    max-width: none !important;
    margin: 0 auto 30px !important;
    border-radius: 24px !important;
    overflow: hidden !important;
  }

  /* Instead of full 16:9 visible height (~663px at 1180px wide),
     cap the hero height to a smaller frame. */
  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    aspect-ratio: auto !important;
    height: clamp(300px, 31vw, 420px) !important;
    min-height: 300px !important;
    max-height: 420px !important;
    border-radius: 24px !important;
    overflow: hidden !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-link,
  body.tf-ltu-fullscreen .tf-ltu-hero-link img {
    width: 100% !important;
    height: 100% !important;
    display: block !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-link img {
    object-fit: cover !important;
    object-position: center center !important;
    border-radius: 24px !important;
  }

  /* keep card on right and keep it visually balanced with the shorter banner */
  body.tf-ltu-fullscreen .tf-ltu-hero-overlay {
    right: 24px !important;
    left: auto !important;
    bottom: 24px !important;
    width: min(460px, calc(100% - 48px)) !important;
    max-width: 460px !important;
    padding: 20px 22px !important;
    border-radius: 18px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-overlay h2 {
    font-size: clamp(22px, 1.9vw, 32px) !important;
    line-height: 1.24 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-overlay p {
    font-size: 14px !important;
  }
}

/* Large desktop can stay elegant and not oversized */
@media (min-width: 1400px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    height: 400px !important;
    max-height: 400px !important;
  }
}

/* Tablet: slightly taller than desktop for balance */
@media (min-width: 769px) and (max-width: 1024px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    height: clamp(280px, 38vw, 360px) !important;
    min-height: 280px !important;
    max-height: 360px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-overlay {
    width: min(420px, calc(100% - 40px)) !important;
    max-width: 420px !important;
    right: 20px !important;
    bottom: 20px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-overlay h2 {
    font-size: 24px !important;
  }
}


/* v0.3.4 - Desktop hero inspired by global travel UI (desktop only)
   Mobile styles are intentionally left unchanged.
*/
body.tf-ltu-fullscreen .tf-ltu-hero-shell {
  position: relative !important;
}

/* Desktop top nav above hero */
@media (min-width: 769px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-shell {
    width: min(1180px, calc(100vw - 64px)) !important;
    max-width: none !important;
    margin: 0 auto 30px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-desktop-topnav {
    display: flex !important;
    align-items: center !important;
    gap: 28px !important;
    padding: 0 12px 14px !important;
    border-bottom: 1px solid #eceff3 !important;
    margin-bottom: 10px !important;
    overflow-x: auto !important;
    scrollbar-width: none !important;
    white-space: nowrap !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-desktop-topnav::-webkit-scrollbar {
    display: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-desktop-topnav a {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    text-decoration: none !important;
    color: #2f3338 !important;
    font-size: 15px !important;
    line-height: 1 !important;
    font-weight: 700 !important;
    padding: 6px 0 !important;
    opacity: .92 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-desktop-topnav a.is-gift {
    color: #ff6500 !important;
    font-weight: 900 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-gift-emoji {
    font-size: 16px !important;
    line-height: 1 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slider {
    position: relative !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    border-radius: 0 !important;
    overflow: hidden !important;
    box-shadow: none !important;
    background: #f4f6f9 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    height: 448px !important;
    min-height: 448px !important;
    max-height: 448px !important;
    aspect-ratio: auto !important;
    border-radius: 0 !important;
    overflow: hidden !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-link img {
    border-radius: 0 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-overlay {
    display: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-desktop-copy {
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    top: 0 !important;
    bottom: 0 !important;
    z-index: 4 !important;
    padding: 114px 0 0 140px !important;
    pointer-events: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-desktop-copy h2 {
    margin: 0 !important;
    max-width: 780px !important;
    color: #fff !important;
    font-size: clamp(48px, 4.5vw, 78px) !important;
    line-height: .98 !important;
    font-weight: 900 !important;
    letter-spacing: -.04em !important;
    text-shadow: 0 10px 30px rgba(0,0,0,.18) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-desktop-copy p {
    margin: 16px 0 0 !important;
    max-width: 860px !important;
    color: rgba(255,255,255,.95) !important;
    font-size: 17px !important;
    line-height: 1.45 !important;
    font-weight: 700 !important;
    text-shadow: 0 8px 24px rgba(0,0,0,.18) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-search {
    margin-top: 28px !important;
    width: min(1000px, calc(100% - 220px)) !important;
    min-height: 66px !important;
    border-radius: 18px !important;
    background: #fff !important;
    box-shadow: 0 18px 46px rgba(0,0,0,.14) !important;
    display: flex !important;
    align-items: center !important;
    overflow: hidden !important;
    pointer-events: auto !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-search-icon {
    flex: 0 0 62px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 32px !important;
    color: #8b9096 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-search input {
    flex: 1 1 auto !important;
    width: auto !important;
    border: 0 !important;
    box-shadow: none !important;
    background: transparent !important;
    color: #4b5563 !important;
    font-size: 18px !important;
    line-height: 1.2 !important;
    padding: 0 18px 0 0 !important;
    outline: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-search input::placeholder {
    color: #8b9096 !important;
    opacity: 1 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-search button {
    flex: 0 0 154px !important;
    height: 54px !important;
    margin: 6px !important;
    border: 0 !important;
    border-radius: 14px !important;
    background: #ff6a00 !important;
    color: #fff !important;
    font-size: 18px !important;
    font-weight: 900 !important;
    cursor: pointer !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-arrow {
    position: absolute !important;
    top: 50% !important;
    z-index: 5 !important;
    width: 54px !important;
    height: 54px !important;
    margin-top: -27px !important;
    border: 0 !important;
    background: transparent !important;
    color: #fff !important;
    font-size: 74px !important;
    line-height: .8 !important;
    cursor: pointer !important;
    text-shadow: 0 10px 30px rgba(0,0,0,.18) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-prev {
    left: 12px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-next {
    right: 12px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-deco {
    position: absolute !important;
    z-index: 3 !important;
    pointer-events: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-deco-left {
    left: -8px !important;
    bottom: 0 !important;
    width: 200px !important;
    height: 190px !important;
    background: linear-gradient(180deg, #f27100 0%, #d94d00 100%) !important;
    border-radius: 0 120px 0 0 !important;
    overflow: hidden !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-deco-left span {
    position: absolute !important;
    display: block !important;
    border: 6px solid rgba(255,255,255,.85) !important;
    border-radius: 999px !important;
    width: 104px !important;
    height: 34px !important;
    transform: rotate(28deg) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-deco-left span:first-child {
    left: -6px !important;
    bottom: 18px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-deco-left span:last-child {
    left: 68px !important;
    bottom: 70px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-deco-right {
    right: -20px !important;
    bottom: 0 !important;
    width: 150px !important;
    height: 244px !important;
    background: linear-gradient(180deg, #e6b600 0%, #c68b00 100%) !important;
    border-radius: 120px 0 0 0 !important;
  }
}

/* Mobile: do not change existing mobile hero */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-desktop-topnav,
  body.tf-ltu-fullscreen .tf-ltu-hero-arrow,
  body.tf-ltu-fullscreen .tf-ltu-hero-deco,
  body.tf-ltu-fullscreen .tf-ltu-hero-desktop-copy {
    display: none !important;
  }
}


/* v0.3.5 - desktop hero cleanup:
   - round image corners
   - reduce headline size
   - add foreign tour company keyword in subtitle
   - remove duplicated quick nav
*/
@media (min-width: 769px) {
  /* remove duplicated hero sub-navigation */
  body.tf-ltu-fullscreen .tf-ltu-hero-desktop-topnav {
    display: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-shell {
    width: min(1180px, calc(100vw - 64px)) !important;
    max-width: none !important;
    margin: 0 auto 30px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slider {
    border-radius: 28px !important;
    overflow: hidden !important;
    box-shadow: 0 12px 34px rgba(15, 23, 42, .08) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    border-radius: 28px !important;
    overflow: hidden !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-link,
  body.tf-ltu-fullscreen .tf-ltu-hero-link img {
    border-radius: 28px !important;
  }

  /* slightly reduce desktop H1-style hero heading */
  body.tf-ltu-fullscreen .tf-ltu-hero-desktop-copy {
    padding: 96px 0 0 110px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-desktop-copy h2 {
    max-width: 700px !important;
    font-size: clamp(36px, 3.6vw, 60px) !important;
    line-height: 1.02 !important;
    letter-spacing: -.03em !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-desktop-copy p {
    margin-top: 14px !important;
    max-width: 760px !important;
    font-size: 15px !important;
    line-height: 1.45 !important;
    font-weight: 800 !important;
    letter-spacing: .01em !important;
    text-transform: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-search {
    margin-top: 24px !important;
    width: min(860px, calc(100% - 220px)) !important;
    min-height: 64px !important;
    border-radius: 16px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-search button {
    border-radius: 12px !important;
  }
}

/* slightly smaller desktop/laptop */
@media (min-width: 769px) and (max-width: 1280px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-desktop-copy {
    padding: 82px 0 0 84px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-desktop-copy h2 {
    font-size: clamp(32px, 3.4vw, 52px) !important;
    max-width: 620px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-search {
    width: min(780px, calc(100% - 170px)) !important;
  }
}


/* v0.3.6 - desktop hero simplified
   1) remove desktop search
   2) use slide card + badge + text centered at bottom with bottom:-20px
   3) keep mobile unchanged
*/
@media (min-width: 769px) {
  /* remove desktop headline/search layer completely */
  body.tf-ltu-fullscreen .tf-ltu-hero-desktop-copy,
  body.tf-ltu-fullscreen .tf-ltu-hero-search {
    display: none !important;
  }

  /* give space for the card hanging below the image */
  body.tf-ltu-fullscreen .tf-ltu-hero-shell {
    margin-bottom: 56px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slider {
    overflow: visible !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    overflow: hidden !important;
    border-radius: 28px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-link,
  body.tf-ltu-fullscreen .tf-ltu-hero-link img {
    border-radius: 28px !important;
  }

  /* bring the real slide card back and place it at center-bottom */
  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay {
    display: block !important;
    position: absolute !important;
    left: 50% !important;
    right: auto !important;
    bottom: -20px !important;
    transform: translateX(-50%) !important;
    width: min(760px, calc(100% - 72px)) !important;
    max-width: 760px !important;
    padding: 22px 26px !important;
    border-radius: 18px !important;
    background: rgba(255,255,255,.98) !important;
    box-shadow: 0 18px 45px rgba(15,23,42,.14) !important;
    backdrop-filter: blur(10px) !important;
    text-align: left !important;
    z-index: 6 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-title-row {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: center !important;
    gap: 14px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-badge {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 42px !important;
    height: 34px !important;
    padding: 0 12px !important;
    border-radius: 8px !important;
    background: #6b7280 !important;
    color: #fff !important;
    font-size: 18px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    flex: 0 0 auto !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay h2 {
    margin: 0 !important;
    color: #111827 !important;
    font-size: clamp(28px, 2.3vw, 42px) !important;
    line-height: 1.16 !important;
    font-weight: 900 !important;
    letter-spacing: -.02em !important;
    display: -webkit-box !important;
    -webkit-box-orient: vertical !important;
    -webkit-line-clamp: 2 !important;
    overflow: hidden !important;
    text-align: center !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay p {
    margin: 12px 0 0 !important;
    color: #6b7280 !important;
    font-size: 15px !important;
    line-height: 1.35 !important;
    font-weight: 800 !important;
    letter-spacing: .01em !important;
    text-transform: none !important;
    text-align: center !important;
  }

  /* small desktop/laptop */
  @media (max-width: 1280px) {
    body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay {
      width: min(680px, calc(100% - 56px)) !important;
      padding: 20px 22px !important;
    }

    body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay h2 {
      font-size: clamp(24px, 2.2vw, 36px) !important;
    }
  }
}

/* Mobile unchanged; just make sure desktop-only copy stays hidden if responsive tooling leaks */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-desktop-copy {
    display: none !important;
  }
}


/* v0.3.7 - Desktop-only homepage UI like requested mockup.
   Mobile is intentionally preserved from previous version.
*/
@media (min-width: 769px) {
  body.tf-ltu-fullscreen .tf-ltu-header {
    background: rgba(255,255,255,.985) !important;
    border-bottom: 1px solid #e9edf4 !important;
    box-shadow: 0 10px 32px rgba(15,23,42,.045) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-header-top {
    height: 78px !important;
    width: min(1380px, calc(100vw - 96px)) !important;
    max-width: none !important;
    padding: 0 !important;
    gap: 34px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-logo-mark {
    width: 48px !important;
    height: 48px !important;
    flex-basis: 48px !important;
    border-radius: 15px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-logo-text strong {
    font-size: 27px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-logo-text small {
    font-size: 11px !important;
    letter-spacing: .24em !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-search {
    max-width: 640px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-search input {
    height: 52px !important;
    background: #fff !important;
    border: 1px solid #dbe4f0 !important;
    border-radius: 999px !important;
    box-shadow: 0 8px 24px rgba(15,23,42,.04) !important;
    font-size: 15px !important;
    padding-left: 30px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-search button {
    right: -2px !important;
    top: 0 !important;
    width: 52px !important;
    height: 52px !important;
    background: #0b73ff !important;
    color: #fff !important;
    font-size: 24px !important;
    box-shadow: 0 12px 28px rgba(11,115,255,.24) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-actions {
    min-width: 240px !important;
    justify-content: flex-end !important;
    gap: 18px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-actions a {
    width: auto !important;
    height: 42px !important;
    border-radius: 999px !important;
    padding: 0 8px !important;
    gap: 8px !important;
    font-size: 16px !important;
    color: #0f172a !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-login-text,
  body.tf-ltu-fullscreen .tf-ltu-menu-text {
    display: inline !important;
    font-size: 15px !important;
    font-weight: 800 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-action-separator {
    width: 1px !important;
    height: 26px !important;
    background: #cbd5e1 !important;
    display: inline-block !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-real-mega-nav {
    height: 62px !important;
    background: #fff !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-real-mega-row {
    height: 62px !important;
    min-height: 62px !important;
    width: min(1180px, calc(100vw - 96px)) !important;
    justify-content: center !important;
    gap: 58px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-item {
    height: 62px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-trigger,
  body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-header-link {
    height: 62px !important;
    color: #334155 !important;
    font-size: 17px !important;
    font-weight: 800 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-trigger::before,
  body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-header-link::before {
    display: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-item:first-child > .tte-mega-trigger {
    color: #0b73ff !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-item:first-child > .tte-mega-trigger::before {
    content: "" !important;
    display: block !important;
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    bottom: -1px !important;
    height: 3px !important;
    border-radius: 999px !important;
    background: #0b73ff !important;
  }

  /* main starts after taller desktop header */
  body.tf-ltu-fullscreen .tf-ltu-main {
    inset: 141px 0 0 0 !important;
    padding-top: 26px !important;
    background: #f8fbff !important;
  }

  /* hero shell/cards */
  body.tf-ltu-fullscreen .tf-ltu-hero-shell {
    width: min(1360px, calc(100vw - 96px)) !important;
    margin: 0 auto 86px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slider {
    position: relative !important;
    border-radius: 26px !important;
    overflow: visible !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    height: 400px !important;
    min-height: 400px !important;
    max-height: 400px !important;
    border-radius: 26px !important;
    overflow: hidden !important;
    box-shadow: 0 24px 60px rgba(15,23,42,.08) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-link,
  body.tf-ltu-fullscreen .tf-ltu-hero-link img {
    border-radius: 26px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-deco-left {
    left: 0 !important;
    bottom: 0 !important;
    width: 190px !important;
    height: 185px !important;
    border-radius: 0 120px 0 26px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-deco-right {
    right: 0 !important;
    bottom: 0 !important;
    width: 150px !important;
    height: 220px !important;
    border-radius: 120px 0 26px 0 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-prev,
  body.tf-ltu-fullscreen .tf-ltu-hero-next {
    width: 48px !important;
    height: 48px !important;
    margin-top: -24px !important;
    border-radius: 999px !important;
    background: #fff !important;
    color: #0f172a !important;
    font-size: 42px !important;
    line-height: .8 !important;
    box-shadow: 0 12px 30px rgba(15,23,42,.12) !important;
    text-shadow: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-prev {
    left: 22px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-next {
    right: 22px !important;
  }

  /* center bottom card overlapping, and push benefits down */
  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay {
    display: block !important;
    position: absolute !important;
    left: 50% !important;
    right: auto !important;
    bottom: -20px !important;
    transform: translateX(-50%) !important;
    width: min(660px, calc(100% - 160px)) !important;
    max-width: 660px !important;
    padding: 22px 28px 24px !important;
    border-radius: 16px !important;
    background: rgba(255,255,255,.985) !important;
    box-shadow: 0 20px 48px rgba(15,23,42,.15) !important;
    z-index: 10 !important;
    text-align: center !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-title-row {
    justify-content: center !important;
    align-items: center !important;
    gap: 14px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay h2 {
    font-size: clamp(26px, 2.2vw, 38px) !important;
    line-height: 1.16 !important;
    text-align: center !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay p {
    text-align: center !important;
  }

  /* benefit cards under hero like the reference */
  body.tf-ltu-fullscreen .tf-ltu-hero-benefits {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 24px !important;
    width: min(1040px, calc(100% - 160px)) !important;
    margin: 62px auto 0 !important;
    position: relative !important;
    z-index: 2 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-benefit-card {
    min-height: 116px !important;
    border-radius: 16px !important;
    background: #fff !important;
    border: 1px solid #e3e9f3 !important;
    box-shadow: 0 16px 38px rgba(15,23,42,.08) !important;
    display: grid !important;
    grid-template-columns: 92px minmax(0, 1fr) 28px !important;
    align-items: center !important;
    gap: 16px !important;
    padding: 22px 24px !important;
    color: #0f172a !important;
    text-decoration: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-benefit-visual {
    width: 80px !important;
    height: 72px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 52px !important;
    background: #f1f7ff !important;
    border-radius: 18px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-benefit-body strong {
    display: block !important;
    color: #327cf6 !important;
    font-size: 24px !important;
    line-height: 1.05 !important;
    font-weight: 900 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-benefit-body small {
    display: block !important;
    margin-top: 8px !important;
    color: #475569 !important;
    font-size: 13px !important;
    line-height: 1.45 !important;
    font-weight: 700 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-benefit-arrow {
    width: 28px !important;
    height: 28px !important;
    border-radius: 999px !important;
    border: 1px solid #d8e4f5 !important;
    color: #0b73ff !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 22px !important;
    line-height: 1 !important;
  }
}

/* laptop tune */
@media (min-width: 769px) and (max-width: 1280px) {
  body.tf-ltu-fullscreen .tf-ltu-header-top {
    width: min(1180px, calc(100vw - 64px)) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-real-mega-row {
    width: min(1180px, calc(100vw - 64px)) !important;
    gap: 42px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-shell {
    width: min(1180px, calc(100vw - 64px)) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    height: 370px !important;
    min-height: 370px !important;
    max-height: 370px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-benefits {
    width: min(960px, calc(100% - 80px)) !important;
  }
}

/* Mobile: do not change previous mobile UI */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-benefits {
    display: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-login-text,
  body.tf-ltu-fullscreen .tf-ltu-menu-text,
  body.tf-ltu-fullscreen .tf-ltu-action-separator {
    display: none !important;
  }
}


/* v0.3.8 - Desktop hero/menu closer to requested mockup
   Desktop only. Mobile remains unchanged.
*/
@media (min-width: 769px) {
  /* Requested menu labels, clean spacing, no fake marketplace labels */
  body.tf-ltu-fullscreen .tf-ltu-real-mega-row {
    width: min(1180px, calc(100vw - 64px)) !important;
    gap: 48px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-trigger,
  body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-header-link {
    font-size: 18px !important;
    font-weight: 900 !important;
    color: #0f172a !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-item:first-child > .tte-mega-trigger {
    color: #0b73ff !important;
  }

  /* Hero like the approved desktop reference:
     image wider/taller, card overlaps bottom center, benefits lower */
  body.tf-ltu-fullscreen .tf-ltu-hero-shell {
    width: min(1360px, calc(100vw - 80px)) !important;
    margin: 0 auto 104px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slider {
    border-radius: 28px !important;
    overflow: visible !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    height: clamp(420px, 31vw, 500px) !important;
    min-height: 420px !important;
    max-height: 500px !important;
    border-radius: 28px !important;
    overflow: hidden !important;
    box-shadow: 0 22px 60px rgba(15, 23, 42, .09) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-link,
  body.tf-ltu-fullscreen .tf-ltu-hero-link img {
    border-radius: 28px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-link img {
    object-fit: cover !important;
    object-position: center center !important;
  }

  /* orange/yellow shapes anchored inside image corners like reference */
  body.tf-ltu-fullscreen .tf-ltu-hero-deco-left {
    left: 0 !important;
    bottom: 0 !important;
    width: 178px !important;
    height: 172px !important;
    border-radius: 0 120px 0 28px !important;
    z-index: 4 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-deco-right {
    right: 0 !important;
    bottom: 0 !important;
    width: 142px !important;
    height: 212px !important;
    border-radius: 110px 0 28px 0 !important;
    z-index: 4 !important;
  }

  /* Arrow position like reference */
  body.tf-ltu-fullscreen .tf-ltu-hero-prev,
  body.tf-ltu-fullscreen .tf-ltu-hero-next {
    z-index: 8 !important;
    width: 48px !important;
    height: 48px !important;
    background: #fff !important;
    color: #0f172a !important;
    border-radius: 999px !important;
    font-size: 42px !important;
    box-shadow: 0 14px 34px rgba(15,23,42,.14) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-prev {
    left: 22px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-next {
    right: 22px !important;
  }

  /* Card + badge + text centered bottom, overlap image and push benefits down */
  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay {
    display: block !important;
    left: 50% !important;
    right: auto !important;
    bottom: -28px !important;
    transform: translateX(-50%) !important;
    width: min(680px, calc(100% - 220px)) !important;
    max-width: 680px !important;
    padding: 24px 30px 25px !important;
    border-radius: 18px !important;
    background: rgba(255,255,255,.985) !important;
    box-shadow: 0 22px 54px rgba(15,23,42,.16) !important;
    z-index: 12 !important;
    text-align: center !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-title-row {
    justify-content: center !important;
    align-items: center !important;
    gap: 14px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay h2 {
    font-size: clamp(28px, 2.25vw, 42px) !important;
    line-height: 1.15 !important;
    text-align: center !important;
    letter-spacing: -.025em !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay p {
    text-align: center !important;
    margin-top: 12px !important;
    font-size: 15px !important;
  }

  /* benefits exactly lower, not too close to hero card */
  body.tf-ltu-fullscreen .tf-ltu-hero-benefits {
    width: min(1040px, calc(100% - 180px)) !important;
    margin: 78px auto 0 !important;
    gap: 24px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-benefit-card {
    min-height: 118px !important;
    border-radius: 18px !important;
    padding: 24px 26px !important;
    box-shadow: 0 17px 40px rgba(15,23,42,.09) !important;
  }
}

/* Laptop tuning */
@media (min-width: 769px) and (max-width: 1280px) {
  body.tf-ltu-fullscreen .tf-ltu-real-mega-row {
    gap: 34px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-shell {
    width: min(1180px, calc(100vw - 64px)) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    height: 390px !important;
    min-height: 390px !important;
    max-height: 390px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay {
    width: min(620px, calc(100% - 140px)) !important;
    bottom: -26px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-benefits {
    width: min(980px, calc(100% - 90px)) !important;
  }
}

/* Mobile untouched */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-benefits {
    display: none !important;
  }
}


/* v0.3.9 - fix mega menu structure and unify hero style for desktop + mobile */

/* hero section unified across desktop and mobile */
body.tf-ltu-fullscreen .tf-ltu-hero-shell {
  position: relative !important;
}
body.tf-ltu-fullscreen .tf-ltu-hero-slider {
  position: relative !important;
  border-radius: 28px !important;
  overflow: visible !important;
  background: transparent !important;
  box-shadow: none !important;
}
body.tf-ltu-fullscreen .tf-ltu-hero-track {
  border-radius: 28px !important;
  overflow: hidden !important;
  box-shadow: 0 22px 60px rgba(15,23,42,.10) !important;
}
body.tf-ltu-fullscreen .tf-ltu-hero-link,
body.tf-ltu-fullscreen .tf-ltu-hero-link img {
  border-radius: 28px !important;
}
body.tf-ltu-fullscreen .tf-ltu-hero-link img {
  object-fit: cover !important;
  object-position: center center !important;
}
body.tf-ltu-fullscreen .tf-ltu-hero-desktop-copy,
body.tf-ltu-fullscreen .tf-ltu-hero-search {
  display:none !important;
}
body.tf-ltu-fullscreen .tf-ltu-hero-prev,
body.tf-ltu-fullscreen .tf-ltu-hero-next {
  z-index: 9 !important;
  width: 42px !important;
  height: 42px !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.96) !important;
  color: #0f172a !important;
  font-size: 36px !important;
  line-height: .8 !important;
  box-shadow: 0 12px 28px rgba(15,23,42,.16) !important;
  text-shadow: none !important;
}
body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay {
  display: block !important;
  position: absolute !important;
  left: 50% !important;
  right: auto !important;
  transform: translateX(-50%) !important;
  bottom: -22px !important;
  width: min(680px, calc(100% - 180px)) !important;
  max-width: 680px !important;
  padding: 22px 28px 20px !important;
  border-radius: 18px !important;
  background: rgba(255,255,255,.985) !important;
  box-shadow: 0 22px 54px rgba(15,23,42,.16) !important;
  z-index: 12 !important;
  text-align: center !important;
}
body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-title-row {
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
  gap: 12px !important;
}
body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay h2 {
  margin:0 !important;
  text-align:center !important;
  color:#111827 !important;
  font-weight:900 !important;
  letter-spacing:-.02em !important;
  display:-webkit-box !important;
  -webkit-box-orient: vertical !important;
  -webkit-line-clamp:2 !important;
  overflow:hidden !important;
}
body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay p {
  margin: 10px 0 0 !important;
  text-align:center !important;
  color:#6b7280 !important;
  font-weight:800 !important;
}
body.tf-ltu-fullscreen .tf-ltu-hero-deco-left {
  left: 0 !important;
  bottom: 0 !important;
  z-index: 4 !important;
}
body.tf-ltu-fullscreen .tf-ltu-hero-deco-right {
  right: 0 !important;
  bottom: 0 !important;
  z-index: 4 !important;
}

@media (min-width: 769px) {
  body.tf-ltu-fullscreen .tf-ltu-real-mega-row {
    width: min(1180px, calc(100vw - 64px)) !important;
    gap: 46px !important;
  }
  body.tf-ltu-fullscreen .tf-ltu-main {
    background: #f8fbff !important;
  }
  body.tf-ltu-fullscreen .tf-ltu-hero-shell {
    width: min(1360px, calc(100vw - 80px)) !important;
    margin: 0 auto 96px !important;
  }
  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    height: clamp(410px, 30vw, 470px) !important;
    min-height: 410px !important;
    max-height: 470px !important;
  }
  body.tf-ltu-fullscreen .tf-ltu-hero-prev { left: 24px !important; top: 46% !important; }
  body.tf-ltu-fullscreen .tf-ltu-hero-next { right: 24px !important; top: 46% !important; }
  body.tf-ltu-fullscreen .tf-ltu-hero-deco-left {
    width: 176px !important; height: 170px !important; border-radius: 0 120px 0 28px !important;
  }
  body.tf-ltu-fullscreen .tf-ltu-hero-deco-right {
    width: 142px !important; height: 214px !important; border-radius: 110px 0 28px 0 !important;
  }
  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay {
    width: min(700px, calc(100% - 220px)) !important;
    bottom: -24px !important;
  }
  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay h2 {
    font-size: clamp(28px, 2.25vw, 42px) !important;
    line-height: 1.14 !important;
  }
  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay p {
    font-size: 15px !important;
  }
  body.tf-ltu-fullscreen .tf-ltu-hero-benefits {
    width: min(1040px, calc(100% - 180px)) !important;
    margin: 78px auto 0 !important;
    gap: 24px !important;
  }
}

@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-main {
    background: #f8fbff !important;
    padding-top: 12px !important;
  }
  body.tf-ltu-fullscreen .tf-ltu-hero-shell {
    width: calc(100vw - 24px) !important;
    margin: 0 auto 42px !important;
  }
  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    height: clamp(210px, 58vw, 300px) !important;
    min-height: 210px !important;
    max-height: 300px !important;
  }
  body.tf-ltu-fullscreen .tf-ltu-hero-prev { left: 12px !important; top: 44% !important; }
  body.tf-ltu-fullscreen .tf-ltu-hero-next { right: 12px !important; top: 44% !important; }
  body.tf-ltu-fullscreen .tf-ltu-hero-deco-left {
    width: 108px !important; height: 104px !important; border-radius: 0 76px 0 24px !important;
  }
  body.tf-ltu-fullscreen .tf-ltu-hero-deco-left span {
    border-width: 4px !important; width: 58px !important; height: 18px !important;
  }
  body.tf-ltu-fullscreen .tf-ltu-hero-deco-left span:first-child { left: 4px !important; bottom: 16px !important; }
  body.tf-ltu-fullscreen .tf-ltu-hero-deco-left span:last-child { left: 34px !important; bottom: 46px !important; }
  body.tf-ltu-fullscreen .tf-ltu-hero-deco-right {
    width: 88px !important; height: 132px !important; border-radius: 72px 0 24px 0 !important;
  }
  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay {
    width: calc(100% - 52px) !important;
    padding: 14px 16px 13px !important;
    bottom: -20px !important;
    border-radius: 14px !important;
  }
  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-title-row {
    gap: 8px !important;
  }
  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-badge {
    min-width: 36px !important; height: 28px !important; padding: 0 10px !important; font-size: 14px !important;
  }
  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay h2 {
    font-size: 18px !important;
    line-height: 1.2 !important;
  }
  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay p {
    font-size: 12px !important;
    margin-top: 8px !important;
  }
  body.tf-ltu-fullscreen .tf-ltu-hero-benefits {
    display: none !important;
  }
}


/* v0.4.0 - fix hero card clipping */

/* Allow the bottom card to render fully, not cut in half */
body.tf-ltu-fullscreen .tf-ltu-hero-shell,
body.tf-ltu-fullscreen .tf-ltu-hero-slider,
body.tf-ltu-fullscreen .tf-ltu-hero-track,
body.tf-ltu-fullscreen .tf-ltu-hero-slide {
  overflow: visible !important;
}

/* Keep image corners rounded while card can extend outside */
body.tf-ltu-fullscreen .tf-ltu-hero-link {
  display: block !important;
  position: relative !important;
  overflow: visible !important;
}

body.tf-ltu-fullscreen .tf-ltu-hero-link img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  border-radius: 28px !important;
}

body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay {
  z-index: 30 !important;
  box-sizing: border-box !important;
  min-height: unset !important;
}

/* Desktop: show full card and give enough space to section below */
@media (min-width: 769px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-shell {
    margin-bottom: 120px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    height: clamp(410px, 30vw, 470px) !important;
    min-height: 410px !important;
    max-height: 470px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay {
    bottom: -36px !important;
    width: min(760px, calc(100% - 240px)) !important;
    max-width: 760px !important;
    padding: 26px 34px 24px !important;
    border-radius: 20px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay h2 {
    font-size: clamp(28px, 2.1vw, 40px) !important;
    line-height: 1.12 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay p {
    font-size: 15px !important;
    margin-top: 10px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-benefits {
    margin-top: 86px !important;
  }
}

/* Mobile: keep same design, but ensure the full card is visible */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-shell {
    margin-bottom: 58px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-track {
    height: clamp(220px, 60vw, 310px) !important;
    min-height: 220px !important;
    max-height: 310px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay {
    bottom: -24px !important;
    width: calc(100% - 36px) !important;
    max-width: none !important;
    padding: 14px 16px 15px !important;
    border-radius: 16px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-title-row {
    gap: 8px !important;
    align-items: center !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-badge {
    flex: 0 0 auto !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay h2 {
    font-size: 16px !important;
    line-height: 1.22 !important;
    -webkit-line-clamp: 2 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-hero-slide .tf-ltu-hero-overlay p {
    font-size: 11px !important;
    margin-top: 7px !important;
  }
}


/* v0.4.1 - Replace login with themed social icons */
body.tf-ltu-fullscreen .tf-ltu-social-actions {
  display: flex !important;
  align-items: center !important;
}

body.tf-ltu-fullscreen .tf-ltu-social-group {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
}

body.tf-ltu-fullscreen .tf-ltu-social-link {
  width: 36px !important;
  height: 36px !important;
  flex: 0 0 36px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-decoration: none !important;
  background: rgba(255,255,255,.94) !important;
  border: 1px solid rgba(216,228,245,.95) !important;
  color: #475569 !important;
  box-shadow: 0 8px 22px rgba(15,23,42,.06) !important;
  transition: transform .16s ease, box-shadow .16s ease, color .16s ease, background .16s ease, border-color .16s ease !important;
}

body.tf-ltu-fullscreen .tf-ltu-social-link svg {
  width: 16px !important;
  height: 16px !important;
  display: block !important;
  fill: currentColor !important;
}

body.tf-ltu-fullscreen .tf-ltu-social-link span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 11px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  letter-spacing: -.02em !important;
}

body.tf-ltu-fullscreen .tf-ltu-social-link:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 12px 28px rgba(15,23,42,.12) !important;
}

body.tf-ltu-fullscreen .tf-ltu-social-facebook:hover {
  color: #1877f2 !important;
  border-color: rgba(24,119,242,.28) !important;
  background: #f3f8ff !important;
}

body.tf-ltu-fullscreen .tf-ltu-social-tiktok:hover {
  color: #111827 !important;
  border-color: rgba(17,24,39,.18) !important;
  background: #f8fafc !important;
}

body.tf-ltu-fullscreen .tf-ltu-social-youtube:hover {
  color: #ff0033 !important;
  border-color: rgba(255,0,51,.22) !important;
  background: #fff5f6 !important;
}

body.tf-ltu-fullscreen .tf-ltu-social-lemon8:hover {
  color: #f59e0b !important;
  border-color: rgba(245,158,11,.28) !important;
  background: #fff9ed !important;
}

/* Desktop header balance */
@media (min-width: 769px) {
  body.tf-ltu-fullscreen .tf-ltu-actions.tf-ltu-social-actions {
    min-width: 300px !important;
    gap: 16px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-menu-link {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }
}

/* Mobile: keep compact, show social icons but no text labels */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-actions.tf-ltu-social-actions {
    gap: 8px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-social-group {
    gap: 5px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-social-link {
    width: 28px !important;
    height: 28px !important;
    flex-basis: 28px !important;
    box-shadow: none !important;
    background: transparent !important;
    border-color: transparent !important;
    color: #0a84ff !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-social-link svg {
    width: 14px !important;
    height: 14px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-social-link span {
    font-size: 9px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-action-separator,
  body.tf-ltu-fullscreen .tf-ltu-menu-text {
    display: none !important;
  }
}


/* v0.4.2 - Add LINE social + ToTop button */
body.tf-ltu-fullscreen .tf-ltu-social-line:hover {
  color: #06c755 !important;
  border-color: rgba(6,199,85,.28) !important;
  background: #f1fff6 !important;
}

/* More compact social group after adding LINE */
@media (min-width: 769px) {
  body.tf-ltu-fullscreen .tf-ltu-actions.tf-ltu-social-actions {
    min-width: 336px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-social-group {
    gap: 7px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-social-link {
    width: 34px !important;
    height: 34px !important;
    flex-basis: 34px !important;
  }
}

/* ToTop */
body.tf-ltu-fullscreen .tf-ltu-to-top {
  position: fixed !important;
  right: max(20px, env(safe-area-inset-right)) !important;
  bottom: calc(24px + env(safe-area-inset-bottom)) !important;
  z-index: 1000002 !important;
  width: 58px !important;
  height: 58px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.96) !important;
  color: #0f172a !important;
  box-shadow: 0 18px 46px rgba(15,23,42,.18) !important;
  display: inline-flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0 !important;
  cursor: pointer !important;
  opacity: 0 !important;
  visibility: hidden !important;
  transform: translateY(12px) scale(.96) !important;
  transition: opacity .18s ease, visibility .18s ease, transform .18s ease, background .18s ease !important;
}

body.tf-ltu-fullscreen .tf-ltu-to-top.is-visible {
  opacity: 1 !important;
  visibility: visible !important;
  transform: translateY(0) scale(1) !important;
}

body.tf-ltu-fullscreen .tf-ltu-to-top:hover {
  background: #0b73ff !important;
  color: #fff !important;
}

body.tf-ltu-fullscreen .tf-ltu-to-top span {
  display: block !important;
  font-size: 22px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  margin-top: 2px !important;
}

body.tf-ltu-fullscreen .tf-ltu-to-top small {
  display: block !important;
  font-size: 9px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  letter-spacing: .06em !important;
}

/* Mobile: keep above bottom app nav */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-social-group {
    gap: 4px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-social-link {
    width: 25px !important;
    height: 25px !important;
    flex-basis: 25px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-social-link svg {
    width: 13px !important;
    height: 13px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-to-top {
    width: 48px !important;
    height: 48px !important;
    right: 14px !important;
    bottom: calc(86px + env(safe-area-inset-bottom)) !important;
    box-shadow: 0 12px 34px rgba(15,23,42,.16) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-to-top span {
    font-size: 19px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-to-top small {
    font-size: 8px !important;
  }
}


/* v0.4.3 - ToTop minimal white circle like reference */
body.tf-ltu-fullscreen .tf-ltu-to-top {
  width: 62px !important;
  height: 62px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(15,23,42,.04) !important;
  background: rgba(255,255,255,.98) !important;
  color: #4b5563 !important;
  box-shadow: 0 14px 36px rgba(15,23,42,.10) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
}

body.tf-ltu-fullscreen .tf-ltu-to-top:hover {
  background: #fff !important;
  color: #111827 !important;
  box-shadow: 0 18px 42px rgba(15,23,42,.14) !important;
  transform: translateY(-1px) scale(1) !important;
}

body.tf-ltu-fullscreen .tf-ltu-to-top span {
  position: relative !important;
  display: block !important;
  width: 24px !important;
  height: 26px !important;
  margin: 0 !important;
  font-size: 0 !important;
  line-height: 0 !important;
}

body.tf-ltu-fullscreen .tf-ltu-to-top span::before {
  content: "" !important;
  position: absolute !important;
  left: 50% !important;
  top: 4px !important;
  width: 17px !important;
  height: 17px !important;
  border-top: 3px solid currentColor !important;
  border-left: 3px solid currentColor !important;
  transform: translateX(-50%) rotate(45deg) !important;
  border-radius: 1px !important;
}

body.tf-ltu-fullscreen .tf-ltu-to-top span::after {
  content: "" !important;
  position: absolute !important;
  left: 50% !important;
  top: 6px !important;
  width: 3px !important;
  height: 25px !important;
  background: currentColor !important;
  transform: translateX(-50%) !important;
  border-radius: 999px !important;
}

body.tf-ltu-fullscreen .tf-ltu-to-top small {
  display: none !important;
}

/* Mobile: smaller but same visual, above bottom nav */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-to-top {
    width: 52px !important;
    height: 52px !important;
    right: 14px !important;
    bottom: calc(86px + env(safe-area-inset-bottom)) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-to-top span {
    width: 21px !important;
    height: 23px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-to-top span::before {
    width: 15px !important;
    height: 15px !important;
    border-top-width: 2.5px !important;
    border-left-width: 2.5px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-to-top span::after {
    width: 2.5px !important;
    height: 22px !important;
  }
}


/* v0.4.4 - Mobile ToTop moved into footer, replacing Contact Us */
@media (max-width: 768px) {
  /* hide floating ToTop on mobile because footer has it now */
  body.tf-ltu-fullscreen .tf-ltu-to-top {
    display: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-footer-mobile a.tf-ltu-footer-top span {
    font-size: 22px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    transform: translateY(-1px) !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-footer-mobile a.tf-ltu-footer-top small {
    letter-spacing: -.01em !important;
  }
}


/* v0.4.5 - Professional mobile footer wording for tour business */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-footer-mobile a small {
    font-size: 11px !important;
    line-height: 1.15 !important;
    font-weight: 700 !important;
    letter-spacing: -.01em !important;
    white-space: nowrap !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-footer-mobile a.is-active small {
    font-weight: 800 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-footer-mobile a span {
    margin-bottom: 3px !important;
  }
}


/* v0.4.6 - Apply mobile footer + ToTop site-wide outside shortcode pages */
.tf-ltu-global-ui {
  font-family: "Noto Sans Thai", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
}

/* Global mobile footer, same professional tour wording */
.tf-ltu-global-mobile-footer {
  display: none !important;
}

@media (max-width: 768px) {
  body:not(.tf-ltu-fullscreen) {
    padding-bottom: calc(72px + env(safe-area-inset-bottom)) !important;
  }

  .tf-ltu-global-mobile-footer {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    z-index: 1000000 !important;
    height: calc(64px + env(safe-area-inset-bottom)) !important;
    padding: 7px 8px calc(7px + env(safe-area-inset-bottom)) !important;
    background: rgba(255,255,255,.96) !important;
    border-top: 1px solid rgba(226,232,240,.95) !important;
    box-shadow: 0 -12px 32px rgba(15,23,42,.08) !important;
    backdrop-filter: blur(18px) !important;
    display: grid !important;
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    align-items: center !important;
    gap: 2px !important;
  }

  .tf-ltu-global-mobile-footer a {
    min-width: 0 !important;
    height: 50px !important;
    display: inline-flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 3px !important;
    color: #94a3b8 !important;
    text-decoration: none !important;
    border-radius: 14px !important;
    font-weight: 700 !important;
  }

  .tf-ltu-global-mobile-footer a span {
    display: block !important;
    font-size: 20px !important;
    line-height: 1 !important;
  }

  .tf-ltu-global-mobile-footer a small {
    display: block !important;
    font-size: 11px !important;
    line-height: 1.15 !important;
    font-weight: 700 !important;
    letter-spacing: -.01em !important;
    white-space: nowrap !important;
  }

  .tf-ltu-global-mobile-footer a.is-active {
    color: #0b73ff !important;
  }

  .tf-ltu-global-mobile-footer a.tf-ltu-footer-top span {
    font-size: 22px !important;
    font-weight: 900 !important;
    transform: translateY(-1px) !important;
  }
}

/* Global ToTop desktop */
.tf-ltu-global-to-top {
  position: fixed !important;
  right: max(22px, env(safe-area-inset-right)) !important;
  bottom: calc(26px + env(safe-area-inset-bottom)) !important;
  z-index: 1000001 !important;
  width: 62px !important;
  height: 62px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(15,23,42,.04) !important;
  background: rgba(255,255,255,.98) !important;
  color: #4b5563 !important;
  box-shadow: 0 14px 36px rgba(15,23,42,.10) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  cursor: pointer !important;
  opacity: 0 !important;
  visibility: hidden !important;
  transform: translateY(12px) scale(.96) !important;
  transition: opacity .18s ease, visibility .18s ease, transform .18s ease, background .18s ease !important;
}

.tf-ltu-global-to-top.is-visible {
  opacity: 1 !important;
  visibility: visible !important;
  transform: translateY(0) scale(1) !important;
}

.tf-ltu-global-to-top:hover {
  background: #fff !important;
  color: #111827 !important;
  box-shadow: 0 18px 42px rgba(15,23,42,.14) !important;
  transform: translateY(-1px) scale(1) !important;
}

.tf-ltu-global-to-top span {
  position: relative !important;
  display: block !important;
  width: 24px !important;
  height: 26px !important;
  margin: 0 !important;
  font-size: 0 !important;
  line-height: 0 !important;
}

.tf-ltu-global-to-top span::before {
  content: "" !important;
  position: absolute !important;
  left: 50% !important;
  top: 4px !important;
  width: 17px !important;
  height: 17px !important;
  border-top: 3px solid currentColor !important;
  border-left: 3px solid currentColor !important;
  transform: translateX(-50%) rotate(45deg) !important;
  border-radius: 1px !important;
}

.tf-ltu-global-to-top span::after {
  content: "" !important;
  position: absolute !important;
  left: 50% !important;
  top: 6px !important;
  width: 3px !important;
  height: 25px !important;
  background: currentColor !important;
  transform: translateX(-50%) !important;
  border-radius: 999px !important;
}

/* On mobile, ToTop is in footer so hide floating button globally */
@media (max-width: 768px) {
  .tf-ltu-global-to-top {
    display: none !important;
  }
}


/* v0.4.6.1 - remove benefit cards under hero */
body.tf-ltu-fullscreen .tf-ltu-hero-benefits,
body.tf-ltu-fullscreen .tf-ltu-benefit-card,
body.tf-ltu-fullscreen .tf-ltu-benefit-visual,
body.tf-ltu-fullscreen .tf-ltu-benefit-body,
body.tf-ltu-fullscreen .tf-ltu-benefit-arrow {
  display: none !important;
}

@media (min-width: 769px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-shell {
    margin-bottom: 72px !important;
  }
}

@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-hero-shell {
    margin-bottom: 52px !important;
  }
}


/* v0.4.6.4 - Free inline SVG icons for mobile footer, no Font Awesome/CDN dependency */
body.tf-ltu-fullscreen .tf-ltu-footer-mobile a .tf-ltu-footer-icon,
.tf-ltu-global-mobile-footer a .tf-ltu-footer-icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 22px !important;
  height: 22px !important;
  margin-bottom: 4px !important;
  color: currentColor !important;
  font-size: 0 !important;
  line-height: 0 !important;
}

body.tf-ltu-fullscreen .tf-ltu-footer-mobile a .tf-ltu-footer-icon svg,
.tf-ltu-global-mobile-footer a .tf-ltu-footer-icon svg {
  display: block !important;
  width: 22px !important;
  height: 22px !important;
  color: currentColor !important;
  stroke: currentColor !important;
  fill: none;
}

body.tf-ltu-fullscreen .tf-ltu-footer-mobile a.is-active .tf-ltu-footer-icon,
.tf-ltu-global-mobile-footer a.is-active .tf-ltu-footer-icon {
  color: #0b73ff !important;
}

body.tf-ltu-fullscreen .tf-ltu-footer-mobile a.tf-ltu-footer-top .tf-ltu-footer-icon,
.tf-ltu-global-mobile-footer a.tf-ltu-footer-top .tf-ltu-footer-icon {
  width: 23px !important;
  height: 23px !important;
}

body.tf-ltu-fullscreen .tf-ltu-footer-mobile a.tf-ltu-footer-top .tf-ltu-footer-icon svg,
.tf-ltu-global-mobile-footer a.tf-ltu-footer-top .tf-ltu-footer-icon svg {
  width: 23px !important;
  height: 23px !important;
}

/* block old raw text icon leak */
body.tf-ltu-fullscreen .tf-ltu-footer-mobile a span:not(.tf-ltu-footer-icon),
.tf-ltu-global-mobile-footer a span:not(.tf-ltu-footer-icon) {
  font-size: inherit !important;
}


/* v0.4.6.5 - hard fix global mobile footer on real server + desktop height comfort */

/* Make sure global UI never gets collapsed by theme/plugin CSS */
.tf-ltu-global-ui {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: none !important;
}

/* Global mobile footer must float above Tour Engine / theme UI */
@media (max-width: 768px) {
  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    z-index: 2147483000 !important;
    width: 100vw !important;
    max-width: 100vw !important;
    height: calc(66px + env(safe-area-inset-bottom)) !important;
    min-height: calc(66px + env(safe-area-inset-bottom)) !important;
    padding: 7px 8px calc(7px + env(safe-area-inset-bottom)) !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    display: grid !important;
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    align-items: center !important;
    justify-items: stretch !important;
    gap: 2px !important;
    background: rgba(255, 255, 255, .98) !important;
    border-top: 1px solid rgba(226, 232, 240, .95) !important;
    box-shadow: 0 -14px 36px rgba(15, 23, 42, .10) !important;
    backdrop-filter: blur(18px) !important;
    -webkit-backdrop-filter: blur(18px) !important;
    pointer-events: auto !important;
    transform: translateZ(0) !important;
  }

  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer a {
    min-width: 0 !important;
    width: auto !important;
    max-width: none !important;
    height: 52px !important;
    min-height: 52px !important;
    padding: 0 2px !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    display: inline-flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 2px !important;
    color: #94a3b8 !important;
    text-decoration: none !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 14px !important;
    font-family: "Noto Sans Thai", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
    line-height: 1 !important;
    pointer-events: auto !important;
  }

  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer a.is-active {
    color: #0b73ff !important;
  }

  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer a .tf-ltu-footer-icon {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 22px !important;
    height: 22px !important;
    margin: 0 0 3px !important;
    color: currentColor !important;
    font-size: 0 !important;
    line-height: 0 !important;
  }

  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer a .tf-ltu-footer-icon svg {
    width: 22px !important;
    height: 22px !important;
    display: block !important;
    stroke: currentColor !important;
  }

  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer a small {
    display: block !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    color: currentColor !important;
    font-size: 10.5px !important;
    line-height: 1.15 !important;
    font-weight: 800 !important;
    letter-spacing: -.02em !important;
  }

  /* Reserve space for the fixed bar on all real landing pages */
  html body:not(.tf-ltu-fullscreen) {
    padding-bottom: calc(78px + env(safe-area-inset-bottom)) !important;
  }

  html body:not(.tf-ltu-fullscreen) main,
  html body:not(.tf-ltu-fullscreen) .te-tour-page,
  html body:not(.tf-ltu-fullscreen) .te-trip-listing,
  html body:not(.tf-ltu-fullscreen) .tte-tour-page {
    padding-bottom: calc(78px + env(safe-area-inset-bottom)) !important;
  }

  /* Avoid duplicate floating top on mobile; footer has top button already */
  html body .tf-ltu-global-ui .tf-ltu-global-to-top,
  html body .tf-ltu-global-to-top {
    display: none !important;
  }

  /* If Tour Engine has its own ToTop floating button, keep it hidden on mobile to avoid conflict */
  html body #tteToTop,
  html body .tte-to-top,
  html body .te-to-top {
    display: none !important;
  }
}

/* Desktop pages on real server looked too short/compressed. Give content and listing a more comfortable first screen. */
@media (min-width: 769px) {
  html body:not(.tf-ltu-fullscreen) .tf-ltu-global-to-top {
    display: inline-flex !important;
  }

  html body:not(.tf-ltu-fullscreen) .te-tour-page,
  html body:not(.tf-ltu-fullscreen) .te-trip-listing,
  html body:not(.tf-ltu-fullscreen) main.te-trip-listing {
    min-height: calc(100vh - 80px) !important;
  }

  html body:not(.tf-ltu-fullscreen) .te-trip-listing,
  html body:not(.tf-ltu-fullscreen) .te-tour-page {
    padding-bottom: 72px !important;
  }

  html body:not(.tf-ltu-fullscreen) .te-product-card,
  html body:not(.tf-ltu-fullscreen) .te-tour-card,
  html body:not(.tf-ltu-fullscreen) .tte-product-card {
    min-height: 260px;
  }
}


/* v0.4.6.6 - widen Tour Engine landing/listing pages on desktop
   Fix: real server desktop layout looked too narrow.
   Keep mobile untouched except existing footer behavior.
*/
@media (min-width: 1025px) {
  /* Header inner width */
  html body:not(.tf-ltu-fullscreen) .tt-site-header,
  html body:not(.tf-ltu-fullscreen) .tte-site-header,
  html body:not(.tf-ltu-fullscreen) .te-site-header {
    width: 100% !important;
  }

  html body:not(.tf-ltu-fullscreen) .tt-site-header > *,
  html body:not(.tf-ltu-fullscreen) .tte-site-header > *,
  html body:not(.tf-ltu-fullscreen) .te-site-header > *,
  html body:not(.tf-ltu-fullscreen) .tt-header-inner,
  html body:not(.tf-ltu-fullscreen) .tte-header-inner,
  html body:not(.tf-ltu-fullscreen) .te-header-inner {
    max-width: min(1560px, calc(100vw - 96px)) !important;
    width: min(1560px, calc(100vw - 96px)) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  /* Main listing/page container */
  html body:not(.tf-ltu-fullscreen) main.te-trip-listing,
  html body:not(.tf-ltu-fullscreen) main.te-tour-page,
  html body:not(.tf-ltu-fullscreen) .te-trip-listing,
  html body:not(.tf-ltu-fullscreen) .te-tour-page,
  html body:not(.tf-ltu-fullscreen) .tte-trip-listing,
  html body:not(.tf-ltu-fullscreen) .tte-tour-page,
  html body:not(.tf-ltu-fullscreen) .te-listing-wrap,
  html body:not(.tf-ltu-fullscreen) .tte-listing-wrap {
    max-width: min(1560px, calc(100vw - 96px)) !important;
    width: min(1560px, calc(100vw - 96px)) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  /* Common inner containers used by the old landing theme */
  html body:not(.tf-ltu-fullscreen) .te-container,
  html body:not(.tf-ltu-fullscreen) .tte-container,
  html body:not(.tf-ltu-fullscreen) .te-page-container,
  html body:not(.tf-ltu-fullscreen) .tte-page-container,
  html body:not(.tf-ltu-fullscreen) .te-content-container,
  html body:not(.tf-ltu-fullscreen) .tte-content-container {
    max-width: min(1560px, calc(100vw - 96px)) !important;
    width: 100% !important;
  }

  /* Listing grid should breathe wider */
  html body:not(.tf-ltu-fullscreen) .te-layout,
  html body:not(.tf-ltu-fullscreen) .tte-layout,
  html body:not(.tf-ltu-fullscreen) .te-listing-layout,
  html body:not(.tf-ltu-fullscreen) .tte-listing-layout {
    display: grid !important;
    grid-template-columns: minmax(260px, 300px) minmax(0, 1fr) !important;
    gap: 28px !important;
    max-width: min(1560px, calc(100vw - 96px)) !important;
    width: 100% !important;
  }

  /* Product area/card grid: allow 4 cards/large comfortable cards if template uses grid */
  html body:not(.tf-ltu-fullscreen) .te-products,
  html body:not(.tf-ltu-fullscreen) .tte-products,
  html body:not(.tf-ltu-fullscreen) .te-product-grid,
  html body:not(.tf-ltu-fullscreen) .tte-product-grid,
  html body:not(.tf-ltu-fullscreen) .te-tour-grid,
  html body:not(.tf-ltu-fullscreen) .tte-tour-grid {
    width: 100% !important;
    max-width: none !important;
  }

  /* Card row image/text proportion should not feel compressed */
  html body:not(.tf-ltu-fullscreen) .te-product-card,
  html body:not(.tf-ltu-fullscreen) .te-tour-card,
  html body:not(.tf-ltu-fullscreen) .tte-product-card,
  html body:not(.tf-ltu-fullscreen) .tte-tour-card {
    width: 100% !important;
  }

  html body:not(.tf-ltu-fullscreen) .te-product-card img,
  html body:not(.tf-ltu-fullscreen) .te-tour-card img,
  html body:not(.tf-ltu-fullscreen) .tte-product-card img,
  html body:not(.tf-ltu-fullscreen) .tte-tour-card img {
    max-width: 100% !important;
  }
}

/* Medium desktop/laptop */
@media (min-width: 769px) and (max-width: 1280px) {
  html body:not(.tf-ltu-fullscreen) .tt-site-header > *,
  html body:not(.tf-ltu-fullscreen) .tte-site-header > *,
  html body:not(.tf-ltu-fullscreen) .te-site-header > *,
  html body:not(.tf-ltu-fullscreen) .tt-header-inner,
  html body:not(.tf-ltu-fullscreen) .tte-header-inner,
  html body:not(.tf-ltu-fullscreen) .te-header-inner,
  html body:not(.tf-ltu-fullscreen) main.te-trip-listing,
  html body:not(.tf-ltu-fullscreen) main.te-tour-page,
  html body:not(.tf-ltu-fullscreen) .te-trip-listing,
  html body:not(.tf-ltu-fullscreen) .te-tour-page,
  html body:not(.tf-ltu-fullscreen) .tte-trip-listing,
  html body:not(.tf-ltu-fullscreen) .tte-tour-page,
  html body:not(.tf-ltu-fullscreen) .te-listing-wrap,
  html body:not(.tf-ltu-fullscreen) .tte-listing-wrap {
    max-width: calc(100vw - 48px) !important;
    width: calc(100vw - 48px) !important;
  }

  html body:not(.tf-ltu-fullscreen) .te-layout,
  html body:not(.tf-ltu-fullscreen) .tte-layout,
  html body:not(.tf-ltu-fullscreen) .te-listing-layout,
  html body:not(.tf-ltu-fullscreen) .tte-listing-layout {
    grid-template-columns: minmax(240px, 280px) minmax(0, 1fr) !important;
    gap: 24px !important;
  }
}

/* Ultra-wide: cap at 1640 so it does not become too stretched */
@media (min-width: 1680px) {
  html body:not(.tf-ltu-fullscreen) .tt-site-header > *,
  html body:not(.tf-ltu-fullscreen) .tte-site-header > *,
  html body:not(.tf-ltu-fullscreen) .te-site-header > *,
  html body:not(.tf-ltu-fullscreen) .tt-header-inner,
  html body:not(.tf-ltu-fullscreen) .tte-header-inner,
  html body:not(.tf-ltu-fullscreen) .te-header-inner,
  html body:not(.tf-ltu-fullscreen) main.te-trip-listing,
  html body:not(.tf-ltu-fullscreen) main.te-tour-page,
  html body:not(.tf-ltu-fullscreen) .te-trip-listing,
  html body:not(.tf-ltu-fullscreen) .te-tour-page,
  html body:not(.tf-ltu-fullscreen) .tte-trip-listing,
  html body:not(.tf-ltu-fullscreen) .tte-tour-page,
  html body:not(.tf-ltu-fullscreen) .te-listing-wrap,
  html body:not(.tf-ltu-fullscreen) .tte-listing-wrap {
    max-width: 1640px !important;
    width: 1640px !important;
  }
}


/* v0.4.6.7 - Desktop: remove header search and move menu into its place */
@media (min-width: 769px) {
  /* Hide the search box only on desktop */
  body.tf-ltu-fullscreen .tf-ltu-search,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-search {
    display: none !important;
  }

  /* Make the top header become: Logo | Menu | Social/Menu actions */
  body.tf-ltu-fullscreen .tf-ltu-header-top,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-header-top {
    display: grid !important;
    grid-template-columns: auto minmax(0, 1fr) auto !important;
    align-items: center !important;
    column-gap: 34px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-logo,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-logo {
    grid-column: 1 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-actions,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-actions {
    grid-column: 3 !important;
    justify-self: end !important;
  }

  /* Pull desktop mega menu up into the header search position */
  body.tf-ltu-fullscreen .tf-ltu-real-mega-nav,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-nav {
    position: absolute !important;
    top: 0 !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    height: 78px !important;
    width: min(760px, calc(100vw - 620px)) !important;
    min-width: 560px !important;
    max-width: 820px !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    z-index: 5 !important;
    pointer-events: none !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-real-mega-row,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row {
    height: 78px !important;
    min-height: 78px !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: clamp(22px, 2.2vw, 38px) !important;
    pointer-events: auto !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-item,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-mega-item {
    height: 78px !important;
    display: flex !important;
    align-items: center !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-trigger,
  body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-header-link,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-mega-trigger,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-header-link {
    height: 78px !important;
    display: inline-flex !important;
    align-items: center !important;
    color: #0f172a !important;
    font-size: 16px !important;
    font-weight: 900 !important;
    text-decoration: none !important;
    white-space: nowrap !important;
  }

  /* No second nav row on desktop: header itself is the menu */
  body.tf-ltu-fullscreen .tf-ltu-header,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-header {
    height: 82px !important;
    min-height: 82px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-header-top,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-header-top {
    height: 82px !important;
    min-height: 82px !important;
  }

  /* content should start higher because second menu row is removed */
  body.tf-ltu-fullscreen .tf-ltu-main {
    inset: 82px 0 0 0 !important;
  }

  html body:not(.tf-ltu-fullscreen) .te-trip-listing,
  html body:not(.tf-ltu-fullscreen) .te-tour-page,
  html body:not(.tf-ltu-fullscreen) main.te-trip-listing,
  html body:not(.tf-ltu-fullscreen) main.te-tour-page {
    margin-top: 0 !important;
  }

  /* Mega dropdowns must still open under the compact header */
  body.tf-ltu-fullscreen .tte-mega-panel,
  html body:not(.tf-ltu-fullscreen) .tte-mega-panel {
    top: 78px !important;
  }
}

/* Laptop: if space is tight, reduce menu and social spacing */
@media (min-width: 769px) and (max-width: 1280px) {
  body.tf-ltu-fullscreen .tf-ltu-real-mega-nav,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-nav {
    width: min(640px, calc(100vw - 520px)) !important;
    min-width: 500px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-real-mega-row,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row {
    gap: 22px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-mega-trigger,
  body.tf-ltu-fullscreen .tf-ltu-real-mega-row .tte-header-link,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-mega-trigger,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-header-link {
    font-size: 15px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-actions.tf-ltu-social-actions,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-actions.tf-ltu-social-actions {
    min-width: 285px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-social-link,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-social-link {
    width: 31px !important;
    height: 31px !important;
    flex-basis: 31px !important;
  }
}

/* Mobile keeps search/menu behavior as-is */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-search,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-search {
    display: flex !important;
  }
}


/* v0.4.6.8 - Mobile footer bar above real mobile browser toolbar / Tour Engine overlays */
@media (max-width: 768px) {
  /* Reserve more space because iOS/Chrome mobile browser toolbar can cover fixed bottom UI */
  html body:not(.tf-ltu-fullscreen) {
    padding-bottom: calc(150px + env(safe-area-inset-bottom)) !important;
  }

  html body:not(.tf-ltu-fullscreen) main,
  html body:not(.tf-ltu-fullscreen) .te-tour-page,
  html body:not(.tf-ltu-fullscreen) .te-trip-listing,
  html body:not(.tf-ltu-fullscreen) .tte-tour-page,
  html body:not(.tf-ltu-fullscreen) .te-mobile-filter-bar,
  html body:not(.tf-ltu-fullscreen) .te-listing-wrap {
    padding-bottom: calc(150px + env(safe-area-inset-bottom)) !important;
  }

  /* Force our global footer to float ABOVE the browser bottom toolbar */
  html body .tf-ltu-global-ui {
    position: relative !important;
    z-index: 2147483600 !important;
    pointer-events: none !important;
  }

  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer {
    position: fixed !important;
    left: 12px !important;
    right: 12px !important;
    bottom: calc(74px + env(safe-area-inset-bottom)) !important;
    z-index: 2147483646 !important;
    width: auto !important;
    max-width: calc(100vw - 24px) !important;
    height: 64px !important;
    min-height: 64px !important;
    padding: 7px 8px !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    display: grid !important;
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    align-items: center !important;
    gap: 2px !important;
    background: rgba(255,255,255,.985) !important;
    border: 1px solid rgba(226,232,240,.96) !important;
    border-radius: 22px !important;
    box-shadow: 0 18px 50px rgba(15,23,42,.18) !important;
    backdrop-filter: blur(18px) !important;
    -webkit-backdrop-filter: blur(18px) !important;
    pointer-events: auto !important;
    transform: translate3d(0,0,0) !important;
    opacity: 1 !important;
    visibility: visible !important;
  }

  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer a {
    height: 50px !important;
    min-height: 50px !important;
    padding: 0 2px !important;
    color: #94a3b8 !important;
    text-decoration: none !important;
    background: transparent !important;
    border: 0 !important;
    display: inline-flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 2px !important;
    font-family: "Noto Sans Thai", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
    pointer-events: auto !important;
  }

  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer a.is-active {
    color: #0b73ff !important;
  }

  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer a .tf-ltu-footer-icon {
    width: 22px !important;
    height: 22px !important;
    margin: 0 0 3px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: currentColor !important;
    font-size: 0 !important;
    line-height: 0 !important;
  }

  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer a .tf-ltu-footer-icon svg {
    width: 22px !important;
    height: 22px !important;
    display: block !important;
    color: currentColor !important;
    stroke: currentColor !important;
  }

  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer a small {
    display: block !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    color: currentColor !important;
    font-size: 10.5px !important;
    line-height: 1.15 !important;
    font-weight: 800 !important;
    letter-spacing: -.02em !important;
  }

  /* Hide Tour Engine / theme competing fixed bars when they occupy bottom */
  html body #tteToTop,
  html body .tte-to-top,
  html body .te-to-top,
  html body .te-mobile-bottom-bar,
  html body .tte-mobile-bottom-bar,
  html body .te-sticky-bottom,
  html body .tte-sticky-bottom {
    display: none !important;
  }
}

/* When browser toolbar is hidden and viewport is tall, drop the bar closer to the bottom */
@media (max-width: 768px) and (min-height: 760px) {
  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer {
    bottom: calc(54px + env(safe-area-inset-bottom)) !important;
  }
}

/* Short mobile screens need even more bottom clearance */
@media (max-width: 768px) and (max-height: 700px) {
  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer {
    bottom: calc(82px + env(safe-area-inset-bottom)) !important;
  }
}


/* v0.4.6.9 - remove header search on every device */

/* Hide search everywhere: desktop, tablet, mobile, app shell, global landing */
body.tf-ltu-fullscreen .tf-ltu-search,
html body:not(.tf-ltu-fullscreen) .tf-ltu-search,
body.tf-ltu-fullscreen .tf-ltu-header-search,
html body:not(.tf-ltu-fullscreen) .tf-ltu-header-search {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Mobile header: logo left, social/menu actions right */
@media (max-width: 768px) {
  body.tf-ltu-fullscreen .tf-ltu-header-top,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-header-top {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-logo,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-logo {
    flex: 0 0 auto !important;
    min-width: 0 !important;
  }

  body.tf-ltu-fullscreen .tf-ltu-actions,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-actions {
    flex: 0 0 auto !important;
    margin-left: auto !important;
  }

  /* since search is gone, reduce empty header area */
  body.tf-ltu-fullscreen .tf-ltu-header-top,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-header-top {
    min-height: 72px !important;
    height: 72px !important;
  }

  /* Mobile tabs move up naturally under header */
  body.tf-ltu-fullscreen .tf-ltu-mobile-tabs,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-mobile-tabs {
    margin-top: 0 !important;
  }

  /* App page main starts a bit higher because search row is gone */
  body.tf-ltu-fullscreen .tf-ltu-main {
    top: 124px !important;
    inset: 124px 0 calc(72px + env(safe-area-inset-bottom)) 0 !important;
  }
}

/* Desktop keeps previous behavior: menu is in the search position */
@media (min-width: 769px) {
  body.tf-ltu-fullscreen .tf-ltu-search,
  html body:not(.tf-ltu-fullscreen) .tf-ltu-search {
    display: none !important;
  }
}


/* v0.4.6.10 - iPhone/Chrome footer visibility fix
   The issue is not only global footer; the shortcode app footer also sits behind the mobile browser toolbar.
   Move BOTH footer types upward and make them floating pills.
*/
@media (max-width: 768px) {
  :root {
    --tf-ltu-mobile-browser-bar: 82px;
    --tf-ltu-mobile-footer-height: 64px;
  }

  /* App homepage footer + global footer on other pages */
  html body.tf-ltu-fullscreen .tf-ltu-footer-mobile,
  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer {
    position: fixed !important;
    left: 12px !important;
    right: 12px !important;
    bottom: calc(var(--tf-ltu-mobile-browser-bar) + env(safe-area-inset-bottom)) !important;
    z-index: 2147483646 !important;
    width: auto !important;
    max-width: calc(100vw - 24px) !important;
    height: var(--tf-ltu-mobile-footer-height) !important;
    min-height: var(--tf-ltu-mobile-footer-height) !important;
    padding: 7px 8px !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    display: grid !important;
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    align-items: center !important;
    gap: 2px !important;
    background: rgba(255,255,255,.985) !important;
    border: 1px solid rgba(226,232,240,.96) !important;
    border-radius: 22px !important;
    box-shadow: 0 18px 50px rgba(15,23,42,.18) !important;
    backdrop-filter: blur(18px) !important;
    -webkit-backdrop-filter: blur(18px) !important;
    pointer-events: auto !important;
    opacity: 1 !important;
    visibility: visible !important;
    transform: translate3d(0,0,0) !important;
  }

  html body.tf-ltu-fullscreen .tf-ltu-footer-mobile a,
  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer a {
    height: 50px !important;
    min-height: 50px !important;
    display: inline-flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 2px !important;
    color: #94a3b8 !important;
    text-decoration: none !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 14px !important;
    font-family: "Noto Sans Thai", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  }

  html body.tf-ltu-fullscreen .tf-ltu-footer-mobile a.is-active,
  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer a.is-active {
    color: #0b73ff !important;
  }

  html body.tf-ltu-fullscreen .tf-ltu-footer-mobile a .tf-ltu-footer-icon,
  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer a .tf-ltu-footer-icon {
    width: 22px !important;
    height: 22px !important;
    margin: 0 0 3px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: currentColor !important;
    font-size: 0 !important;
    line-height: 0 !important;
  }

  html body.tf-ltu-fullscreen .tf-ltu-footer-mobile a .tf-ltu-footer-icon svg,
  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer a .tf-ltu-footer-icon svg {
    width: 22px !important;
    height: 22px !important;
    display: block !important;
    color: currentColor !important;
    stroke: currentColor !important;
  }

  html body.tf-ltu-fullscreen .tf-ltu-footer-mobile a small,
  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer a small {
    display: block !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    color: currentColor !important;
    font-size: 10.5px !important;
    line-height: 1.15 !important;
    font-weight: 800 !important;
    letter-spacing: -.02em !important;
  }

  /* Give the scroll content enough bottom space so the floating footer never covers the last cards */
  html body.tf-ltu-fullscreen .tf-ltu-main {
    bottom: 0 !important;
    padding-bottom: calc(var(--tf-ltu-mobile-browser-bar) + var(--tf-ltu-mobile-footer-height) + 34px + env(safe-area-inset-bottom)) !important;
  }

  html body:not(.tf-ltu-fullscreen) {
    padding-bottom: calc(var(--tf-ltu-mobile-browser-bar) + var(--tf-ltu-mobile-footer-height) + 34px + env(safe-area-inset-bottom)) !important;
  }

  html body:not(.tf-ltu-fullscreen) main,
  html body:not(.tf-ltu-fullscreen) .te-tour-page,
  html body:not(.tf-ltu-fullscreen) .te-trip-listing,
  html body:not(.tf-ltu-fullscreen) .tte-tour-page,
  html body:not(.tf-ltu-fullscreen) .te-listing-wrap {
    padding-bottom: calc(var(--tf-ltu-mobile-browser-bar) + var(--tf-ltu-mobile-footer-height) + 34px + env(safe-area-inset-bottom)) !important;
  }

  /* Hide all floating top buttons on mobile because footer contains ขึ้นบน */
  html body .tf-ltu-to-top,
  html body .tf-ltu-global-to-top,
  html body #tteToTop,
  html body .tte-to-top,
  html body .te-to-top {
    display: none !important;
  }
}

/* Very short screens or browsers with a large visible toolbar */
@media (max-width: 768px) and (max-height: 720px) {
  :root {
    --tf-ltu-mobile-browser-bar: 92px;
  }
}

/* When browser toolbar is collapsed, keep it less high but still safe */
@media (max-width: 768px) and (min-height: 820px) {
  :root {
    --tf-ltu-mobile-browser-bar: 64px;
  }
}


/* v0.4.6.11 - Mobile footer must be fixed bottom, not floating pill */
@media (max-width: 768px) {
  :root {
    --tf-ltu-mobile-footer-height: 68px;
  }

  /* App homepage footer + global footer: true fixed bottom bar */
  html body.tf-ltu-fullscreen .tf-ltu-footer-mobile,
  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    z-index: 2147483646 !important;
    width: 100vw !important;
    max-width: 100vw !important;
    height: calc(var(--tf-ltu-mobile-footer-height) + env(safe-area-inset-bottom)) !important;
    min-height: calc(var(--tf-ltu-mobile-footer-height) + env(safe-area-inset-bottom)) !important;
    padding: 7px 8px calc(7px + env(safe-area-inset-bottom)) !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    display: grid !important;
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    align-items: center !important;
    justify-items: stretch !important;
    gap: 2px !important;
    background: rgba(255,255,255,.985) !important;
    border-top: 1px solid rgba(226,232,240,.96) !important;
    border-left: 0 !important;
    border-right: 0 !important;
    border-bottom: 0 !important;
    border-radius: 0 !important;
    box-shadow: 0 -12px 34px rgba(15,23,42,.10) !important;
    backdrop-filter: blur(18px) !important;
    -webkit-backdrop-filter: blur(18px) !important;
    pointer-events: auto !important;
    opacity: 1 !important;
    visibility: visible !important;
    transform: translate3d(0,0,0) !important;
  }

  html body.tf-ltu-fullscreen .tf-ltu-footer-mobile a,
  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer a {
    height: 52px !important;
    min-height: 52px !important;
    padding: 0 2px !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    display: inline-flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 2px !important;
    color: #94a3b8 !important;
    text-decoration: none !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 14px !important;
    font-family: "Noto Sans Thai", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  }

  html body.tf-ltu-fullscreen .tf-ltu-footer-mobile a.is-active,
  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer a.is-active {
    color: #0b73ff !important;
  }

  html body.tf-ltu-fullscreen .tf-ltu-footer-mobile a .tf-ltu-footer-icon,
  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer a .tf-ltu-footer-icon {
    width: 22px !important;
    height: 22px !important;
    margin: 0 0 3px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: currentColor !important;
    font-size: 0 !important;
    line-height: 0 !important;
  }

  html body.tf-ltu-fullscreen .tf-ltu-footer-mobile a .tf-ltu-footer-icon svg,
  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer a .tf-ltu-footer-icon svg {
    width: 22px !important;
    height: 22px !important;
    display: block !important;
    color: currentColor !important;
    stroke: currentColor !important;
  }

  html body.tf-ltu-fullscreen .tf-ltu-footer-mobile a small,
  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer a small {
    display: block !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    color: currentColor !important;
    font-size: 10.5px !important;
    line-height: 1.15 !important;
    font-weight: 800 !important;
    letter-spacing: -.02em !important;
  }

  /* Content reserve: enough for fixed bottom footer, not floating gap */
  html body.tf-ltu-fullscreen .tf-ltu-main {
    bottom: 0 !important;
    padding-bottom: calc(var(--tf-ltu-mobile-footer-height) + 22px + env(safe-area-inset-bottom)) !important;
  }

  html body:not(.tf-ltu-fullscreen) {
    padding-bottom: calc(var(--tf-ltu-mobile-footer-height) + 22px + env(safe-area-inset-bottom)) !important;
  }

  html body:not(.tf-ltu-fullscreen) main,
  html body:not(.tf-ltu-fullscreen) .te-tour-page,
  html body:not(.tf-ltu-fullscreen) .te-trip-listing,
  html body:not(.tf-ltu-fullscreen) .tte-tour-page,
  html body:not(.tf-ltu-fullscreen) .te-listing-wrap {
    padding-bottom: calc(var(--tf-ltu-mobile-footer-height) + 22px + env(safe-area-inset-bottom)) !important;
  }

  /* No floating top buttons on mobile */
  html body .tf-ltu-to-top,
  html body .tf-ltu-global-to-top,
  html body #tteToTop,
  html body .tte-to-top,
  html body .te-to-top {
    display: none !important;
  }
}


/* v0.4.6.13 - Global-safe compatibility with ThaiFly Tour Engine
   Goal: use LINE Today UI site-wide without turning every page into fullscreen app mode. */
body:not(.tf-ltu-fullscreen) .tf-ltu-global-ui {
  display: block !important;
}

/* LINE Today owns the site-wide ToTop, so hide Tour Engine's duplicate button on all non-fullscreen pages. */
body:not(.tf-ltu-fullscreen) #tteToTop,
body:not(.tf-ltu-fullscreen) .tte-to-top {
  display: none !important;
}

/* Make plugin-rendered policy/static pages keep footer at the real bottom when content is short. */
body.tte-standalone-page:not(.tf-ltu-fullscreen),
body.tte-plugin-page-hard:not(.tf-ltu-fullscreen) {
  min-height: 100vh !important;
}

body.tte-plugin-page-hard:not(.tf-ltu-fullscreen) > main,
body.tte-standalone-page:not(.tf-ltu-fullscreen) > main {
  min-height: calc(100vh - 260px) !important;
}

@media (max-width: 768px) {
  body.tte-plugin-page-hard:not(.tf-ltu-fullscreen) > main,
  body.tte-standalone-page:not(.tf-ltu-fullscreen) > main {
    min-height: calc(100vh - 220px) !important;
  }
}

/* v0.4.6.14 - Tour landing compatibility: put Filter/Sort in LINE Today footer */
@media (max-width: 768px) {
  html.tf-ltu-tour-listing-actions body .tte-mobile-filter-bar:not(.tte-mobile-sheet):not(#tteMobileFilterSheet),
  html.tf-ltu-tour-listing-actions body .tte-floating-filter-bar:not(.tte-mobile-sheet):not(#tteMobileFilterSheet),
  html.tf-ltu-tour-listing-actions body .tte-mobile-filter-float:not(.tte-mobile-sheet):not(#tteMobileFilterSheet) {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }

  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer.tf-ltu-tour-listing-footer {
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
    padding-left: 4px !important;
    padding-right: 4px !important;
  }

  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer > button,
  html body.tf-ltu-fullscreen .tf-ltu-footer-mobile > button {
    appearance: none !important;
    -webkit-appearance: none !important;
    height: 52px !important;
    min-height: 52px !important;
    padding: 0 2px !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    display: inline-flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 2px !important;
    color: #94a3b8 !important;
    text-decoration: none !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 14px !important;
    font-family: "Noto Sans Thai", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
    cursor: pointer !important;
    box-shadow: none !important;
  }

  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer > button.is-active,
  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer > button.tf-ltu-footer-filter,
  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer > button.tf-ltu-footer-sort {
    color: #0b73ff !important;
  }

  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer > button .tf-ltu-footer-icon {
    width: 22px !important;
    height: 22px !important;
    margin: 0 0 3px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: currentColor !important;
    font-size: 0 !important;
    line-height: 0 !important;
  }

  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer > button .tf-ltu-footer-icon svg {
    width: 22px !important;
    height: 22px !important;
    display: block !important;
    color: currentColor !important;
    stroke: currentColor !important;
  }

  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer > button small {
    display: block !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    color: currentColor !important;
    font-size: 10px !important;
    line-height: 1.1 !important;
    font-weight: 800 !important;
    letter-spacing: -.02em !important;
  }

  html.tf-ltu-tour-listing-actions body:not(.tf-ltu-fullscreen) main,
  html.tf-ltu-tour-listing-actions body:not(.tf-ltu-fullscreen) .tte-tour-page,
  html.tf-ltu-tour-listing-actions body:not(.tf-ltu-fullscreen) .tte-listing-page,
  html.tf-ltu-tour-listing-actions body:not(.tf-ltu-fullscreen) .tte-trip-listing,
  html.tf-ltu-tour-listing-actions body:not(.tf-ltu-fullscreen) .te-tour-page,
  html.tf-ltu-tour-listing-actions body:not(.tf-ltu-fullscreen) .te-listing-wrap {
    padding-bottom: calc(var(--tf-ltu-mobile-footer-height, 68px) + 28px + env(safe-area-inset-bottom)) !important;
  }
}


/* v0.4.6.15 - Desktop ToTop hard fix
   The global UI wrapper intentionally has pointer-events:none to avoid blocking the page.
   The floating ToTop button must opt back in, otherwise desktop clicks pass through it. */
html body .tf-ltu-global-ui .tf-ltu-global-to-top,
html body .tf-ltu-global-to-top,
html body button.tf-ltu-global-to-top,
html body .tf-ltu-to-top.tf-ltu-global-to-top {
  pointer-events: auto !important;
  touch-action: manipulation !important;
  z-index: 2147483646 !important;
}

@media (min-width: 769px) {
  html body:not(.tf-ltu-fullscreen) .tf-ltu-global-ui {
    position: relative !important;
    z-index: 2147483600 !important;
    pointer-events: none !important;
  }

  html body:not(.tf-ltu-fullscreen) .tf-ltu-global-ui .tf-ltu-global-to-top {
    display: inline-flex !important;
    position: fixed !important;
    right: max(22px, env(safe-area-inset-right)) !important;
    bottom: calc(26px + env(safe-area-inset-bottom)) !important;
    pointer-events: auto !important;
  }
}

/* v0.4.6.16 - Site-wide LINE Today header + footer shell
   Use the LINE Today header/footer on every non-home page without forcing fullscreen app mode. */
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) {
  --tf-ltu-global-header-height: 126px;
  padding-top: var(--tf-ltu-global-header-height) !important;
  background: #ffffff !important;
  overflow-x: hidden !important;
}

body.admin-bar.tf-ltu-global-shell:not(.tf-ltu-fullscreen) {
  --tf-ltu-global-header-admin-offset: 32px;
}

/* Hide the WordPress/theme shell header/footer only; keep content headers inside articles untouched. */
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) #masthead,
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .site-header,
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .wp-site-blocks > header,
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) > header:not(.tf-ltu-header),
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) #colophon,
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .site-footer,
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .wp-site-blocks > footer,
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) > footer:not(.tf-ltu-footer):not(.tf-ltu-desktop-footer) {
  display: none !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-global-header-wrap,
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-global-desktop-footer-wrap {
  font-family: "Noto Sans Thai", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-global-header-wrap .tf-ltu-header {
  position: fixed !important;
  left: 0 !important;
  right: 0 !important;
  top: 0 !important;
  z-index: 2147483000 !important;
  overflow: visible !important;
  background: rgba(255,255,255,.98) !important;
  border-bottom: 1px solid rgba(226,232,240,.95) !important;
  box-shadow: 0 10px 32px rgba(15,23,42,.06) !important;
}

body.admin-bar.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-global-header-wrap .tf-ltu-header {
  top: 32px !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-header-top {
  height: 72px !important;
  max-width: 1180px !important;
  margin: 0 auto !important;
  padding: 0 22px !important;
  display: flex !important;
  align-items: center !important;
  gap: 22px !important;
  box-sizing: border-box !important;
}

/* Logo */
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-logo-brand {
  display: inline-flex !important;
  align-items: center !important;
  gap: 14px !important;
  color: #101c2d !important;
  text-decoration: none !important;
  min-width: 0 !important;
  font-size: 0 !important;
  letter-spacing: 0 !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-logo-mark {
  width: 52px !important;
  height: 52px !important;
  flex: 0 0 52px !important;
  border-radius: 16px !important;
  background: linear-gradient(135deg, #0877f2 0%, #16a5ff 100%) !important;
  color: #fff !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 20px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  letter-spacing: .02em !important;
  box-shadow: 0 14px 26px rgba(8,119,242,.18) !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-logo-text {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  min-width: 0 !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-logo-text strong {
  display: block !important;
  color: #111827 !important;
  font-size: 28px !important;
  line-height: .95 !important;
  font-weight: 900 !important;
  letter-spacing: .01em !important;
  white-space: nowrap !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-logo-text small {
  display: block !important;
  margin-top: 8px !important;
  color: #667085 !important;
  font-size: 13px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  letter-spacing: .23em !important;
  white-space: nowrap !important;
}

/* Search + social */
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-search {
  flex: 1 1 auto !important;
  max-width: 520px !important;
  margin: 0 auto !important;
  position: relative !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-search input {
  width: 100% !important;
  height: 42px !important;
  border: 0 !important;
  outline: none !important;
  border-radius: 999px !important;
  background: #f2f3f5 !important;
  padding: 0 48px 0 22px !important;
  color: #111827 !important;
  font-size: 15px !important;
  box-shadow: none !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-search button {
  position: absolute !important;
  right: 6px !important;
  top: 5px !important;
  width: 32px !important;
  height: 32px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: transparent !important;
  color: #60646c !important;
  cursor: pointer !important;
  box-shadow: none !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-actions.tf-ltu-social-actions {
  min-width: 336px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 16px !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-social-group {
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-social-link {
  width: 34px !important;
  height: 34px !important;
  flex: 0 0 34px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-decoration: none !important;
  background: rgba(255,255,255,.94) !important;
  border: 1px solid rgba(216,228,245,.95) !important;
  color: #475569 !important;
  box-shadow: 0 8px 22px rgba(15,23,42,.06) !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-social-link svg {
  width: 16px !important;
  height: 16px !important;
  display: block !important;
  fill: currentColor !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-social-link span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 11px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-menu-link {
  width: auto !important;
  min-width: 44px !important;
  padding: 0 10px !important;
  gap: 6px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #111827 !important;
  text-decoration: none !important;
  border-radius: 999px !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-action-separator {
  width: 1px !important;
  height: 28px !important;
  background: rgba(148,163,184,.34) !important;
}

/* Desktop mega nav */
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-tabs a::after,
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-tab-item > a::after,
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tte-mega-trigger::after,
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tte-header-link::after {
  display: none !important;
  content: none !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-nav {
  display: block !important;
  height: 54px !important;
  overflow: visible !important;
  background: rgba(255,255,255,.98) !important;
  border-top: 1px solid rgba(226,232,240,.72) !important;
  border-bottom: 1px solid rgba(226,232,240,.9) !important;
  box-shadow: 0 10px 30px rgba(6,27,51,.04) !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row {
  width: min(1180px, calc(100vw - 64px)) !important;
  max-width: none !important;
  height: 54px !important;
  min-height: 54px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 42px !important;
  overflow: visible !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-mega-item {
  position: static !important;
  height: 54px !important;
  display: flex !important;
  align-items: center !important;
  flex: 0 0 auto !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-mega-trigger,
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-header-link {
  height: 54px !important;
  display: inline-flex !important;
  align-items: center !important;
  position: relative !important;
  padding: 0 !important;
  color: #0f2238 !important;
  text-decoration: none !important;
  font-size: 17px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  border: 0 !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-mega-trigger:hover,
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-header-link:hover {
  color: #0798e8 !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-mega-item:hover > .tte-mega-trigger::before,
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-mega-item:hover > .tte-header-link::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  bottom: -1px !important;
  height: 4px !important;
  border-radius: 999px 999px 0 0 !important;
  background: #10c8e8 !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-mega-panel {
  position: absolute !important;
  top: 54px !important;
  left: 50% !important;
  right: auto !important;
  z-index: 2147483001 !important;
  transform: translateX(-50%) translateY(10px) !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  transition: opacity .18s ease, transform .18s ease, visibility .18s ease !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-mega-item:hover > .tte-mega-panel,
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-mega-item:focus-within > .tte-mega-panel {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: translateX(-50%) translateY(0) !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-mega-panel-country {
  width: min(1040px, calc(100vw - 64px)) !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-mega-panel-city {
  width: min(760px, calc(100vw - 64px)) !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-country-mega-wrap,
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-city-mega-wrap {
  background: rgba(255,255,255,.985) !important;
  border: 1px solid #e5eaf2 !important;
  box-shadow: 0 26px 70px rgba(15,23,42,.16) !important;
  backdrop-filter: blur(18px) !important;
  border-radius: 24px !important;
  overflow: hidden !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-country-mega-wrap {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 0 !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-city-mega-wrap {
  display: block !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-country-col,
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-city-col-main {
  padding: 24px 30px 26px !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-country-col + .tte-country-col {
  border-left: 1px solid #e5eaf2 !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-country-col h3,
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-city-col-main h3 {
  margin: 0 0 18px !important;
  padding-bottom: 12px !important;
  border-bottom: 1px solid #e5eaf2 !important;
  color: #071116 !important;
  font-size: 20px !important;
  font-weight: 900 !important;
  line-height: 1.25 !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-country-list {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 9px 14px !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-country-menu-link {
  min-height: 38px !important;
  padding: 7px 9px !important;
  display: flex !important;
  align-items: center !important;
  gap: 9px !important;
  border-radius: 12px !important;
  color: #0f2238 !important;
  text-decoration: none !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  line-height: 1.25 !important;
  white-space: nowrap !important;
  min-width: 0 !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-country-menu-link:hover {
  background: #f4fbfb !important;
  color: #007f7a !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-country-flag {
  width: 22px !important;
  height: 22px !important;
  flex: 0 0 22px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 16px !important;
}

/* Global desktop footer */
body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-global-desktop-footer-wrap {
  width: 100% !important;
  position: relative !important;
  z-index: 1 !important;
  pointer-events: auto !important;
  background: #ffffff !important;
}

body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-global-desktop-footer-wrap .tf-ltu-footer-mobile {
  display: none !important;
}

@media (min-width: 769px) {
  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-global-ui .tf-ltu-global-mobile-footer {
    display: none !important;
  }

  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-global-desktop-footer-wrap .tf-ltu-desktop-footer {
    display: block !important;
    width: 100% !important;
    margin: 70px 0 0 !important;
    padding: 0 0 42px !important;
    color: #ffffff !important;
    font-family: "Noto Sans Thai", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  }
}

/* Global mobile header */
@media (max-width: 768px) {
  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) {
    --tf-ltu-global-header-height: 126px;
    padding-top: var(--tf-ltu-global-header-height) !important;
  }

  body.admin-bar.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-global-header-wrap .tf-ltu-header {
    top: 46px !important;
  }

  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-header-top {
    height: 74px !important;
    padding: 0 14px !important;
    gap: 10px !important;
  }

  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-logo-brand {
    gap: 10px !important;
  }

  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-logo-mark {
    width: 42px !important;
    height: 42px !important;
    flex-basis: 42px !important;
    border-radius: 13px !important;
    font-size: 16px !important;
  }

  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-logo-text strong {
    font-size: 22px !important;
  }

  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-logo-text small {
    margin-top: 6px !important;
    font-size: 10px !important;
    letter-spacing: .22em !important;
  }

  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-search {
    display: none !important;
  }

  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-actions.tf-ltu-social-actions {
    min-width: 0 !important;
    margin-left: auto !important;
    gap: 8px !important;
  }

  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-social-group {
    gap: 5px !important;
  }

  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-social-link {
    width: 28px !important;
    height: 28px !important;
    flex-basis: 28px !important;
    box-shadow: none !important;
    background: transparent !important;
    border-color: transparent !important;
    color: #0a84ff !important;
  }

  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-social-link svg {
    width: 14px !important;
    height: 14px !important;
  }

  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-social-link span {
    font-size: 9px !important;
  }

  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-action-separator,
  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-menu-text {
    display: none !important;
  }

  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-nav {
    display: none !important;
  }

  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-mobile-tabs {
    display: block !important;
    width: 100% !important;
    height: 52px !important;
    border-top: 1px solid #f1f2f4 !important;
    border-bottom: 1px solid #e9edf2 !important;
    background: rgba(255,255,255,.98) !important;
    overflow: hidden !important;
  }

  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-mobile-tabs-scroll {
    width: 100% !important;
    height: 52px !important;
    padding: 0 12px !important;
    display: flex !important;
    align-items: center !important;
    gap: 26px !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    white-space: nowrap !important;
    scrollbar-width: none !important;
    -webkit-overflow-scrolling: touch !important;
  }

  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-mobile-tabs-scroll::-webkit-scrollbar {
    display: none !important;
  }

  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-mobile-tabs-scroll a,
  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-mobile-more {
    position: relative !important;
    flex: 0 0 auto !important;
    height: 52px !important;
    display: inline-flex !important;
    align-items: center !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    color: #9ca3af !important;
    text-decoration: none !important;
    font-size: 17px !important;
    line-height: 1 !important;
    font-weight: 800 !important;
    white-space: nowrap !important;
  }

  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-mobile-tabs-scroll a:hover,
  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-mobile-tabs-scroll a.is-active {
    color: #111827 !important;
  }

  body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-global-desktop-footer-wrap {
    display: none !important;
  }
}


/* v0.4.6.17 - Hard dock mobile footer to the real viewport bottom
   Fixes /tour mobile footer floating/moving during scroll on iPhone/Chrome. */
@media (max-width: 768px) {
  html,
  body {
    overflow-x: hidden !important;
  }

  html body:not(.tf-ltu-fullscreen) {
    padding-bottom: calc(86px + env(safe-area-inset-bottom)) !important;
  }

  html body:not(.tf-ltu-fullscreen) main,
  html body:not(.tf-ltu-fullscreen) .te-tour-page,
  html body:not(.tf-ltu-fullscreen) .te-trip-listing,
  html body:not(.tf-ltu-fullscreen) .tte-tour-page,
  html body:not(.tf-ltu-fullscreen) .tte-listing-page,
  html body:not(.tf-ltu-fullscreen) .te-listing-wrap,
  html body:not(.tf-ltu-fullscreen) .tte-trip-listing {
    padding-bottom: calc(96px + env(safe-area-inset-bottom)) !important;
  }

  /* Keep the wrapper harmless. Do not let older rules move it upward. */
  html body .tf-ltu-global-ui {
    position: static !important;
    inset: auto !important;
    width: auto !important;
    height: auto !important;
    min-height: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: visible !important;
    transform: none !important;
    translate: none !important;
    pointer-events: none !important;
    z-index: auto !important;
  }

  /* True fixed bottom bar, full width, no floating pill, no browser-toolbar offset. */
  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer,
  html body .tf-ltu-global-mobile-footer,
  html body.tf-ltu-fullscreen .tf-ltu-footer-mobile {
    position: fixed !important;
    top: auto !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100vw !important;
    max-width: 100vw !important;
    height: calc(72px + env(safe-area-inset-bottom)) !important;
    min-height: calc(72px + env(safe-area-inset-bottom)) !important;
    padding: 8px 6px calc(8px + env(safe-area-inset-bottom)) !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    display: grid !important;
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    align-items: center !important;
    justify-items: stretch !important;
    gap: 0 !important;
    background: rgba(255,255,255,.985) !important;
    border-top: 1px solid rgba(226,232,240,.96) !important;
    border-left: 0 !important;
    border-right: 0 !important;
    border-bottom: 0 !important;
    border-radius: 0 !important;
    box-shadow: 0 -12px 34px rgba(15,23,42,.10) !important;
    backdrop-filter: blur(18px) !important;
    -webkit-backdrop-filter: blur(18px) !important;
    transform: none !important;
    translate: none !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    z-index: 2147483646 !important;
    contain: layout style paint !important;
  }

  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer.tf-ltu-tour-listing-footer {
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
    padding-left: 2px !important;
    padding-right: 2px !important;
  }

  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer a,
  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer button,
  html body.tf-ltu-fullscreen .tf-ltu-footer-mobile a,
  html body.tf-ltu-fullscreen .tf-ltu-footer-mobile button {
    min-width: 0 !important;
    width: auto !important;
    max-width: none !important;
    height: 54px !important;
    min-height: 54px !important;
    padding: 0 1px !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    display: inline-flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 2px !important;
    color: #94a3b8 !important;
    text-decoration: none !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 14px !important;
    box-shadow: none !important;
    font-family: "Noto Sans Thai", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
    line-height: 1 !important;
    pointer-events: auto !important;
  }

  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer a.is-active,
  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer button.is-active,
  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer button.tf-ltu-footer-filter,
  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer button.tf-ltu-footer-sort {
    color: #0b73ff !important;
  }

  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer .tf-ltu-footer-icon,
  html body.tf-ltu-fullscreen .tf-ltu-footer-mobile .tf-ltu-footer-icon {
    width: 23px !important;
    height: 23px !important;
    margin: 0 0 3px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: currentColor !important;
    font-size: 0 !important;
    line-height: 0 !important;
  }

  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer .tf-ltu-footer-icon svg,
  html body.tf-ltu-fullscreen .tf-ltu-footer-mobile .tf-ltu-footer-icon svg {
    width: 23px !important;
    height: 23px !important;
    display: block !important;
    color: currentColor !important;
    stroke: currentColor !important;
  }

  html body .tf-ltu-global-ui .tf-ltu-global-mobile-footer small,
  html body.tf-ltu-fullscreen .tf-ltu-footer-mobile small {
    display: block !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    color: currentColor !important;
    font-size: 10px !important;
    line-height: 1.12 !important;
    font-weight: 800 !important;
    letter-spacing: -.03em !important;
  }

  html body .tf-ltu-to-top,
  html body .tf-ltu-global-to-top,
  html body #tteToTop,
  html body .tte-to-top,
  html body .te-to-top {
    display: none !important;
  }
}


/* v0.4.6.18 - Site-wide desktop header parity fix
   Make Tour/Landing/Policy pages use the same LINE Today header geometry as the homepage. */
@media (min-width: 769px) {
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) {
    --tf-ltu-global-header-height: 94px !important;
    padding-top: var(--tf-ltu-global-header-height) !important;
  }

  /* Hide Tour Engine / theme header clones so only LINE Today header remains. */
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) #masthead,
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .site-header,
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .wp-site-blocks > header,
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tt-site-header,
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tte-site-header,
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .te-site-header,
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) header.tte-site-header,
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) header.te-site-header {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    min-height: 0 !important;
    overflow: hidden !important;
  }

  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-global-header-wrap .tf-ltu-header {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    width: 100vw !important;
    height: 94px !important;
    min-height: 94px !important;
    z-index: 2147483000 !important;
    overflow: visible !important;
    background: rgba(255,255,255,.985) !important;
    border-bottom: 1px solid rgba(226,232,240,.95) !important;
    box-shadow: 0 10px 32px rgba(15,23,42,.06) !important;
  }

  html body.admin-bar.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-global-header-wrap .tf-ltu-header {
    top: 32px !important;
  }

  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-header-top {
    width: min(1570px, calc(100vw - 288px)) !important;
    max-width: none !important;
    min-width: 0 !important;
    height: 94px !important;
    min-height: 94px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding: 0 !important;
    display: grid !important;
    grid-template-columns: auto minmax(0, 1fr) auto !important;
    align-items: center !important;
    column-gap: 34px !important;
    box-sizing: border-box !important;
    position: relative !important;
  }

  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-logo-brand,
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-logo {
    grid-column: 1 !important;
    justify-self: start !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 16px !important;
    text-decoration: none !important;
    color: #101828 !important;
  }

  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-logo-mark {
    width: 58px !important;
    height: 58px !important;
    flex: 0 0 58px !important;
    border-radius: 18px !important;
    font-size: 21px !important;
    font-weight: 900 !important;
    letter-spacing: .02em !important;
    background: linear-gradient(135deg, #0877f2 0%, #16a5ff 100%) !important;
    color: #fff !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-logo-text strong {
    font-size: 32px !important;
    line-height: .95 !important;
    font-weight: 900 !important;
    color: #111827 !important;
    letter-spacing: .005em !important;
  }

  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-logo-text small {
    margin-top: 9px !important;
    font-size: 13px !important;
    line-height: 1 !important;
    letter-spacing: .30em !important;
    font-weight: 900 !important;
    color: #667085 !important;
  }

  /* Header search is removed site-wide; menu takes this space. */
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-search {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }

  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-actions,
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-actions.tf-ltu-social-actions {
    grid-column: 3 !important;
    justify-self: end !important;
    min-width: 336px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 16px !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }

  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-social-group {
    display: inline-flex !important;
    align-items: center !important;
    gap: 7px !important;
  }

  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-social-link {
    width: 34px !important;
    height: 34px !important;
    flex: 0 0 34px !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: rgba(255,255,255,.96) !important;
    border: 1px solid rgba(216,228,245,.95) !important;
    color: #475569 !important;
    text-decoration: none !important;
    box-shadow: 0 8px 22px rgba(15,23,42,.06) !important;
  }

  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-social-link svg {
    width: 16px !important;
    height: 16px !important;
    display: block !important;
    fill: currentColor !important;
  }

  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-action-separator {
    width: 1px !important;
    height: 28px !important;
    background: rgba(148,163,184,.34) !important;
    display: inline-block !important;
  }

  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-menu-link {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    min-width: 44px !important;
    padding: 0 10px !important;
    color: #111827 !important;
    text-decoration: none !important;
    font-size: 16px !important;
    font-weight: 900 !important;
    border-radius: 999px !important;
  }

  /* Compact desktop mega menu: same as homepage, no second blue/white row. */
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-nav {
    position: absolute !important;
    top: 0 !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    width: min(760px, calc(100vw - 620px)) !important;
    min-width: 560px !important;
    max-width: 820px !important;
    height: 94px !important;
    min-height: 94px !important;
    z-index: 5 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: visible !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
  }

  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row {
    width: 100% !important;
    max-width: none !important;
    height: 94px !important;
    min-height: 94px !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 42px !important;
    overflow: visible !important;
  }

  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-mega-item {
    position: static !important;
    height: 94px !important;
    display: flex !important;
    align-items: center !important;
    flex: 0 0 auto !important;
  }

  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-mega-trigger,
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-header-link {
    height: 94px !important;
    display: inline-flex !important;
    align-items: center !important;
    padding: 0 !important;
    border: 0 !important;
    color: #0f2238 !important;
    text-decoration: none !important;
    font-size: 17px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    white-space: nowrap !important;
  }

  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-mega-panel {
    top: 94px !important;
  }
}

@media (min-width: 769px) and (max-width: 1540px) {
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-header-top {
    width: min(1360px, calc(100vw - 96px)) !important;
  }

  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-nav {
    width: min(650px, calc(100vw - 560px)) !important;
    min-width: 500px !important;
  }

  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row {
    gap: 24px !important;
  }

  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-mega-trigger,
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-real-mega-row .tte-header-link {
    font-size: 15px !important;
  }
}


/* v0.4.6.19 - Mobile footer hard dock for Tour Engine pages
   Problem: /tour routes may print the desktop-footer mobile nav in document flow.
   Fix: only the global dock footer is allowed on mobile global shell pages. */
@media (max-width: 768px) {
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) {
    padding-bottom: calc(86px + env(safe-area-inset-bottom)) !important;
  }

  /* The global UI layer itself must never take document-flow space. */
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) > .tf-ltu-global-ui,
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-global-ui {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    top: auto !important;
    bottom: 0 !important;
    width: 100vw !important;
    height: 0 !important;
    min-height: 0 !important;
    max-height: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: visible !important;
    transform: none !important;
    translate: none !important;
    pointer-events: none !important;
    z-index: 2147483646 !important;
    contain: none !important;
  }

  /* Hide the duplicate mobile footer that is inside the desktop footer markup. */
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-global-desktop-footer-wrap .tf-ltu-footer-mobile,
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) footer.tf-ltu-footer-mobile:not(.tf-ltu-global-mobile-footer),
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-desktop-footer .tf-ltu-footer-mobile {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
    position: static !important;
    width: 0 !important;
    height: 0 !important;
    min-height: 0 !important;
    max-height: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: hidden !important;
  }

  /* The real footer dock. This is the only visible mobile footer. */
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-global-ui > .tf-ltu-global-mobile-footer,
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) body > .tf-ltu-global-ui > .tf-ltu-global-mobile-footer,
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-global-mobile-footer {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    top: auto !important;
    bottom: 0 !important;
    width: 100vw !important;
    max-width: 100vw !important;
    height: calc(72px + env(safe-area-inset-bottom)) !important;
    min-height: calc(72px + env(safe-area-inset-bottom)) !important;
    max-height: calc(72px + env(safe-area-inset-bottom)) !important;
    padding: 8px 6px calc(8px + env(safe-area-inset-bottom)) !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    display: grid !important;
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    align-items: center !important;
    justify-items: stretch !important;
    gap: 0 !important;
    background: rgba(255,255,255,.985) !important;
    border-top: 1px solid rgba(226,232,240,.96) !important;
    border-radius: 0 !important;
    box-shadow: 0 -12px 34px rgba(15,23,42,.10) !important;
    backdrop-filter: blur(18px) !important;
    -webkit-backdrop-filter: blur(18px) !important;
    transform: translate3d(0,0,0) !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    z-index: 2147483647 !important;
  }

  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-global-mobile-footer.tf-ltu-tour-listing-footer {
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  }

  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-global-mobile-footer > a,
  html body.tf-ltu-global-shell:not(.tf-ltu-fullscreen) .tf-ltu-global-mobile-footer > button {
    position: relative !important;
    z-index: 1 !important;
    pointer-events: auto !important;
  }
}


/* v0.4.6.25 - Bootstrap .container style content box for Tour Engine pages
   Requirement: /tour, /tour/{country}, and tour detail use the same predictable
   content width as Bootstrap .container instead of custom full-screen widths. */
:root {
  --tf-ltu-bs-container: 100%;
  --tf-ltu-bs-gutter-x: 24px;
}

@media (min-width: 576px) {
  :root { --tf-ltu-bs-container: 540px; }
}

@media (min-width: 768px) {
  :root { --tf-ltu-bs-container: 720px; }
}

@media (min-width: 992px) {
  :root { --tf-ltu-bs-container: 960px; }
}

@media (min-width: 1200px) {
  :root { --tf-ltu-bs-container: 1140px; }
}

@media (min-width: 1400px) {
  :root { --tf-ltu-bs-container: 1320px; }
}

/* Apply only to Tour Engine pages rendered under the LINE Today global shell. */
body.tf-ltu-global-shell.tf-ltu-tour-page-context .tte-container,
body.tf-ltu-global-shell.tf-ltu-tour-page-context .container,
body.tf-ltu-global-shell.tf-ltu-tour-page-context .wp-site-blocks > main > .tte-container,
body.tf-ltu-global-shell.tf-ltu-tour-page-context .tte-listing-hero > .tte-container,
body.tf-ltu-global-shell.tf-ltu-tour-page-context .tte-listing-section > .tte-container,
body.tf-ltu-global-shell.tf-ltu-tour-page-context .tte-detail-breadcrumb-section > .tte-container,
body.tf-ltu-global-shell.tf-ltu-tour-page-context .tte-detail-hero > .tte-container,
body.tf-ltu-global-shell.tf-ltu-tour-page-context .tte-tour-detail-page > .tte-container,
body.tf-ltu-global-shell.tf-ltu-tour-page-context .tte-page > .tte-container {
  width: 100% !important;
  max-width: var(--tf-ltu-bs-container) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: calc(var(--tf-ltu-bs-gutter-x) * .5) !important;
  padding-right: calc(var(--tf-ltu-bs-gutter-x) * .5) !important;
  box-sizing: border-box !important;
}

/* Sections can still paint full-width background, but their content is boxed. */
body.tf-ltu-global-shell.tf-ltu-tour-page-context .tte-listing-hero,
body.tf-ltu-global-shell.tf-ltu-tour-page-context .tte-listing-hero-cover,
body.tf-ltu-global-shell.tf-ltu-tour-page-context .tte-listing-section,
body.tf-ltu-global-shell.tf-ltu-tour-page-context .tte-detail-breadcrumb-section,
body.tf-ltu-global-shell.tf-ltu-tour-page-context .tte-detail-hero,
body.tf-ltu-global-shell.tf-ltu-tour-page-context .tte-section,
body.tf-ltu-global-shell.tf-ltu-tour-page-context .tte-section-soft,
body.tf-ltu-global-shell.tf-ltu-tour-page-context .tte-seo-block,
body.tf-ltu-global-shell.tf-ltu-tour-page-context .tte-trust-section {
  width: 100% !important;
  max-width: none !important;
  box-sizing: border-box !important;
}

/* Listing page: keep filter + result in one full Bootstrap container. */
@media (min-width: 992px) {
  body.tf-ltu-global-shell.tf-ltu-tour-listing-context .tte-listing-layout {
    width: 100% !important;
    max-width: 100% !important;
    display: grid !important;
    grid-template-columns: minmax(280px, 320px) minmax(0, 1fr) !important;
    gap: 28px !important;
    align-items: start !important;
    box-sizing: border-box !important;
  }

  body.tf-ltu-global-shell.tf-ltu-tour-listing-context .tte-listing-sidebar,
  body.tf-ltu-global-shell.tf-ltu-tour-listing-context .tte-filter-sidebar {
    width: 100% !important;
    max-width: 320px !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  body.tf-ltu-global-shell.tf-ltu-tour-listing-context .tte-listing-results,
  body.tf-ltu-global-shell.tf-ltu-tour-listing-context .tte-trip-result-shell,
  body.tf-ltu-global-shell.tf-ltu-tour-listing-context .tte-results,
  body.tf-ltu-global-shell.tf-ltu-tour-listing-context .tte-results-wrap {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  body.tf-ltu-global-shell.tf-ltu-tour-listing-context .tte-trip-card,
  body.tf-ltu-global-shell.tf-ltu-tour-listing-context .tte-tour-card,
  body.tf-ltu-global-shell.tf-ltu-tour-listing-context .tte-result-card {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
}

/* Detail page: hero + detail content follow the same Bootstrap container width. */
@media (min-width: 992px) {
  body.tf-ltu-global-shell.tf-ltu-tour-detail-context .tte-detail-grid {
    width: 100% !important;
    max-width: var(--tf-ltu-bs-container) !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1.08fr) minmax(360px, .92fr) !important;
    gap: 36px !important;
    align-items: center !important;
    box-sizing: border-box !important;
  }

  body.tf-ltu-global-shell.tf-ltu-tour-detail-context .tte-detail-layout {
    width: 100% !important;
    max-width: var(--tf-ltu-bs-container) !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 340px !important;
    gap: 28px !important;
    align-items: start !important;
    box-sizing: border-box !important;
  }

  body.tf-ltu-global-shell.tf-ltu-tour-detail-context .tte-cover,
  body.tf-ltu-global-shell.tf-ltu-tour-detail-context .tte-detail-copy,
  body.tf-ltu-global-shell.tf-ltu-tour-detail-context .tte-main-content,
  body.tf-ltu-global-shell.tf-ltu-tour-detail-context .tte-side-card,
  body.tf-ltu-global-shell.tf-ltu-tour-detail-context .tte-side-card-share {
    min-width: 0 !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  body.tf-ltu-global-shell.tf-ltu-tour-detail-context .tte-detail-cover-media,
  body.tf-ltu-global-shell.tf-ltu-tour-detail-context .tte-cover img,
  body.tf-ltu-global-shell.tf-ltu-tour-detail-context .tte-detail-cover-media img {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    box-sizing: border-box !important;
  }
}

/* Tablet/mobile keep natural 100% width and avoid horizontal overflow. */
@media (max-width: 991.98px) {
  body.tf-ltu-global-shell.tf-ltu-tour-page-context .tte-container,
  body.tf-ltu-global-shell.tf-ltu-tour-page-context .container {
    max-width: 100% !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  body.tf-ltu-global-shell.tf-ltu-tour-page-context .tte-listing-layout,
  body.tf-ltu-global-shell.tf-ltu-tour-page-context .tte-detail-grid,
  body.tf-ltu-global-shell.tf-ltu-tour-page-context .tte-detail-layout {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }
}
