.cst_overlay:before{
	 background: linear-gradient(180deg, rgba(0,0,0,1) 0%, #000000 100%) !important;
	transition: background 0.3s;
}

.cst_overlay:hover:before{
	 background: linear-gradient(180deg, rgba(0,0,0,0.0) 0%, #000000 40%) !important;
}

.cst_overlay .elementor-widget-heading{
	position: relative;
	top: 60%;
	transform: translatey(-60%);
	transition: 0.3s;
}

.cst_overlay:hover .elementor-widget-heading{
	top: 50%;
	transform: translatey(-50%);
}

.cst_overlay p{
	margin-bottom: 0px;
}

.cst_overlay .elementor-widget-text-editor{
	opacity: 0;
	margin-bottom: 0px;
	transition: 0.3s opacity;
}

.cst_overlay:hover .elementor-widget-text-editor{
	opacity: 1;
}

@media screen and (max-width: 1025px){
	.cst_overlay:hover .elementor-widget-heading{
	top: -10%;
	transform: translatey(-10%);
}
}


/* xxxxx */
.elementor-image-carousel{
	margin-bottom: 20px;
}

.e-n-accordion details{
border-radius: 8px;
box-shadow: 0px 10px 30px 0px rgba(0,0,0,0.15);
-webkit-box-shadow: 0px 10px 30px 0px rgba(0,0,0,0.15);
-moz-box-shadow: 0px 10px 30px 0px rgba(0,0,0,0.15);
}

@media screen and (min-width: 767px){
	.heading_pattern{
	position: relative;
}

.heading_pattern:before{
	content: "";
	display: block;
	width: 100%;
	height: 87px;
	background-image: url(//srv/htdocs/wp-content/uploads/2024/12/headings_pattern.svg);
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	top: 50%;
	left: -60px;
	transform: translatey(-50%);
}
}



/* .hfe-nav-menu__layout-horizontal{
	background-color: #fff !important;
} */

/* form */

/* Main container styles */
.booking {
    padding: 16px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.booking__container {
    width: 100% !important;
    max-width: 800px !important;
    padding: 20px !important;
}

.booking__form-group {
    margin-bottom: 24px !important;
}

.booking__label {
    display: block !important;
    margin-bottom: 12px !important;
    font-size: 18px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    color: #000 !important;
    font-weight: 500 !important;
}

.booking__name-group {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 16px !important;
}

.booking__form-group p{
	margin-bottom: 0px;
}

/* Form inputs */
.booking__input,
.booking__select,
.booking__textarea {
    width: 100% !important;
    padding: 12px !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 4px !important;
    font-size: 15px !important;
    color: #000 !important;
}

.booking__input::placeholder,
.booking__select::placeholder,
.booking__textarea::placeholder {
    color: #9ca3af !important;
}

/* Custom select styling */
.booking__select {
    appearance: none !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23000000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 16px center !important;
    padding-right: 40px !important;
}

.booking__textarea {
    min-height: 100px !important;
    resize: vertical !important;
}

.booking__info {
    font-size: 13px !important;
    color: #4b5563 !important;
    line-height: 1.6 !important;
}

.booking__info + .booking__info {
    margin-top: 8px !important;
}

/* Submit button */
.booking__submit {
    background-color: #ffc107 !important;
    color: #000 !important;
    border: none !important;
    padding: 14px 24px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    border-radius: 4px !important;
    cursor: pointer !important;
    width: 100% !important;
    margin-top: 24px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    transition: background-color 0.2s ease !important;
}

.booking__submit:hover {
    background-color: #ffca28 !important;
}

/* Contact Form 7 specific styles */
.wpcf7-not-valid-tip {
    color: #dc2626 !important;
    font-size: 13px !important;
    margin-top: 4px !important;
}

.wpcf7-response-output {
    margin: 2em 0 1em !important;
    padding: 0.5em 1em !important;
    border: 2px solid #00a0d2 !important;
    text-align: center !important;
}

.wpcf7 form.invalid .wpcf7-response-output {
    border-color: #dc2626 !important;
}

.wpcf7 form.sent .wpcf7-response-output {
    border-color: #46c35b !important;
}

/* Focus states */
.booking__input:focus,
.booking__select:focus,
.booking__textarea:focus {
    outline: none !important;
    border-color: #9ca3af !important;
}

/* Tablet breakpoint */
@media (min-width: 480px) {
    .booking__container {
        padding: 32px !important;
    }

    .booking__form-group {
        margin-bottom: 32px !important;
    }

    .booking__name-group {
        grid-template-columns: 1fr 1fr !important;
    }

    .booking__input,
    .booking__select,
    .booking__textarea {
        padding: 16px !important;
    }

    .booking__textarea {
        min-height: 120px !important;
    }

    .booking__info {
        font-size: 14px !important;
    }

    .booking__submit {
        padding: 16px 32px !important;
        font-size: 15px !important;
        margin-top: 32px !important;
    }

    .wpcf7-not-valid-tip {
        font-size: 14px !important;
    }
}

/* Desktop breakpoint */
@media (min-width: 768px) {
    .booking__container {
        padding: 40px !important;
    }
}

/* Touch device optimizations */
@media (hover: none) {
    .booking__input,
    .booking__select,
    .booking__textarea {
        font-size: 16px !important;
    }
}

/* custom grid */
/* .cst_grid{
	grid-template-columns: repeat(8, 1fr) !important;
	gap: 0px;
} */

@media only screen and (min-width: 1024px) {
  .cst_grid-left{
	grid-column: 1 / 9;
}

.cst_grid-right{
	grid-column: 6 / -1;
	box-shadow: 0px 4px 4px 0px rgba(0,0,0,0.5);
	backdrop-filter: blur(6px);
}  
	
	.cst_grid-left, .cst_grid-right {
        grid-row: 1 / 2;
    }
/* Hide the capacity (person icon + number) in Amelia Catalog cards */
.amelia-app-booking .am-service-info .am-capacity {
    display: none !important;
} /* 🔥 FINAL FIX — hide person icon + number in Amelia catalog */
.amelia-app-booking .am-service-info i.am-icon-user,
.amelia-app-booking .am-service-info i[class*="user"] {
    display: none !important;
}

.amelia-app-booking .am-service-info .am-service-capacity,
.amelia-app-booking .am-service-info .am-capacity,
.amelia-app-booking .am-service-info span:has(i[class*="user"]) {
    display: none !important;
}