:root {
	--color-green: #889d69;
	--color-yellow: #e3c07c;
	--color-text: #1A1A1A;
	--color-text-dark: #1A1A1A;
	--color-bg: #fafafa;
	--box-radius: 2rem;
	--grid-gap: 1rem;
	--image-radius: 1rem;
	--color-border: #e0e0e0;
	--radius: 1rem;
	--gap: 1.5rem;
	--box-rgb: 136, 157, 105;
}

body {
	font-family: GothamBook;
	font-weight: normal;
	font-style: normal;
	-webkit-font-smoothing: antialiased;
	color: var(--color-text);
}

a {
	text-decoration: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-family: GothamLight;
	font-style: normal;
}

p {
	line-height: 1.4;
	font-family: GothamLight;
}

.m-b-40 {
	margin-bottom: 3vw;
}

.wrapper {
	max-width: 1550px;
	margin: 0 auto;
	position: relative;
	width: 100%;
}

.wrapper-sml {
	max-width: 1100px;
	margin: 0 auto;
	position: relative;
	width: 100%;
}

.wrapper-lg {
	max-width: 90%;
	margin: 0 auto;
	position: relative;
}

p strong {
	font-family: GothamMedium;
	font-weight: normal;
	font-style: normal;
}

.grid {display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    grid-gap: 50px;
    margin: 30px 0;}

.grid img {border-radius:20px;}

.valign {display:flex; width: 100%; flex-wrap:wrap; align-content:center}

.glow {
	position: absolute;
	left: 0;
	top: 0;
	right: 0;
	bottom: 0;
	z-index: -2;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	overflow: visible;
	width: 100vw;
	min-height: 100vh;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	background-image: radial-gradient(circle farthest-corner at 75% 15%, #aa9465, rgba(194, 181, 155, 0) 48%);
	opacity: .5;
	-webkit-filter: blur(3em);
	filter: blur(3em);
	max-width: 100%;
}

.fixed-height {
	height: 100vh;
	position: relative;
}

.floating-header {
	position: absolute;
	width: 100%;
	z-index: 999;
}

.fixed-header {
	padding: 20px 0
}

.fixed-header header .logo {
	margin: 0;
	width: 150px;
}

.fixed-header header nav {
	top: 20px
}

header .logo {
	margin: 30px auto;
	width: 260px;
}

header nav {
	position: absolute;
	right: 0;
	top: 40px;
	text-align: right;
	display: flex;
	z-index: 999;
}

header nav ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

header nav li {
	display: inline-block;
}

header nav li a {
	text-decoration: none;
	color: #222;
	margin-right: 15px;
	display: block;
	padding: 18px 0;
	text-transform: uppercase;
	font-size: 15px;
	font-family: GothamMedium;
}

header nav li a:hover {
	color: var(--color-green);
}

.alt header nav li a {
	color: #fff
}

.book-now {
	background-color: var(--color-green);
	color: #FFFFFF;
	border: none;
	border-radius: 55px;
	padding: 18px 36px;
	font-family: GothamBook;
	font-size: 15px;
	font-weight: 500;
	text-transform: uppercase;
	cursor: pointer;
	text-decoration: none;
	display: flex;
	align-items: center;
	margin-left: 20px;
}

.book-now::before {
	content: "";
	display: inline-block;
	width: 5px;
	height: 5px;
	background-color: #FAC747;
	border-radius: 50%;
	margin-right: 5px;
}

.banner {
	position: relative;
}

.banner img {
	border-bottom-right-radius: 100px;
}

.banner.small {
	height: 50dvh; background: #f6f6f6; border-bottom-right-radius: 100px;
}

.banner.small .line {
	max-width: 45%;
}

.banner.small::before {content: ''; display: block; background: #7a945f; position: absolute; top: 0; left: 0; width: 30vh; mask-image:url('/img/banner-mask.svg'); mask-size: cover; mask-position: center; mask-repeat:no-repeat; height: 100%;}

.overlay-text {
	position: absolute;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: flex-end;
}

.inside .overlay-text {
	align-items: flex-end;
}

.inside .hero h1 {
	color: #fff;
	font-size: 3.5rem;
	margin-bottom: 0;
}

.inside .hero p {
	color: #fff;
}

.inside .hero {
	max-width: 650px;
	margin: 0 7vw 1vw 0;
	text-align: right;
}

.banner.inside .dark h1 {
	color: #1A1A1A;
}

.banner.inside .dark p {
	color: var(--color-green);
}

.line {
	display: inline-block;
	max-width: 70%;
	margin-bottom: 3rem;
}

.line svg {
	width: 100%;
}

.hero-text {
	text-align: center;
}

.hero-text h1 {
	text-align: center;
	font-size: 100px;
	line-height: 1.2;
}

.hero-text p {
	display: inline-flex;
	text-align: center;
	margin: 0 auto
}

.hero-text .button {
	margin-top: 45px;
}

.hero {
	max-width: 600px;
	margin: 0 10vw 0 0;
}

.hero p,
.hero-text p {
	display: inline-block;
	position: relative;
	font-size: 0.9rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1px;
	color: var(--color-green);
	margin-bottom: 1rem;
	padding-left: 0.75rem;
}

.hero p strong, .hero-text p strong {font-family: GothamMedium; display:inline-block; font-style:normal}

.hero p::before,
.hero-text p::before {
	content: "•";
	position: absolute;
	left: 0em;
	top: 0;
	color: var(--color-yellow);
	font-size: 0.9rem;
}

.hero h1 {
	font-size: 4rem;
	line-height: 1.2;
	font-weight: 400;
	margin-bottom: 2rem;
	font-family: GothamLight;
}

.hero strong {
	font-style: normal;
	position: relative;
	font-weight: 600;
	font-family: "GothamBookItalic";
	display: block;
}

.hero strong::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 4px;
}

.hero__buttons {
	display: flex;
	align-items: center;
	gap: 1.5rem;
}

.button {
	display: inline-flex;
	align-items: center;
	padding: 1.1rem 2rem 1.1rem 1.75rem;
	border-radius: 999px;
	background-color: var(--color-green);
	color: #ffffff;
	font-size: 0.9rem;
	font-weight: 700;
	letter-spacing: 1px;
	text-transform: uppercase;
	position: relative;
	transition: background-color 0.2s ease-in-out;
	border: none;
	font-family: GothamBook;
}

.button::before {
	content: "•";
	color: var(--color-yellow);
	margin-right: 0.5rem;
	font-size: 0.9rem;
}

.button:hover,
.button:focus {
	background-color: #7a945f;
}

.button-secondary {
	position: relative;
	font-size: 0.9rem;
	font-weight: 700;
	letter-spacing: 1px;
	text-transform: uppercase;
	color: var(--color-text);
	background: none;
	padding: 1rem 0rem;
	cursor: pointer;
}

.button-secondary::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0.2rem;
	width: 0%;
	height: 2px;
	background-color: var(--color-green);
	transition: width 0.2s ease-in-out;
}

.button-secondary:hover::after,
.button-secondary:focus::after {
	width: 100%;
}

.button-secondary:hover,
.button-secondary:focus {
	color: var(--color-green);
}

.intro-section {
	padding: 5vw 0;
}

.intro-heading {
	text-align: center;
	margin-bottom: 3rem;
}

.intro-heading p {
	display: inline-block;
	position: relative;
	font-size: 0.9rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1px;
	color: var(--color-green);
	margin-bottom: 1rem;
	font-family: GothamBook;
}

.intro-heading p::before {
	content: "•";
	position: absolute;
	left: -1.2em;
	top: 0;
	color: var(--color-yellow);
	font-size: 0.9rem;
}

.intro-heading h2 {
	font-size: 3rem;
	line-height: 1.2;
	font-weight: 400;
	color: var(--color-text);
	margin: 20px auto 0;
}

.intro-section__columns {
	column-count: 2;
	column-gap: 2.5rem;
	max-width: 95%;
	margin: 0 auto;
	text-align: left;
}

.intro-section__columns p {
	font-size: 1.1rem;
	line-height: 1.6;
	color: var(--color-text);
	break-inside: avoid;
	margin-bottom: 0rem;
}

.intro-section__columns p a {
	color: var(--color-green);
	border-bottom: 1px dashed var(--color-yellow);
}

.intro-section__columns p:first-child {
	text-align: right;
}

.services-cards .info-box:nth-child(2) {
	--box-alpha: 0.9;
}

.services-cards .info-box:nth-child(3) {
	--box-alpha: 0.8;
}

.services-cards .info-box:nth-child(4) {
	--box-alpha: 0.7;
}

.info-cards {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	grid-gap: 2rem;
	max-width: 1366px;
	margin: 0 auto;
}

.info-box {
	position: relative;
	--box-alpha: 1;
	background-color: rgba(var(--box-rgb), var(--box-alpha));
	border-radius: var(--box-radius);
	padding: 3rem 3rem 2.5rem 3rem;
	color: var(--color-text-light);
	overflow: hidden;
	min-height: 250px;
}

.info-box::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: 50%;
	height: 100%;
	background-image: url("/img/dragonflies.svg");
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	opacity: 0.3;
}

.info-box h3 {
	font-size: 46px;
	font-weight: 400;
	margin: 0 0 1rem;
	color: #fff;
	max-width: 70%;
	line-height: 1;
}

.info-box p {
	font-size: 1.1rem;
	line-height: 1.5;
	margin: 0;
	color: #fff;
	max-width: 80%;
}

.info-box .button {
	background: #758D55;
	margin-top: 25px;
}

.mobile-view {display: none;}

.feature__banner {
	position: relative;
	width: 90%;
	margin: 7vw 0
}

.feature__banner__overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: var(--overlay-color);
	z-index: 1;
	display: flex;
	align-items: center;
}

.feature__banner__content {
	position: relative;
	z-index: 2;
}

.feature__banner__content.wrapper {
	max-width: 80%;
}

.feature__banner__content p {
	display: inline-block;
	position: relative;
	font-size: 1rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 1px;
	padding-left: 15px;
	margin-bottom: 1.5rem;
	color: #fff;
}

.feature__banner__content p::before {
	content: "•";
	position: absolute;
	left: 0;
	top: 0;
	color: var(--color-yellow);
	font-size: 0.9rem;
}

.feature__banner__content h4 {
	font-size: 3.4rem;
	line-height: 1.1;
	font-weight: 400;
	margin: 0;
	color: #fff;
	max-width: 790px;
}

.feature__banner__content h4 strong {
	font-family: "GothamMediumItalic";
	position: relative;
}

.feature__banner__content h4 strong::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 4px;
	background-color: var(--highlight-underline);
	transform: translateY(4px);
	border-radius: 2px;
}

.highlight.text-center {
	text-align: center;
}

.highlight {
	margin: 0 auto 5vw
}

.highlight .book-now {
	display: inline-flex;
}

.highlight p {
	font-size: 3rem;
	margin-bottom: 2rem;
	letter-spacing: -2px;
}

.image-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	grid-gap: 20px;
}

.image-grid figure {
	background-color: #222;
	border-radius: var(--image-radius);
	overflow: hidden;
}

.image-grid img {
	width: 100%;
	height: auto;
	display: block;
	object-fit: cover;
	mix-blend-mode: luminosity;
}

.content {
	padding: 5vw 0
}

.content h2 {
	font-size: 35px;
	color: var(--color-green);
	font-family: GothamMedium;
}

.content h3 {
	font-size: 25px;
	color: var(--color-green);
	font-family: GothamMedium;
	margin: 25px 0
}

.content p {
	font-size: 17px;
	margin: 15px 0;
	line-height: 1.4;
	font-family: GothamLight;
}

.content ul {
	margin: 15px;
	padding: 0;
	line-height: 1.4;
	color: var(--color-text);
}

.content ul li::marker {
	color: var(--color-yellow);
}

.content ul li {
	font-size: 17px;
	font-family: GothamLight;
}

.content p em {
	font-size: 24px;
}

.content hr {border: none;border-top: 1px solid var(--color-border);margin: 3vw 0 2vw;}

/* ===========================
GET STARTED SECTION
=========================== */
.get-started {
	padding: 4rem 0rem;
	margin: 5vw auto 0;
	border-top: 1px solid #ccc;
}

.get-started__grid {
	display: grid;
	grid-template-columns: 1.5fr 1fr;
	gap: 9vw;
}

/* HEADINGS */
.get-started h2 {
	font-size: 99px;
	font-weight: 400;
	margin-bottom: 0.5rem;
	letter-spacing: -2px;
}

.get-started p {
	font-size: 32px;
}

/* CONTACT FORM */
.contact-form {
	margin-top: 50px;
}

.contact-form .form-row {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 2vw;
	margin-bottom: 1.5rem;
}

.contact-form .form-row.wide {
	grid-template-columns: repeat(1, 1fr);
}

.contact-form .form-row:last-child {
	grid-template-columns: 1fr;
	/* single column for textarea */
}

.contact-form input,
.contact-form select,
.contact-form textarea {
	width: 100%;
	background: none;
	border: none;
	border-bottom: 1px solid var(--color-border);
	font-size: 1rem;
	padding: 0.5rem 0;
	color: var(--color-text-dark);
	font-family: GothamBook;
	outline: none
}

.contact-form select {
	appearance: none;
	cursor: pointer;
}

.contact-form textarea {
	resize: vertical;
	min-height: 100px;
}

.contact-form input:-webkit-autofill,
.contact-form input:-webkit-autofill,
.contact-form input:-webkit-autofill:hover,
.contact-form input:-webkit-autofill:focus {
    background-color: #fff !important;
    box-shadow: 0 0 0px 1000px #fff inset !important;
    -webkit-text-fill-color: #1A1A1A !important;
    border-color: #e0e0e0 !important;
    font-family: inherit;
}

.contact-form input:-webkit-autofill,
.contact-form input:-webkit-autofill:focus {
    transition: background-color 9999s ease-out, color 9999s ease-out;
    -webkit-animation: autofill-fix 0s 9999s both;
}

@keyframes autofill-fix {
    100% {
        background-color: #ff;
        color: #1A1A1A;
    }
}

.contact-form[data-autocompleted] {
    background-color: transparent !important;
}

.form-wrapper {
		position: relative;
}

.highlight_message p {color: #61161f!important; background-color: #fdd!important; border: 1px solid #f1b7bf; width: 100%; text-align: center; padding: 15px; margin: 30px auto; border-radius: 15px; font-size: 18px; font-family: GothamBook;}
.success-message p {width: 100%; text-align: center; padding: 15px; margin: 30px auto; background: #889d69 !important; border-radius: 15px; color: #fff !important; border: 1px solid #889d69 !important; font-size: 18px; font-family: GothamBook;}

.form-field-missing input {color: #61161f; border-bottom: 1px solid #f1b7bf;}

#loader {display: none; position: absolute; left: 50%; top: 50%; z-index: 1; width: 30px; height: 30px; transform: translate(-50%, -50%); border: 5px solid #f3f3f3; border-radius: 50%; border-top: 5px solid #889d69; -webkit-animation: spin 2s linear infinite; animation: spin 2s linear infinite; transition: 0.3s; opacity: 1;}

@-webkit-keyframes spin { 0% { -webkit-transform: translate(-50%, -50%) rotate(0deg); } 100% { -webkit-transform: translate(-50%, -50%) rotate(360deg); }}

@keyframes spin { 0% { transform: translate(-50%, -50%) rotate(0deg); } 100% { transform: translate(-50%, -50%) rotate(360deg); }}

/* FORM ACTIONS: button + social icons */
.form-actions {
	display: flex;
	align-items: center;
	gap: 2rem;
	margin-top: 3rem;
	justify-content: space-between;
}

.actions-left {
	display: flex;
	align-items: center;
}

.social-icons {
	display: flex;
	gap: 0.5rem;
	margin-left: 20px;
}

.social-icons svg {
	width: 3rem;
	height: 3rem;
	object-fit: contain;
	cursor: pointer;
}

/* CONTACT INFO */
.contact-info {
	font-size: 1rem;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	text-align: left;
}

.contact-info a {
	color: var(--color-text-dark);
	text-decoration: none;
}

/* ===========================
TESTIMONIAL (RIGHT COLUMN)
=========================== */
.get-started .testimonial__tagline {
	display: inline-block;
	position: relative;
	font-size: 0.9rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 1px;
	color: var(--color-green);
	margin: 1rem 0;
	padding-left: 15px;
}

.testimonial__tagline::before {
	content: "•";
	position: absolute;
	left: 0;
	top: 0;
	color: var(--color-yellow);
	font-size: 1rem;
}

.testimonial {
	margin-bottom: 2rem;
}

.testimonial p {
	font-size: 1.8rem;
	font-weight: 300;
	margin-bottom: 0.8rem;
	line-height: 1.4;
}

.testimonial footer {
	font-size: 17px;
	font-weight: 500;
	text-align: left;
}

/* SLIDER NAVIGATION */
.slider-nav {
	display: flex;
	gap: 1rem;
}

.slider-nav button {
	width: 3rem;
	height: 3rem;
	background: none;
	border: 1px solid var(--color-border);
	border-radius: 50%;
	font-size: 1.5rem;
	line-height: 1;
	color: var(--color-text-dark);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* ===========================
SITE FOOTER
=========================== */
.site-footer {
	padding: 0 0 25px;
	background-color: #fff;
}

.footer__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 2rem;
	align-items: center;
	margin: 6.5rem auto 0rem;
}

.footer-nav {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.footer-nav a {
	color: var(--color-text-dark);
	font-size: 1rem;
	text-decoration: none;
	text-transform: uppercase;
}

.footer-logos {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 0.5rem;
}

.footer-logos img {
	max-height: 5rem;
	object-fit: contain;
}

.site-footer hr {
	border: none;
	border-top: 1px solid var(--color-border);
	margin-bottom: 1.5rem;
}

.footer-bottom {
	display: flex;
	justify-content: space-between;
	font-size: 12px;
	color: var(--color-text-dark);
}

.site-credit,
.site-credit a {
	color: #a0a0a0;
}

.classes-marquee__wrapper {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 4vw;
	overflow: hidden;
	min-width: 100vw;
	opacity: .3
}

.classes-marquee__track {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-webkit-justify-content: flex-start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-flex-wrap: nowrap;
	-ms-flex-wrap: nowrap;
	flex-wrap: nowrap
}

.classes-marquee__comp {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	width: 100%;
	min-width: 100vw;
	-webkit-justify-content: space-around;
	-ms-flex-pack: distribute;
	justify-content: space-around;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center
}

.classes-marquee__item {
	display: block;
	font-size: 1.125em;
	letter-spacing: .1em;
	text-transform: uppercase
}

.classes-marquee__wipper {
	position: absolute;
	left: 0;
	top: 0;
	right: auto;
	bottom: auto;
	z-index: 1;
	width: 33.333333333333336vw;
	height: 100%;
	background-image: -webkit-gradient(linear, left top, right top, color-stop(10%, #fff), to(rgba(240, 236, 230, 0)));
	background-image: linear-gradient(90deg, #fff 10%, rgba(240, 236, 230, 0));
}

.classes-marquee__wipper.is-right {
	left: auto;
	top: 0;
	right: 0;
	bottom: auto;
	background-image: -webkit-gradient(linear, right top, left top, color-stop(10%, #fff), to(rgba(240, 236, 230, 0)));
	background-image: linear-gradient(270deg, #fff 10%, rgba(240, 236, 230, 0))
}

.section-classes-window {
	position: relative;
	z-index: 1;
	border-top: 1px solid #000;
	background-color: #f0ece6
}

@keyframes scrollMarquee {
	0% {
		transform: translateX(0%);
	}

	100% {
		transform: translateX(-50%);
	}
}

.classes-marquee__track {
	display: flex;
	justify-content: flex-start;
	flex-wrap: nowrap;
	animation: scrollMarquee 20s linear infinite;
}



.testimonial-slider {
  position: relative;
  overflow: hidden;
  max-width: 600px; /* Adjust as needed */
}

.testimonial-slide {
  display: none;
  transition: opacity 0.5s ease;
}

.testimonial-slide.active {
  display: block;
}
