:root {
	--green-900: #0d4d2b;
	--green-700: #15703e;
	--green-500: #24a055;
	--green-300: #7bd68f;
	--green-100: #dff9e7;
	--mint-100: #effff3;
	--white: #ffffff;
	--ink: #163323;
	--ink-soft: #2f5943;
	--card-border: rgba(21, 112, 62, 0.18);
	--shadow-soft: 0 14px 30px rgba(19, 92, 50, 0.12);
	--shadow-lift: 0 16px 30px rgba(15, 77, 43, 0.2);
	--radius: 20px;
	--space-xl: clamp(4.2rem, 8vw, 7rem);
	--space-lg: clamp(2.8rem, 5vw, 4.5rem);
	--space-md: clamp(1.4rem, 2.5vw, 2rem);
}

* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
	scroll-padding-top: 110px;
}

body {
	margin: 0;
	line-height: 1.55;
	font-family: "Nunito", sans-serif;
	color: var(--ink);
	background:
		radial-gradient(circle at 4% 2%, rgba(123, 214, 143, 0.45), transparent 28%),
		radial-gradient(circle at 95% 18%, rgba(36, 160, 85, 0.2), transparent 35%),
		linear-gradient(180deg, #f4fff7 0%, #ffffff 52%, #f1fff5 100%);
}

h1,
h2,
h3,
.brand,
.btn {
	font-family: "Baloo 2", cursive;
	letter-spacing: 0.2px;
	margin: 0;
}

p,
ul {
	margin: 0;
}

img {
	border-radius: 20px;
	max-width: 100%;
	display: block;
}

.container {
	width: min(1160px, 92vw);
	margin: 0 auto;
}

.site-header {
	position: sticky;
	top: 0;
	z-index: 60;
	padding-top: 0.55rem;
	backdrop-filter: blur(16px) saturate(160%);
	-webkit-backdrop-filter: blur(16px) saturate(160%);
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.78), rgba(255, 255, 255, 0.56));
	border-bottom: 1px solid rgba(21, 112, 62, 0.1);
}

.nav-wrap {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	min-height: 82px;
}

.brand {
	text-decoration: none;
	color: var(--green-900);
	font-size: clamp(1.2rem, 1.6vw, 1.55rem);
	line-height: 1;
}

.site-nav {
	display: flex;
	align-items: center;
	gap: 1.2rem;
	flex-wrap: wrap;
}

.site-nav a {
	text-decoration: none;
	color: var(--green-900);
	font-weight: 700;
	position: relative;
}

.site-nav a::after {
	content: "";
	position: absolute;
	height: 2px;
	width: 0;
	left: 0;
	bottom: -3px;
	background: var(--green-700);
	transition: width 0.25s ease;
}

.site-nav a:hover::after {
	width: 100%;
}

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: none;
	text-decoration: none;
	cursor: pointer;
	min-height: 46px;
	padding: 0.78rem 1.25rem;
	border-radius: 13px;
	font-size: 1.07rem;
	line-height: 1.1;
	text-align: center;
	transition: transform 0.22s ease, box-shadow 0.22s ease;
}

.btn:hover {
	transform: translateY(-3px);
	box-shadow: var(--shadow-lift);
}

.btn-primary {
	color: var(--white);
	background: linear-gradient(135deg, var(--green-700), var(--green-500));
	box-shadow: 0 10px 24px rgba(21, 112, 62, 0.24);
}

.btn-secondary {
	color: var(--green-900);
	background: var(--green-100);
	box-shadow: 0 8px 18px rgba(21, 112, 62, 0.14);
}

.panel {
	padding: var(--space-xl) 0;
}

.panel-tight {
	padding: 1rem 0 0;
}

.hero-panel {
	padding-top: calc(var(--space-xl) + 1rem);
	padding-bottom: var(--space-lg);
}

.hero-grid,
.booking-grid {
	display: grid;
	gap: var(--space-md);
	grid-template-columns: 1.2fr 0.8fr;
	align-items: start;
}

.kicker {
	display: inline-block;
	padding: 0.36rem 0.76rem;
	border-radius: 999px;
	font-size: 0.81rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	background: var(--green-100);
	font-weight: 700;
	margin-bottom: 0.9rem;
}

h1 {
	font-size: clamp(2.8rem, 6vw, 5rem);
	line-height: 0.95;
	margin-bottom: 1rem;
}

.lead {
	font-size: clamp(1.05rem, 1.7vw, 1.25rem);
	max-width: 52ch;
	color: var(--ink-soft);
}

.hero-actions {
	display: flex;
	gap: 0.75rem;
	flex-wrap: wrap;
	margin: 1.5rem 0 1rem;
}

.local-note {
	font-weight: 700;
	color: var(--green-700);
}

.hero-card,
.price-card,
.review-card,
.contact-card,
.booking-form,
.trust-pill,
.faq-item {
	background: rgba(255, 255, 255, 0.85);
	border-radius: var(--radius);
	padding: 1.25rem;
	box-shadow: var(--shadow-soft);
	border: 1px solid var(--card-border);
	transition: transform 0.24s ease, box-shadow 0.24s ease;
}

.hero-card:hover,
.price-card:hover,
.review-card:hover,
.trust-pill:hover,
.faq-item:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-lift);
}

.hero-card ul,
.price-card ul {
	padding-left: 1.1rem;
	margin: 0.8rem 0 1rem;
}

.hero-card li,
.price-card li {
	margin-bottom: 0.35rem;
}

.trust-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 0.85rem;
	padding-bottom: var(--space-md);
}

.trust-pill h3 {
	font-size: 1.22rem;
	margin-bottom: 0.2rem;
}

.trust-pill p {
	color: var(--ink-soft);
	font-size: 0.97rem;
}

.section-head {
	margin-bottom: 1.7rem;
	max-width: 70ch;
}

.section-head h2 {
	font-size: clamp(2rem, 4vw, 3.3rem);
	line-height: 0.98;
	margin-bottom: 0.4rem;
}

.section-head p {
	color: var(--ink-soft);
}

.bento-grid,
.reviews-grid {
	display: grid;
	gap: 1rem;
}

.bento-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
	grid-auto-rows: minmax(180px, auto);
}

.bento-card {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}

.bento-wide {
	grid-column: span 2;
}

.bento-tall {
	grid-row: span 2;
}

.bento-feature {
	background: linear-gradient(145deg, rgba(223, 249, 231, 0.92), rgba(255, 255, 255, 0.9));
}

.price-card .price {
	margin: 0.3rem 0 0.7rem;
	font-size: 2.3rem;
	font-weight: 800;
	color: var(--green-900);
}

.price-card .price span {
	font-size: 1rem;
	font-weight: 700;
	color: #35674b;
}

.featured {
	border: 2px solid var(--green-500);
	background: linear-gradient(165deg, rgba(255, 255, 255, 0.94), rgba(236, 255, 241, 0.82));
}

.badge {
	display: inline-block;
	margin-bottom: 0.4rem;
	font-size: 0.82rem;
	font-weight: 800;
	color: var(--white);
	background: var(--green-700);
	border-radius: 10px;
	padding: 0.22rem 0.64rem;
}

.booking-panel {
	padding-top: var(--space-lg);
	padding-bottom: var(--space-lg);
	background: linear-gradient(180deg, rgba(123, 214, 143, 0.16), rgba(123, 214, 143, 0.06));
}

.contact-card {
	margin: 1rem 0;
}

.contact-card p {
	overflow-wrap: anywhere;
	margin-bottom: 0.3rem;
}

.booking-form {
	display: grid;
	gap: 0.65rem;
}

label {
	font-weight: 700;
	font-size: 0.96rem;
}

input,
textarea {
	width: 100%;
	border: 1px solid #b7debf;
	border-radius: 12px;
	padding: 0.82rem;
	min-height: 46px;
	font-family: inherit;
	font-size: 1rem;
	background: var(--white);
}

textarea {
	min-height: 120px;
	resize: vertical;
}

input:focus,
textarea:focus {
	outline: 2px solid rgba(21, 112, 62, 0.32);
	border-color: var(--green-700);
}

#form-status {
	min-height: 1.2rem;
	font-weight: 700;
	color: var(--green-700);
}

.faq-panel {
	padding-top: var(--space-lg);
}

.faq-list {
	display: grid;
	gap: 0.75rem;
}

.faq-item {
	padding: 0.35rem 1rem;
}

.faq-trigger {
	width: 100%;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
	border: 0;
	background: transparent;
	padding: 0.7rem 0;
	font-family: "Nunito", sans-serif;
	font-size: 1.05rem;
	font-weight: 800;
	color: var(--ink);
	cursor: pointer;
	text-align: left;
}

.faq-icon {
	font-family: "Baloo 2", cursive;
	font-size: 1.5rem;
	line-height: 1;
	color: var(--green-700);
	transition: transform 0.22s ease;
}

.faq-item.open .faq-icon {
	transform: rotate(45deg);
}

.faq-content {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.32s ease;
}

.faq-content p {
	padding: 0 0 0.7rem;
	color: var(--ink-soft);
}

.reviews-panel {
	position: relative;
	padding-top: var(--space-lg);
}

.reviews-panel::before {
	content: "";
	position: absolute;
	width: 240px;
	height: 240px;
	border-radius: 50%;
	background: rgba(36, 160, 85, 0.08);
	top: 20px;
	right: 1%;
	filter: blur(2px);
	pointer-events: none;
}

.reviews-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.review-card p {
	font-size: 1.08rem;
	margin-bottom: 0.8rem;
}

cite {
	display: block;
	margin-bottom: 0.7rem;
	font-style: normal;
	font-weight: 700;
	color: var(--ink-soft);
}

.site-footer {
	padding: 1.7rem 0 2.8rem;
}

.footer-wrap {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: wrap;
	padding-top: 0.2rem;
}

.mobile-fab {
	position: fixed;
	right: 1rem;
	bottom: 1rem;
	z-index: 70;
	display: none;
	background: linear-gradient(140deg, var(--green-700), var(--green-500));
	color: var(--white);
	text-decoration: none;
	font-family: "Baloo 2", cursive;
	font-size: 1.03rem;
	border-radius: 999px;
	padding: 0.75rem 1.1rem;
	box-shadow: var(--shadow-lift);
	min-height: 46px;
	align-items: center;
	justify-content: center;
}

[data-reveal] {
	opacity: 0;
	transform: translateY(22px);
	transition: opacity 0.58s ease, transform 0.58s ease;
}

[data-reveal].visible {
	opacity: 1;
	transform: translateY(0);
}

@media (max-width: 1024px) {
	.hero-grid,
	.booking-grid,
	.bento-grid,
	.reviews-grid,
	.trust-grid {
		grid-template-columns: 1fr;
	}

	.bento-wide,
	.bento-tall {
		grid-column: span 1;
		grid-row: span 1;
	}

	.site-nav {
		display: none;
	}

	.panel {
		padding: var(--space-lg) 0;
	}
}

@media (max-width: 720px) {
	.container {
		width: min(1160px, 94vw);
	}

	.nav-wrap {
		align-items: flex-start;
		flex-wrap: wrap;
		gap: 0.6rem;
		padding-bottom: 0.65rem;
	}

	.nav-wrap > .btn {
		width: 100%;
	}

	h1 {
		font-size: clamp(2.2rem, 11vw, 3rem);
		line-height: 0.96;
	}

	.hero-actions {
		flex-direction: column;
	}

	.hero-actions .btn,
	.price-card .btn,
	.review-card .btn,
	.footer-wrap .btn,
	.booking-form .btn {
		width: 100%;
	}

	.section-head h2 {
		font-size: clamp(1.8rem, 9vw, 2.3rem);
	}

	.hero-card,
	.price-card,
	.review-card,
	.contact-card,
	.booking-form,
	.trust-pill,
	.faq-item {
		padding: 1rem;
	}

	.mobile-fab {
		display: inline-flex;
	}

	.footer-wrap {
		justify-content: center;
		text-align: center;
	}
}

@media (max-width: 390px) {
	.kicker {
		font-size: 0.72rem;
	}

	.btn,
	input,
	textarea,
	.faq-trigger {
		font-size: 0.96rem;
	}
}
