/*
Theme Name:  Hello Elementor Child
Template: 	 hello-elementor
Theme URI:	 https://wordpress.org/themes/hello-elementor/
Author:		 ChildThemeWP
Author URI:	 https://childthemewp.com
Version:	 1.0.0
License:	 GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Tags:    	 opensource
Text Domain: helloelementorchild
*/
:root {
    --blue: #1f3b5f;
    --blue-deep: #162a45;
    --beige: #f3e8d8;
    --sand: #cbb59b;
    --gold: #bfa56a;
    --text-dark: #1f2a33;
    --text-muted: #5b6870;
    --text-subtle: #7a8790;
    --border: #d7c7b1;
    --border-strong: #c2b097;
    --bg: #f7f2ea;
    --bg-alt: #f3e8d8;
    --bg-muted: #efe2cf;
    --overlay: rgba(31, 59, 95, 0.65);
    --white: var(--white);
}
.elementor-page-13 .elementor-element.elementor-element-4b837e8{
	background-color:transparent !important;
}
.elementor-page-13  .shrinker.elementor-sticky--effects{
	    background: #fff !important;
}
.elementor-page-13 .elementor-element.elementor-element-4b837e8:not(.elementor-sticky--effects){
	box-shadow:unset;
}
.elementor-page-13 .elementor-element.elementor-element-4b837e8:not(.elementor-sticky--effects) .elementor-nav-menu--main .elementor-item{
	fill:#fff;
	color:#fff;
}
.exp-card-slide {
    height: 350px;
    width: 400px !important;
    box-shadow: 0pt 2pt 7pt var(--text-dark)00071;
    background: var(--white);
    position: relative;
}
.elementor-24 .elementor-element.elementor-element-16d9ee4 img{
	 transition: all 0.5s ease-in-out;
}
.exp-card-content p {
    margin: 0 14px 14px 14px;
    font-size: 12px;
    color: var(--text-muted);
}

h1 b,
h2 b {
    font-family: 'Montserrat';
    font-weight: 400;
}

.leftcontent-box {
    padding: 60px !important;
}

.rightcontent-box {
    padding: 60px !important;
}

.custom-image-offers,
.custom-image-offers>div {
    height: 100%;
}

.custom-image-offers img {
    height: 100%;
    width: 100%;
    object-fit: cover;
}

.deals-grid-wrapper {
    display: flex;
    flex-wrap: wrap;
}

.deals-grid-wrapper a.deals-box {
    width: 50%;
    height: 400px;
    position: relative;
}

.deals-grid-wrapper .deals-box-content {
    opacity: 0;
    visibility: hidden;
    position: absolute;
    display: flex;
    flex-direction: column;
    color: var(--white);
    transition: all 0.5s ease-in-out;
    z-index: 3;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: var(--blue);
    padding: 10px 30px;
    justify-content: center;
}

.deals-grid-wrapper a.deals-box:nth-child(1) {
    border-right: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
}

.deals-grid-wrapper a.deals-box:nth-child(2) {
    border-bottom: 1px solid var(--border);
}

.deals-grid-wrapper a.deals-box:nth-child(3) {
    border-right: 1px solid var(--border);
}

.deals-grid-wrapper a.deals-box:hover>.deals-box-content {
    opacity: 1;
    visibility: visible;
    transition: all 0.5s ease-in-out;
}

.deals-grid-wrapper a.deals-box img {
    height: 100%;
    width: 100%;
    object-fit: cover;
    z-index: 2;
}

.exp-card-content strong {
    color: var(--text-dark) !important;
}

.exp-card-content a {
    margin: 0 7px 7px 7px;
    font-size: 16px;
    color: var(--white);
    background: var(--gold);
    display: flex;
    height: 37px;
    align-items: center;
    justify-content: center;
    position: absolute;
    bottom: 0px;
    width: calc(100% - 14px);
}

.contactusform form input {
    margin-bottom: 10px !important;
}

.contactusform form>p {
    width: 90%;
}

.mySwiper-resorts .swiper-wrapper {
    padding: 10px;
    z-index: 2;
}

.exp-card-slide img {
    width: calc(100% - 14px);
    height: 305px !important;
    object-fit: cover;
    object-position: center;
    margin: 7px 7px 0px 7px;
}

.exp-card-content h3 {
    margin: 5px auto 10px auto;
    width: fit-content;
    font-size: 24px;
}

.swiper-arrow-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 100%;
    height: 40px;
    z-index: 3;
}

.swiper-arrow-nav .swiper-button-next,
.swiper-arrow-nav .swiper-button-prev {
    height: 50px !important;
    width: 50px !important;
    justify-content: center;
    align-items: center;
    display: flex;
    background: var(--gold);
    border-radius: 50%;
}

.swiper-arrow-nav .swiper-button-next::after,
.swiper-arrow-nav .swiper-button-prev::after {
    color: var(--white);
    height: 50px !important;
    width: 50px !important;
    font-size: 28px;
    justify-content: center;
    align-items: center;
    display: flex;
}

.swiper-arrow-nav .swiper-button-next {
    right: 20px;
}

.swiper-arrow-nav .swiper-button-prev {
    left: 20px;
}

.hero-cutoff img {
    height: 70vh;
    width: 100%;
    object-fit: cover;
    object-position: center;
}

.exp-card-content span {
    text-align: center;
    width: 100%;
    display: flex;
    justify-content: center;
    column-gap: 5px;
    padding-bottom: 60px;
    font-size: 16px;
    font-style: italic;
    color: var(--text-dark);
}

/*
.header-additional-info {
    opacity: 1;
    visibility: visible;
    transition: all 0.5s ease-in-out;
    height: 24px;
    transform: translateY(0px);
}
.custom-header-class, .custom-header-class.scroll-active {
    transition: all 0.5s ease-in-out;
}
.header-logo-img {
    transition: all 0.5s ease-in-out;
}
.custom-header-class.scroll-active .header-logo-img {
    transition: all 0.5s ease-in-out;
    width: 160px;
}
.custom-header-class.scroll-active .header-additional-info {
    opacity: 0;
    visibility: hidden;
    height: 0px;
    transform: translateY(-200px);
    transition: all 0.5s ease-in-out;
}
.custom-header-class.scroll-active .content-header-column > div {
    align-content: center !important;
    transition: all 0.5s ease-in-out;
}
 */
body.elementor-default .elementor-24 .elementor-element.elementor-element-4b837e8 {
    width: 100% !important;
}
/* body.elementor-default.elementor-editor-active .elementor-24 .elementor-element.elementor-element-4b837e8{
	position:relative !important;
	margin:0;
}
 */
.shrinker.elementor-sticky--effects .elementor-motion-effects-parent {
    /* background: var(--blue) !important; */
}

body .elementor-24 .elementor-element.elementor-element-38da3ae {

    --grid-column-gap: 0px;
    --grid-row-gap: 0px;
}

body .wpcf7-list-item.first.last label {
	display: flex !important;
    gap: 5px !important;
}
/* Events and Property Management page */
.exp-boxes-img img {
    height: 550px;
    object-fit: cover;
}
.exp-boxes-img {
    transition: all 0.5s ease-in-out;
}
.exp-boxes-img:hover {
    margin-top: -80px;
    transition: all 0.5s ease-in-out;
}


.exp-headings-boxes {
    position: absolute;
    top: 50%;
    width: 80%;
    left:50%;
    transform: translate(-50%, -50%);
}
.exp-headings-boxes .visit-website {
	line-height: 68px;
    font-size: 24px;
    font-weight: 400;
}
.exp-headings-boxes .this-property {
	font-size: 14px;
	line-height: 28px;
}
.exp-headings-boxes .price {
	font-size: 36px;
}
.exp-headings-boxes .unit-name {
	font-size: 22px;
}
.exp-headings-boxes .info {
	font-size: 14px;
	font-weight: 400;
}
.exp-headings-boxes .info span {
	border-right: 1px solid var(--white);
	padding-right: 5px;
	margin-right: 5px;
}

.exp-boxes-wrapper .dont-display {
	display: none !important;
}
/* Events and Property Management page end */

.accordion-list {
	
}

/* Container layout - 3 columns grid */
#conc-form .wpcf7-form-control.wpcf7-checkbox {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    padding: 20px;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    background: #f9f9f9;
}

/* Each checkbox item */
#conc-form .wpcf7-list-item {
    display: flex;
    align-items: center;
    padding: 10px 14px;
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.2s ease;
    margin: 0 !important;
    position: relative;
}

#conc-form .wpcf7-list-item:hover {
    border-color: #5cb8e6;
    background: #f0f8ff;
}

/* Hide default checkbox */
#conc-form .wpcf7-list-item input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
    pointer-events: none;
}

/* Custom checkbox */
#conc-form .wpcf7-list-item .wpcf7-list-item-label {
    position: relative;
    padding-left: 28px;
    font-size: 14px;
    color: #333;
    cursor: pointer;
    display: block;
    width: 100%;
}

#conc-form .wpcf7-list-item .wpcf7-list-item-label::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 18px;
    height: 18px;
    border: 2px solid #ccc;
    border-radius: 4px;
    background: #fff;
    transition: all 0.2s ease;
}

/* Checked state */
#conc-form .wpcf7-list-item input[type="checkbox"]:checked + .wpcf7-list-item-label::before {
    background: #5cb8e6;
    border-color: #5cb8e6;
}

#conc-form .wpcf7-list-item input[type="checkbox"]:checked + .wpcf7-list-item-label::after {
    content: '✓';
    position: absolute;
    left: 3px;
    top: 50%;
    transform: translateY(-50%);
    color: #fff;
    font-size: 13px;
    font-weight: bold;
}

/* Highlight the whole item when checked */
#conc-form .wpcf7-list-item:has(input:checked) {
    border-color: #5cb8e6;
    background: #eef7fc;
}

#conc-form input[type="submit"] {
    background: #5cb8e6;
    color: #fff;
    border: none;
    padding: 14px 40px;
    font-size: 15px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    border-radius: 0;
    cursor: pointer;
    transition: all 0.3s ease;
    width: 100%;
    margin-top: 10px;
}

#conc-form input[type="submit"]:hover {
    background: #1a237e;
}
/* Responsive - stack on mobile */
@media (max-width: 768px) {
    #conc-form .wpcf7-form-control.wpcf7-checkbox {
        grid-template-columns: 1fr;
    }
}
/* Two column rows */
#conc-form .form-row {
    display: flex;
    gap: 16px;
    margin-bottom: 16px;
}

#conc-form .form-col {
    flex: 1;
}

/* Full width message */
#conc-form .form-full {
    margin-bottom: 16px;
}

/* Responsive - stack on mobile */
@media (max-width: 768px) {
    #conc-form .form-row {
        flex-direction: column;
    }
}
@media only screen and (max-width:1024px) {
    .exp-card-slide {
        width: 300px !important;
    }

    .custom-image-offers img {
        height: 300px;
    }

    .exp-card-slide img {
        height: 200px !important;
    }

    .hero-cutoff img {
        height: 50vh;
    }

    .elementor-menu-toggle i {
        margin-top: 4px;
        margin-right: 10px
    }

    .leftcontent-box {
        padding: 20px !important;
    }

    .rightcontent-box {
        padding: 20px !important;
    }

    .offers-section section>div {
        flex-direction: column;
    }

    .offers-section section>div>div {
        width: 100% !important;
    }

    .deals-grid-wrapper .deals-box-content {
        opacity: 1;
        visibility: visible;
        transition: all 0.5s ease-in-out;
        z-index: 3;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: var(--text-dark)00070;
        padding: 10px 30px;
        justify-content: center;
    }

    .exp-boxes-wrapper>div>div {
        width: 100% !important;
    }

    .elementor-24 .elementor-element.elementor-element-da418aa .elementor-nav-menu--main>.elementor-nav-menu>li>.elementor-nav-menu--dropdown,
    .elementor-24 .elementor-element.elementor-element-da418aa .elementor-nav-menu__container.elementor-nav-menu--dropdown {
        margin-top: 10px !important;
    }


}

@media only screen and (max-width:767px) {
    .footer-logo>div {
        display: flex;
    }

    .footer-logo img {
        margin: 0 auto;
    }

    .elementor-menu-toggle i {
        margin-top: 0px;
        margin-right: 0px
    }

    .deals-grid-wrapper a.deals-box {
        width: 100%;
    }

    .deals-grid-wrapper a.deals-box:nth-child(1) {
        border-right: none;
        border-bottom: 1px solid var(--border);
    }

    .deals-grid-wrapper a.deals-box:nth-child(2) {
        border-bottom: 1px solid var(--border);
    }

    .deals-grid-wrapper a.deals-box:nth-child(3) {
        border-right: none;
        border-bottom: 1px solid var(--border);
    }

    .contactusform form>p {
        width: 100%;
    }

    .elementor-nav-menu__align-left .elementor-nav-menu--layout-vertical>ul>li>a {
        justify-content: center !important;
    }
}

@media only screen and (min-width:561px) {
    .hanging-booknow {
        display: none;
    }
}

@media only screen and (max-width:560px) {

    .elementor-page-13 .elementor-element.elementor-element-4b837e8 {
        background: #fff!important;
    }

    .swiper-arrow-nav .swiper-button-next,
    .swiper-arrow-nav .swiper-button-prev {
        height: 40px !important;
        width: 40px !important;
    }

    .swiper-arrow-nav .swiper-button-next::after,
    .swiper-arrow-nav .swiper-button-prev::after {
        height: 40px !important;
        width: 40px !important;
        font-size: 22px;
    }

    .hanging-booknow {
        position: fixed;
        bottom: -5px;
        left: 0;
        z-index: 10;
        width: 100%;
        padding: 5px 0;
    }

    .custom-header-class.scroll-active .content-header-column>div {
        padding: 5px;
    }

    .custom-header-class .header-logo-img img {
        transition: all 0.5s ease-in-out;
    }

    .custom-header-class.scroll-active .header-logo-img img {
        width: 160px !important;
        transition: all 0.5s ease-in-out;
    }
	.team-member-popup-holder a {
		font-size: 14px;
	}
}

@media only screen and (min-width:768px) {
    .footer-menu-widget li.menu-item a {
        width: fit-content;
    }
}

@media only screen and (min-width:1440px) {
    .custom-header-class {
        padding: 10px 40px !important;
    }
}

.home-form {
    width: 100%;
}

.home-form .wpcf7-form-control-wrap {
    display: block;
    margin-bottom: 20px;

}

.home-form br {
    display: none;
}

.home-form [type=button], .home-form [type=submit], .home-form button {
    border: 1px solid #162a45;
    border-radius: 7px;
    color: #162a45;
    padding: 0.8em 2em 0.8em 2em;
    margin: auto;
    display: block;
    background: none;
}

.home-form [type=button]:hover, .home-form [type=submit]:hover, .home-form button:hover {
    background: #bfa56a;
    color: #162a45;
}

.home-form input, .home-form textarea {
    background: #f7f2ea;
    font-family: "Montserrat";
    max-height: 200px;
}