/* 
Theme Name: Hello Elementor Child
Theme URI: https://github.com/elementor/hello-theme-child/
Description: Hello Elementor Child is a child theme of Hello Elementor, created by Elementor team
Author: Elementor Team
Author URI: https://elementor.com/
Template: hello-elementor
Version: 2.0.0
Text Domain: hello-elementor-child
License: GNU General Public License v3 or later.
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Tags: flexible-header, custom-colors, custom-menu, custom-logo, editor-style, featured-images, rtl-language-support, threaded-comments, translation-ready
*/

/* Add your custom styles here */
html,body {
	overflow-x:hidden;
}
.disabled{
cursor:not-allowed;
}
.disabled a{
pointer-events:none;
}

.btn{
cursor:pointer;
}
.elementor-widget-image img{
pointer-events:none;
}

.EB.marker ol li::marker {
    font-family: "EB Garamond", Sans-serif !important;
    font-size: calc(100% + 8px) !important;
    font-weight: 600 !important;
}

/* #main-menu a.dropdown-toggle::after {
  content: "";
  display: inline-block;
  width: 12px;
  height: 7px;
  margin-left: 6px;
  background-color: currentColor;
  -webkit-mask: url("data:image/svg+xml;utf8,\
<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 7'>\
<path d='M0.867348 0.144027L5.90949 5.02352L10.9516 0.144027C11.1501 -0.0480087 11.4718 -0.0480087 11.6702 0.144027C11.8687 0.336062 11.8687 0.647413 11.6702 0.839448L6.26879 6.06665C6.07036 6.25869 5.74863 6.25869 5.55019 6.06665L0.148746 0.839448C-0.0496903 0.647413 -0.0496903 0.336062 0.148746 0.144027C0.347203 -0.0477666 0.668995 -0.0479279 0.867348 0.144027Z'/>\
</svg>") no-repeat center / contain;
          mask: url("data:image/svg+xml;utf8,\
<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 7'>\
<path d='M0.867348 0.144027L5.90949 5.02352L10.9516 0.144027C11.1501 -0.0480087 11.4718 -0.0480087 11.6702 0.144027C11.8687 0.336062 11.8687 0.647413 11.6702 0.839448L6.26879 6.06665C6.07036 6.25869 5.74863 6.25869 5.55019 6.06665L0.148746 0.839448C-0.0496903 0.647413 -0.0496903 0.336062 0.148746 0.144027C0.347203 -0.0477666 0.668995 -0.0479279 0.867348 0.144027Z'/>\
</svg>") no-repeat center / contain;
  transition: transform 0.2s ease;
}

#main-menu  .current-menu-parent:hover a.dropdown-toggle::after {
  transform: rotate(180deg);
} */

/* #main-menu  a.dropdown-toggle {
  color: #222;
}

#main-menu  a.dropdown-toggle:hover {
  color: #ff5a00;
} */

#breadcrumbs span {
    display: flex;
    gap: 12px;
    flex-direction: row;
    align-items: center;
}
#breadcrumbs .breadcrumb_last {
    /* color: #000; */
    font-weight: bold;
}
.cus-tab.type-1 .e-n-tabs-heading {
    background: #fff;
    padding: 8px 9px;
    border-radius: 100px;
}

.cus-tab.type-1 .e-n-tabs {
    align-items: center;
}

.sb{
    font-weight: 600 !important;
}
.hlt{
    color: var( --e-global-color-text ) !important;
}
p:last-child {
	margin-bottom:0;
 }
/*
.headingAni .word {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%);
}
.headingAni h1, 
.headingAni h2, 
.headingAni h3,
.headingAni .word{
  padding-bottom: 0.4em; 给底部留出呼吸空间
  padding-top: 0.04em;
  margin-bottom: 0; 防止边距塌陷影响布局
}
.headingAni .word {
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  display: inline-block; 确保 word 级别有完整的盒子模型
}
.headingAni .word {
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  display: inline-block; 确保 word 级别有完整的盒子模型
} */

.snSocial .elementor-social-icon {
	width:35px;
	transform:rotate(45deg);
}
.snSocial .elementor-social-icon svg {
	transform:rotate(-45deg);
}
/* Button */
.elementor-button {
	fill:#fff !important;
}
.elementor-button-content-wrapper {
	display:flex;
	justify-content: space-between;
	align-items:center;
}

#cus-buton .elementor-button-icon {
    background: var(--e-global-color-accent);
    width: 36px;
    height: 36px;
    justify-content: center;
	margin-left:30px;
	border-radius:100px !important;
}

.cus-buton .elementor-button-icon {
    background: var(--e-global-color-accent);
    width: 36px;
    height: 36px;
    justify-content: center;
	margin-left:30px;
	border-radius:100px !important;
}
/* MENU */

ul.cpel-switcher__list::before {
    content: "/";
    position: absolute;
    top: calc(50% + 0px);
    left: calc(50% + 0px);
    transform: translate(-50%, -50%);
}

/* tabs */
#amenities .e-n-tabs-heading {
    background: #D4D6B5;
    width: fit-content;
    align-items: center;
    padding: 7px;
    border-radius: 100px;
}
#amenities .e-n-tabs.e-activated {
    display: flex;
    flex-direction: column;
    align-items: center;
}

/* banner */
.join-btn{
    animation: fadeIn 0.4s ease-out forwards;
}
.join-btn.sticky-it {
    position: fixed;
    right: 50px;
    bottom: 100px;
    z-index: 9999;
    animation: fadeIn 0.4s ease-out forwards;
transform:scale(0.9);
}

#amenities .e-n-tabs-heading {
    background: #D4D6B5;
    width: fit-content;
    align-items: center;
    padding: 7px;
    border-radius: 100px;
}

#amenities .e-n-tabs.e-activated {
    display: flex;
    flex-direction: column;
    align-items: center;
}

@keyframes fadeIn {
    from { opacity: 0; }
    to   { opacity: 1; }
}
@keyframes fadeOut {
    from { opacity: 1; }
    to   { opacity: 2; }
}
.join-btn.sticky-it .elementor-widget-text-path svg path {
  stroke: var(--path-fill,transparent);           /* border color */
  stroke-width: 34px;        /* border thickness */
  stroke-linecap: round;  /* cap style */
  stroke-linejoin: round; /* join style */
  paint-order: stroke fill;/* paint stroke before fill if you want stroke underneath */
  vector-effect: non-scaling-stroke; /* keeps stroke width constant when scaling */
}

.join-btn.sticky-it:hover{
    transform:scale(1.2);
} 
/* Expanding Card */
.accordion-card {
	cursor: pointer;
    overflow: hidden;
	height:580px;
    display: flex;
    flex-direction: column;
    transition: all 0.5s ease;
    position: relative;
}

/* Inner title and content layout */
.content {
	height:100%;
}
.inner-title {
	top:50%;
	transform: translatey(-50%);
    transition: transform 0.5s ease;
}

.inner-content {
    opacity: 0;
    max-height: 0;
    overflow: hidden;
    transition: all 0.5s ease 0.4s;
}

/* Active state */
.accordion-card.expanded .inner-title {
	top:0;
    transform: translateY(0); /* moves up slightly */
}

.accordion-card.expanded .inner-content {
    opacity: 1;
    max-height: 500px; /* enough for content */
}


/* From style */
/*.elementor-form button.is-disabled {*/
/*    opacity: 0.5;*/
/*    cursor: not-allowed;*/
/*    pointer-events: none;*/
/*}*/

/* Container/Background Styling (Remains the same as before) */
.elementor-field-option {
    padding: 15px 0px;
    border-radius: 5px; 
    display: flex;
    align-items: flex-start; 
    line-height: 1.4; 
}

/* Text Styling (Remains the same as before) */
.elementor-field-option label {
    color: #2e3d30; 
    font-size: 18px; 
    font-weight: 500; 
    margin-left: 15px; 
    cursor: default; 
}

/* Checkbox (Input) Styling - UPDATED BACKGROUND COLOR */
.elementor-field-option input[type="checkbox"] {
    appearance: none; 
    -webkit-appearance: none; 
    width: 25px; 
    height: 25px;
    /* --- UPDATED: New light background color for the box --- */
    background-color: #D4D6B5; 
    /* --- Optional: Adjust border color to match new box color better --- */
    border: 1px solid #c0c2a7; 
    border-radius: 3px; 
    flex-shrink: 0;
    position: relative; 
    cursor: pointer;
}

/* Optional: Styling for the link (Remains the same) */
.elementor-field-option label a {
    color: #2e3d30; 
    text-decoration: underline; 
    font-weight: 700; 
}

/* Style for the CHECKED state (The surrounding box remains the new color) */
.elementor-field-option input[type="checkbox"]:checked {
    background-color: #D4D6B5;
}

/* Adding the checkmark using a pseudo-element on CHECKED state (Remains the same) */
.elementor-field-option input[type="checkbox"]:checked::before {
    content: '✔'; 
    font-size: 18px; 
    color: #2e3d30; 
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.elementor-field-group .elementor-field:not(.elementor-select-wrapper) {background-color: #ffffff !important;color: #A0A0A0 !important;}

elementor-field-group{
padding:0;
margin:0;
}

/* --- 1. Main Form Background Color --- */
/* (This should be applied to the main container wrapper) */
.elementor-form-fields-wrapper {
    /* background-color: #799a70; */ /* The main sage/moss green color */
    /* padding: 30px; */
}

/* --- 2. & 3. Input Field Styling (Name, Email, Phone, Salutations) --- */
/* Target all textual inputs and the select box */
.elementor-field-textual,
.elementor-select-wrapper select {
    /* The light tan/khaki background color for the fields */
    background-color: #d8d9b1 !important; 
    color: #A0A0A0; /* Darker text color */
    border: none !important; /* Remove borders */
    border-radius: 4px; /* Slight rounding on corners */
    height: 45px; /* Define a clear height for consistency */
    padding: 10px 15px; /* Adjust padding inside the fields */
    box-shadow: none; /* Remove any default shadows */
    font-size: 15px;
}

/* Ensures the select dropdown structure looks right */
.elementor-select-wrapper {
    border: none;
}

/* --- 5. Button Styling (CONTINUE) --- */
.e-form__buttons__wrapper__button-next {
    background-color: #d8d9b1 !important; /* Light khaki background */
    color: #A0A0A0 !important; /* Dark text color */
    border: none !important;
    border-radius: 20px; /* Rounded pill shape */
    padding: 10px 30px;
    font-size: 16px;
    font-weight: bold;
    text-transform: uppercase;
    float: right; /* Push the button to the right */
    margin-top: 20px;
}
/* -- dorp down */
.elementor-field-group .elementor-select-wrapper select {
    background-color: #ffffff !important;
}

.elementor-select-wrapper select:valid {
    /* Revert to the dark text color used for other inputs (from previous CSS) */
    color: #A0A0A0;
    font-size: 14px;
}


/* Desktop: width expand */
@media screen and (min-width: 1025px) {
    .accordion-card {
        width: 100%;
    }
    .accordion-card.expanded {
        width: 150% !important;
    }
	.accordion-card.expanded.big .cover {
		min-height: 288px;
	}


}

/* Tablet: height expand */
@media (max-width: 1024px) {


.join-btn.sticky-it {

 
    bottom: 70px;

}


    .accordion-card {
        height: 100px;
    }
    .accordion-card.expanded {
        height: 500px !important;
    }

.content {
    position: absolute;
    color: #fff;
    background: #00000085;
}

.content * {
    color: #fff !important;
}

}
/* Mobile: height expand smaller */
@media (max-width:768px) {
	ul.cpel-switcher__list::before{
/* font-size:2em; */
}
	.elementor-field-option input[type="checkbox"] {
		width: 15px;
		height: 15px;
		margin-top:2px;
	}

	.elementor-field-option label {
		margin-left: 10px;
	}

	.elementor-field-group.elementor-column.elementor-field-type-submit.e-form__buttons.elementor-col-100 buttom {
		min-height: 40px;
	}

	.cus-tab.type-1 .e-n-tabs-heading {
		flex-direction: column;
		width: 100%;
    border-radius: 30px;
	}



}

@media (max-width: 480px) {

	.join-btn.sticky-it {
		right: 20px;
		bottom: 63px;
		transform: scale(0.7);
	}

    .accordion-card {
        height: 100px;
    }

    .accordion-card.expanded {
        height: 350px !important;
    }

}

/* Info Box */
.snInfo {
	top: 50%;
	transform: translatey(-50%);
}
.hover-target {
	cursor:pointer;
}
.hover-popup {
  width: fit-content;
  transform: scale(0);
  transition: transform 200ms ease;
  transform-origin: 50% 50%;
}

.hover-target:hover + .hover-popup,
.hover-target:focus + .hover-popup,
.hover-popup:hover{
  transform: scale(1);
}

