:root {
    /* ===========================
       BRAND COLORS
    ============================ */

    /* Main Brand Colors */
/* ==========================================================================
     1. GLOBAL PRIMITIVE TOKENS (The Raw Palette)
     ========================================================================== */
  --color-green-base:       #1F4D43; /* Premium Green */
  --color-green-alt:        #244E46; /* Alternative Premium Green */
  
  --color-gold-base:        #C8A063; /* Sand Gold */
  --color-gold-alt:         #D4B07B; /* Alternative Sand Gold */
  
  --color-cream-base:       #F7F4EE; /* Main Cream / Beige Background */
  --color-cream-alt:        #F5F1EA; /* Alternative Background */
  --color-cream-light:      #FCFBF8; /* Off-white Card Background */
  
  --color-neutral-dark:     #2C2C2C; /* Premium Dark Text */
  --color-neutral-muted:    #6B6B6B; /* Secondary Text */

  /* ==========================================================================
     2. SEMANTIC TOKENS (Functional Mapping)
     ========================================================================== */
  
  /* --- Brand & Accents --- */
  --color-primary:          var(--color-green-base);
  --color-primary-hover:    var(--color-green-alt);
  --color-accent:           var(--color-gold-base);
  --color-accent-hover:     var(--color-gold-alt);

  /* --- Backgrounds --- */
  --bg-main:                var(--color-cream-base);
  --bg-surface:             var(--color-cream-alt);
  --bg-card:                var(--color-cream-light);

  /* --- Typography --- */
  --text-main:              var(--color-neutral-dark);
  --text-muted:             var(--color-neutral-muted);
  --text-on-primary:        var(--color-cream-light);
  --text-on-accent:         var(--color-neutral-dark);

  /* --- Interactive Components (CTAs & Buttons) --- */
  --cta-bg:                 var(--color-primary);
  --cta-bg-hover:           var(--color-primary-hover);
  --cta-text:               var(--text-on-primary);
  
  --cta-alt-bg:             var(--color-accent);
  --cta-alt-bg-hover:       var(--color-accent-hover);
  --cta-alt-text:           var(--text-on-accent);

  /* --- Borders & Dividers --- */
  --border-color-subtle:    var(--color-cream-alt);
  --border-color-focus:     var(--color-gold-base);

  /* Fonts used */
  --font-inter: "Inter", sans-serif;

    /* Base Scale Ratio: 1.25 (Major Third) */
    /* Min Width: 400px | Max Width: 1440px */

    --fs-p:  clamp(0.875rem, 0.85rem + 0.125vw, 1rem);
    --fs-h6: clamp(1.05rem, 1.02rem + 0.15vw, 1.125rem);
    --fs-h5: clamp(1.15rem, 1.1rem + 0.25vw, 1.25rem);
    --fs-h4: clamp(1.3rem, 1.2rem + 0.5vw, 1.5rem);
    --fs-h3: clamp(1.5rem, 1.35rem + 0.75vw, 1.875rem);
    --fs-h2: clamp(1.85rem, 1.6rem + 1.25vw, 2.375rem);
    --fs-h1: clamp(2.25rem, 1.8rem + 2vw, 3rem);

    --lh-tight:1.1;
    --lh-snug:1.25;
    --lh-base: 1.45;
    --lh-loose: 1.6;

    /* Fluid Section Padding */
    /* Mobile: 60px | Desktop: 120px */
    --section-spacing-y: clamp(3.75rem, 2.5rem + 5vw, 7.5rem);
    
    /* Extra Large Spacing (for Hero or visual breaks) */
    /* Mobile: 80px | Desktop: 160px */
    --section-spacing-xl: clamp(5rem, 3rem + 8vw, 10rem);

    /* Container Horizontal Padding */
    --container-gap: clamp(1.25rem, 5vw, 2.5rem);

    /* Base Indent / Small Spacing */
    --space-xs: 1.5rem;   /* 24px - Your horizontal indent base */
    
    /* Medium Spacing (Element gaps) */
    --space-s:  2rem;     /* 32px - Between headline and text */
    --space-m:  3rem;     /* 48px - Between text and buttons */
    
    /* Large Spacing (Inner section components) */
    --space-l:  4rem;     /* 64px - Padding inside large cards */
    
    /* Extra Large (Section padding / Hero gaps) */
    --space-xl: 5rem;     /* 80px - Minimal section vertical padding */

    /* Bonus: Fluid Section Gap (Mobile: 3rem -> Desktop: 5rem) */
    --space-section: clamp(3rem, 5vw, 5rem);
}

.my-logo a {
  display: flex;
}

.my-logo svg {
  color: var(--color-primary);
  height: 50px;
  width: auto;
  transition: color 0.3s ease;
}

.my-logo:hover svg {
  color: var(--color-accent);
}

@media (max-width: 1024px) {
  .my-logo svg {
    height: 40px;
  }
}

/* benefits-section */
.benefits-section {
    padding-block: calc(var(--space-l) - 1.25rem);
}

/* property section */

.featured-properties-section {
    padding-block: var(--space-l);
}

.property-main-section {
    padding-top: 6rem;
    padding-bottom: 4rem;
}

/* Benefit Icon CSS */
.benefit-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
}

.benefit-card {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: 1.25rem;
    padding: 1.25rem;
}

.benefit-card__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 80px;
    height: 80px;
    border-radius: 50%;
    border: 1px solid var(--color-gold-alt,#D4B07B);
    color: var(--color-gold-base, #C8A063);
}

.benefit-card__icon svg {
    width: 40px;
    height: 40px;
    fill: currentColor;
}

.benefit-card__content {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.benefit-card__title {
    font-size: var(--fs-h4);
    font-weight: 600;
    color: var(--color-neutral-dark, #2C2C2C);
    margin: 0;
}

.benefit-card__text {
    font-size: var(--fs-p);
    color: var(--color-neutral-dark, #2C2C2C);
    margin: 0;
}

.benefit-card__link,
a.benefit-card__link {
    color: var(--color-gold-base, #C8A063);
    text-decoration: none;
    font-size: calculate(var(--fs-p) * 0.85);
    margin-top: 0;
}

.benefit-card__link:hover,
a.benefit-card__link:hover {
    color: var(--color-neutral-dark, #2C2C2C);
}

@media (max-width: 600px) {
    .benefit-cards {
        grid-template-columns: 1fr;
    }
}

/* lifestyle-section css */
/* ==========================================================================
   Lifestyle Section - Clean Responsive Layout (Stacked at 1280px & Below)
   ========================================================================== */

/* 1. Mobile, Tablet & Small Laptop Setup (Stacked View - Up to 1280px) */
.lifestyle-section .vc_column-inner > .wpb_wrapper {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
}

/* Image on TOP */
.lifestyle-media-inner-wrapper {
    background-image: url('/wp-content/uploads/2026/05/Escape-invest-enjoy-in-Thailand-01.jpg');
    background-size: cover;
    background-position: 65% center;
    background-repeat: no-repeat;
    width: 100%;
    height: 380px;
    order: 1;
}

/* Content on BOTTOM with Fluid Responsive Padding */
.lifestyle-content-inner-wrapper {
    background-color: var(--color-green-base, #1F4D43);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    padding: clamp(2.5rem, 5vw, 5rem) clamp(2rem, 5vw, 5rem);
    box-sizing: border-box;
    order: 2;
}

/* Typography Base Styles */
.lifestyle-section-title,
.lifestyle-section-tagline {
    color: var(--color-cream-base, #F7F4EE);
    line-height: 1.45;
    width: 100%;
}

.lifestyle-section-tagline {
    font-size: var(--fs-p);
}


/* 2. Desktop & Standard Laptop Split View (1281px and up) */
@media (min-width: 1281px) {
    
    .lifestyle-section .vc_column-inner > .wpb_wrapper {
        grid-template-columns: 40% 60%;
        min-height: 650px;
        align-items: stretch;
    }

    .lifestyle-media-inner-wrapper {
        height: 100%;
        background-position: center center;
        order: unset;
    }

    .lifestyle-content-inner-wrapper {
        order: unset;
    }
}

/* partner-section css */
.partner-section {
    padding-block: var(--space-l);
}

/* footer css */


.main-footer-section {
    background: var(--color-gold-alt, #D4B07B);
    padding-block: var(--space-m);
    color: var(--color-green-base, #1F4D43);
}

.main-footer-inner-wrapper {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
}

@media (min-width: 1025px) {
    .main-footer-inner-wrapper {
        display: grid;
        grid-template-columns: 1fr 1fr 1fr 1fr;
        gap: 2.5rem;
    }
}

.bottom-footer-section {
    background: var(--color-green-base, #1F4D43);
    padding-block: 0.5rem;
}

.bottom-footer-section .vc_column-inner > .wpb_wrapper {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 3rem;
        align-content: center;
        align-items: center;
}

.footer-copyright {
    font-family: var(--font-inter);
    font-weight: 400;
    font-size: calc(var(--fs-p) * 0.85);
    font-optical-sizing: auto;
    color: var(--color-gold-base);
}

.trusted-by-section {
    padding-block: var(--space-m);
}

.trusted-by-section-title {
    text-align: center;
}

.trusted-by-section-tagline {
    text-align: center;
    font-family: var(--font-inter);
    font-weight: 400;
    font-size: calc(var(--fs-p) * 0.85);
    font-optical-sizing: auto;
    color: var(--color-gold-base);
}

/* general hero section css */
/* ============================================================
   HERO SECTION — Reusable Component
   
   Usage: Add class "hero-section" to any WPBakery row.
   Background images are auto-injected per page via PHP snippet
   using the page's featured image (2560×1707px master).
   ============================================================ */

.hero-section {
    --hero-img-mobile:  none;
    --hero-img-laptop:  none;
    --hero-img-desktop: none;

    width: 100%;
    background-image: var(--hero-img-mobile);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: right center;
    aspect-ratio: 3 / 4;
    min-height: 500px;
}

@media (min-width: 1025px) {
    .hero-section {
        background-image: 
            linear-gradient(to right, rgba(26, 54, 54, 0.5) 0%, rgba(26, 54, 54, 0.1) 50%, transparent 100%), 
            var(--hero-img-laptop);
        background-position: center center;
        aspect-ratio: 16 / 9;
        min-height: auto;
    }
}

@media (min-width: 1381px) {
    .hero-section {
        background-image: 
            linear-gradient(to right, rgba(26, 54, 54, 0.5) 0%, rgba(26, 54, 54, 0.1) 50%, transparent 100%), 
            var(--hero-img-desktop);
        background-position: center center;
        aspect-ratio: 21 / 9;
    }
}

/* ==========================================================================
   Full Height Inherit & Vertical Alignment Fix
   ========================================================================== */

.hero-section,
.hero-section > .l-section-h,
.hero-section .g-cols,
.hero-section .vc_column-container,
.hero-section .vc_column-inner {
    height: 100%;
    min-height: inherit;
}

.hero-section .vc_column-inner > .wpb_wrapper {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0rem;
    box-sizing: border-box;
    height: 100%;
    align-content: end;
    padding-top: 0rem;
    padding-left: 0rem;
    padding-right: 0rem;
    padding-bottom: 4rem;
}

@media (max-width: 1024px) {
    .hero-section .hero-cta-inner-wrapper {
        display: flex !important;
        flex-direction: column !important;
        width: 100%;
        gap: 0.8rem;
    }

    .hero-section .hero-cta-inner-wrapper .w-btn-wrapper,
    .hero-section .hero-cta-inner-wrapper .w-btn {
        width: auto !important;
        display: inline-block;
        text-align: left;
        margin-bottom: 0 !important;
    }
}

@media (min-width: 1025px) {
    .hero-section .vc_column-inner > .wpb_wrapper {
        grid-template-columns: 1fr 1fr;
        gap: 3rem;
        padding: 4rem;
        align-content: center;
        align-items: center;
    }

    .hero-section .w-vwrapper:first-child {
        grid-column: 1 / 2;
    }

    .hero-section .hero-cta-inner-wrapper {
        display: inline-flex !important;
        flex-direction: row !important;
        width: auto;
    }

    .hero-section .hero-cta-inner-wrapper .w-btn-wrapper,
    .hero-section .hero-cta-inner-wrapper .w-btn {
        width: auto;
    }
}

.main-hero-title {
    color: var(--color-cream-base, #F7F4EE);
}

.main-hero-tagline {
    font-size: var(--fs-h6);
    font-weight: 400;
}

.main-hero-title,
.main-hero-tagline {
    color: var(--color-cream-base, #F7F4EE);
    text-shadow: 0 4px 14px rgba(26, 54, 54, 0.5), 0 1px 2px rgba(0, 0, 0, 0.3);
}

/* About us page */
.our-vision-section {
    padding-block: var(--space-l);
    background: var(--color-cream-alt, #F5F1EA);
}

.our-vision-inner-wrapper {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
}

@media (min-width: 1025px) {
    .our-vision-inner-wrapper {
        display: grid;
        grid-template-columns: 3fr 7fr;
        gap: 1.25rem;
    }
}

/* Grid Item Border */
/* Grid Item */
.our-pillars-item {
    background: var(--color-cream-light, #FCFBF8);
    border-radius: 10px;
    overflow: hidden;
    width: 76%;
}

@media (min-width: 1024px) {
    .our-pillars-item {
        width: auto;
    }
}

/* Image */
.our-pillars-media img {
    transition: transform 0.5s ease;
}

/* Image Hover Zoom */
.our-pillars-item:hover .our-pillars-media img {
    transform: scale(1.05);
}

/* Title */
.our-pillars-title {
    margin-inline: 0.5rem;
    font-size: var(--fs-h5);
    line-height: var(--lh-tight);
}

/* Content */
.our-pillars-content {
    margin-inline: 0.5rem;
    margin-bottom: 0.5rem;
    font-size: var(--fs-p);
    line-height: var(--lh-snug);
}

.small-tagline {
    color: var(--color-gold-alt, #D4B07B);
    font-size: calc(var(--fs-p) * 0.8);
    font-weight: 700;
}

.our-vision-content {
    font-size: var(--fs-p);
    line-height: var(--lh-snug);
}

.our-vision-content ul {
    margin-left: 1.3rem !important;
}

.our-commitments {
    padding-block: var(--space-l);
    background: var(--color-cream-light,#FCFBF8);
}

.title-commitments {
    text-align: center;
}

.small-tagline-commitments {
    color: var(--color-gold-alt, #D4B07B);
    font-size: calc(var(--fs-p) * 0.8);
    font-weight: 700;
    text-align: center;
    margin-bottom: 0.6rem;
}

.our-commitments-inner-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
}

@media (min-width: 600px) {
    .our-commitments-inner-wrapper {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (min-width: 1024px) {
    .our-commitments-inner-wrapper {
        grid-template-columns: repeat(5, 1fr);
    }
}

.our-commitments-iconbox .w-iconbox-icon {
    padding-bottom: 1.125rem;
}

.our-commitments-iconbox .w-iconbox-title {
    margin-inline: 0.5rem;
    font-size: var(--fs-h5);
    line-height: var(--lh-tight);
}

.our-commitments-iconbox .w-iconbox-text {
    font-size: var(--fs-p);
    line-height: var(--lh-snug);
}

.in-numbers-section {
    position: relative;
    padding-block: var(--space-l);
    background-image: url('/wp-content/uploads/2026/05/In-Numbers-Background-02.jpg');
    background-size: cover;
    background-position: center;
}

.in-numbers-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background-color: rgba(36, 78, 70, 0.90); /* --color-green-alt at 86% */
    z-index: 0;
}

.in-numbers-section > * {
    position: relative;
    z-index: 1;
}

.in-numbers-section .vc_column-inner .wpb_wrapper {
    display: grid !important;
    grid-template-columns: 1fr;
    gap: 2rem;
    align-items: center;
}

@media (min-width: 1025px) {
    .in-numbers-section .vc_column-inner .wpb_wrapper {
        grid-template-columns: 1fr 4fr;
    }
}

.in-numbers-section .vc_column-inner .wpb_wrapper > * {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    flex: unset !important;
}

/* Wrapper */
.in-numbers-wrapper {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem;
    padding: 2.5rem 3rem;
    border-radius: 10px;
}

/* Item */
.in-numbers-item {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
}

/* Icon */
.in-numbers-icon {
    flex-shrink: 0;
    height: clamp(2rem, 3vw, 3.6rem);
    width: auto;
    color: var(--color-gold-base, #C8A063);
}
.in-numbers-icon svg {
    height: 100%;
    width: auto;
    fill: currentColor;
}

/* Text block */
.in-numbers-content {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
}

/* Number */
.in-numbers-value {
    font-size: clamp(2rem, 3vw, 3.6rem);
    font-weight: 700;
    font-family: var(--h4-font-family, inherit);
    color: var(--color-cream-base, #F7F4EE);
    line-height: 1;
}

/* Label */
.in-numbers-label {
    font-size: calc(var(--fs-p) * 0.95);
    color: var(--color-cream-base, #F7F4EE);
    line-height: var(--lh-normal, 1.5);
}

/* Tablet */
@media (max-width: 1024px) {
    .in-numbers-wrapper {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Mobile */
@media (max-width: 600px) {
    .in-numbers-wrapper {
        grid-template-columns: 1fr 1fr;
        padding: 2rem 1.25rem;
    }
}

.in-numbers-section-title {
    font-size: var(--fs-h2);
    color: var(--color-cream-base, #F7F4EE);
    font-family: var(--h4-font-family, inherit);
    line-height: var(--lh-snug);
}

.our-mission-media {
    border-radius: 10px;
}

.general-cta-section {
    padding-block: var(--space-l);
    position: relative;
    background-image: url('/wp-content/uploads/2026/05/CTA-Background-02.jpg');
    background-size: cover;
    background-position: center;
}

.general-cta-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background-color: rgba(20, 30, 25, 0.86);
    z-index: 0;
}

.general-cta-section .l-section-h {
    position: relative;
    z-index: 1;
}

.general-cta-section .vc_column-inner .wpb_wrapper {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
}

@media (min-width: 1025px) {
    .general-cta-section .vc_column-inner .wpb_wrapper {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 2rem;
    }
}

.general-cta-title {
    color: var(--color-cream-base, #F7F4EE);
    font-family: var(--h4-font-family, inherit);
    line-height: var(--lh-snug);
    width: 90%;
    text-align: center;
}

@media (min-width: 1025px) {
    .general-cta-title {
        color: var(--color-cream-base, #F7F4EE);
        font-family: var(--h4-font-family);
        font-size: var(--fs-h3);
        line-height: var(--lh-snug);
        width: 60%;
        text-align: left;
    }
}

.general-cta-tagline {
    color: var(--color-cream-base, #F7F4EE);
    line-height: var(--lh-snug);
    font-size: var(--fs-h6);
    width: 100%;
    text-align: center;
}

@media (min-width: 1025px) {
    .general-cta-tagline {
        color: var(--color-cream-base, #F7F4EE);
        line-height: var(--lh-snug);
        font-size: var(--fs-h6);
        width: 100%;
        text-align: left;
    }
}

.contact-icon-box-section {
    padding-block: var(--space-m);
    background: var(--color-cream-base, #F7F4EE);
}

.contact-icon-box-section .vc_column-inner .wpb_wrapper {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}

@media (min-width: 600px) {
.contact-icon-box-section .vc_column-inner .wpb_wrapper {
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
}
}

@media (min-width: 1025px) {
.contact-icon-box-section .vc_column-inner .wpb_wrapper {
    grid-template-columns: 1fr 1fr 1fr 1fr;
    gap: 2.5rem;
}
}

/* =============================================
   Icon Box — Card Style
   ============================================= */
.w-iconbox {
  border: 1.5px solid #e8e0d8;
  border-radius: 10px;
  padding: 2rem;
  background: #fff;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
}

/* =============================================
   Icon Box — CTA Link
   ============================================= */
a.ibox-cta {
  color: var(--color-gold-base, #C8A063);
  font-weight: 500;
  font-size: 0.875rem;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  margin-top: 0.75rem;
}

a.ibox-cta:hover {
  color: var(--color-green-alt, #244E46);
}

.ibox-cta .fal {
  font-size: 0.9em;
  transition: transform 0.2s ease;
}

.ibox-cta:hover .fal {
  transform: translateX(3px);
}

.contact-form-section {
    padding-block: var(--space-m);
    background: var(--color-cream-light, #FCFBF8);
}

.contact-form-section .vc_column-inner .wpb_wrapper {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
}

@media (min-width: 1015px) {
.contact-form-section .vc_column-inner .wpb_wrapper {
    display: grid;
    grid-template-columns: 2fr 3fr;
    gap: 1.5rem;
}
}

.maps-section {
    padding-block: var(--space-m);
    background: var(--color-cream-light, #FCFBF8);
}

.maps-section .vc_column-inner .wpb_wrapper {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
}

@media (min-width: 1015px) {
.maps-section .vc_column-inner .wpb_wrapper {
    display: grid;
    grid-template-columns: 2fr 3fr;
    gap: 1.5rem;
}
}

.office-location-maps {
    width: 100%!important;
}
#multi-location-map img {
    max-width: none !important;
    width: auto !important;
}