:root {
	--pear: #b8d94f;
	--pear-dark: #7b9c22;
	--sun: #ffbe55;
	--sunset: #ff8d7b;
	--sky: #89e4ff;
	--ocean: #39c6da;
	--deep-ocean: #168aa6;
	--sand: #fff2cf;
	--palm: #2e8856;
	--leaf: #49ae71;
	--white: #ffffff;
	--text: #402d2d;
	--shadow: 0 20px 45px rgba(0, 0, 0, 0.14);
	--radius-xl: 34px;
	--radius-lg: 26px;
	--radius-md: 18px;
	--max: 1200px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
	margin: 0;
	font-family: 'Montserrat', sans-serif;
	color: var(--text);
	background:
		radial-gradient(circle at top left, rgba(255,255,255,.38), transparent 24%),
		linear-gradient(180deg, #74dfff 0%, #a7eeff 26%, #ffe7a8 66%, #ffd49f 100%);
	min-height: 100vh;
	overflow-x: hidden;
}

body::before,
body::after {
	content: "";
	position: fixed;
	width: 330px;
	height: 330px;
	border-radius: 50%;
	filter: blur(55px);
	opacity: .22;
	pointer-events: none;
	z-index: 0;
}

body::before {
	top: -100px;
	right: -70px;
	background: var(--sunset);
}

body::after {
	left: -80px;
	bottom: -110px;
	background: var(--ocean);
}

.shell {
	position: relative;
	z-index: 1;
}

.topbar {
	position: sticky;
	top: 0;
	z-index: 50;
	backdrop-filter: blur(18px);
	background: rgba(255,255,255,.72);
	border-bottom: 1px solid rgba(255,255,255,.55);
}

.nav {
	max-width: var(--max);
	margin: 0 auto;
	padding: 14px 20px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
}

.brand {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	text-decoration: none;
	color: var(--text);
}

.pear-icon {
	width: 54px;
	height: 54px;
	border-radius: 26px;
	display: grid;
	place-items: center;
	background: linear-gradient(145deg, #dff88d, #9ac92e);
	filter: drop-shadow(0 10px 20px rgba(0,0,0,0.4));
	font-size: 1.5rem;
	background-image: url("/assets/img/logo.png");
	background-size: contain;
}

.brand h1 {
	margin: 0;
	font-family: 'Baloo 2', cursive;
	font-size: 2rem;
	line-height: .9;
}

.brand span {
	display: block;
	margin-top: 4px;
	font-size: .82rem;
	font-weight: 800;
	color: var(--pear-dark);
	letter-spacing: .08em;
	text-transform: uppercase;
}

.nav-links {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	gap: 10px;
}

.nav-links a {
	text-decoration: none;
	color: var(--text);
	font-weight: 800;
	padding: 10px 14px;
	border-radius: 999px;
	transition: .22s ease;
}

.nav-links a:hover {
	background: rgba(255,255,255,.82);
	transform: translateY(-2px);
}

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	padding: 14px 22px;
	border-radius: 999px;
	text-decoration: none;
	font-weight: 800;
	border: none;
	cursor: pointer;
	transition: .22s ease;
	font-family: inherit;
}

.btn-primary {
	background: linear-gradient(135deg, var(--pear), var(--sun));
	color: #3f2c00;
	box-shadow: 0 14px 28px rgba(255,190,85,.28);
}

.btn-secondary {
	background: rgba(255,255,255,.72);
	color: var(--text);
	border: 1px solid rgba(255,255,255,.72);
}

.btn:hover { transform: translateY(-3px); }

.hero {
	max-width: var(--max);
	margin: 0 auto;
	padding: 54px 20px 28px;
	display: grid;
	grid-template-columns: 1.08fr .92fr;
	gap: 28px;
	align-items: center;
}

.glass,
.hero-copy,
.hero-art,
.card,
.promo-card,
.link-card,
.footer-card {
	background: rgba(255,255,255,.72);
	border: 1px solid rgba(255,255,255,.58);
	box-shadow: var(--shadow);
	backdrop-filter: blur(14px);
}

.hero-copy {
	border-radius: 36px;
	padding: 34px;
	position: relative;
	overflow: hidden;
}

.hero-copy::before {
	content: "";
	position: absolute;
	width: 250px;
	height: 250px;
	border-radius: 50%;
	top: -70px;
	right: -35px;
	background: radial-gradient(circle, rgba(255,190,85,.24), transparent 70%);
}

.eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 9px 14px;
	border-radius: 999px;
	background: rgba(255,255,255,.9);
	color: var(--pear-dark);
	font-weight: 800;
	font-size: .82rem;
	letter-spacing: .05em;
	margin-bottom: 16px;
}

.hero h1,
.hero h2 {
	margin: 0;
	font-family: 'Baloo 2', cursive;
	font-size: clamp(1rem, 6vw, 2rem);
	line-height: .92;
}

.hero h1,
.hero h2 .accent { color: var(--pear-dark); }

.hero p {
	margin: 18px 0 0;
	font-size: 1.07rem;
	line-height: 1.72;
	max-width: 640px;
}

.hero-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 26px;
}

.hero-art {
	aspect-ratio: 16 / 9;
width: 100%;
	border-radius: 36px;
	position: relative;
	overflow: hidden;
	background: linear-gradient(180deg, rgba(135,225,255,.96), rgba(255,234,190,.95));
	background-image: url("/assets/img/PearadiseLive_Horz.jpg");
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

.sun {
	position: absolute;
	top: 34px;
	right: 34px;
	width: 132px;
	height: 132px;
	border-radius: 50%;
	background: radial-gradient(circle at 38% 38%, #fff7cf 0%, #ffd763 44%, #ffaf38 75%);
	box-shadow: 0 0 55px rgba(255,183,64,.44);
}

.cloud {
	position: absolute;
	background: rgba(255,255,255,.82);
	border-radius: 999px;
}

.cloud::before,
.cloud::after {
	content: "";
	position: absolute;
	background: inherit;
	border-radius: 50%;
}

.cloud.one { top: 88px; left: 56px; width: 112px; height: 28px; }
.cloud.one::before { width: 38px; height: 38px; left: 10px; top: -15px; }
.cloud.one::after { width: 50px; height: 50px; right: 10px; top: -23px; }

.cloud.two { top: 152px; right: 112px; width: 85px; height: 22px; }
.cloud.two::before { width: 30px; height: 30px; left: 3px; top: -12px; }
.cloud.two::after { width: 34px; height: 34px; right: 4px; top: -16px; }

.ocean {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 95px;
	height: 130px;
	background: linear-gradient(180deg, rgba(69,211,228,.93), rgba(19,156,182,.95));
	border-top-left-radius: 55% 34px;
	border-top-right-radius: 50% 34px;
}

.shore {
	position: absolute;
	left: -6%;
	right: -6%;
	bottom: 0;
	height: 134px;
	background: linear-gradient(180deg, #ffe8b2, #ffd194);
	border-top-left-radius: 50% 42px;
	border-top-right-radius: 50% 44px;
}

.palm {
	position: absolute;
	bottom: 75px;
	width: 20px;
	border-radius: 999px;
	background: linear-gradient(180deg, #8b623c, #6b4828);
	transform-origin: bottom center;
}

.palm.left { height: 220px; left: 82px; transform: rotate(-10deg); }
.palm.right { height: 190px; right: 84px; transform: rotate(12deg); }

.leafset {
	position: absolute;
	width: 170px;
	height: 170px;
}

.leaf {
	position: absolute;
	width: 112px;
	height: 18px;
	border-radius: 999px;
	background: linear-gradient(90deg, var(--palm), var(--leaf));
	transform-origin: left center;
	box-shadow: inset -12px 0 0 rgba(255,255,255,.08);
}

.leaf.a { transform: rotate(-55deg); top: 38px; left: 30px; }
.leaf.b { transform: rotate(-28deg); top: 58px; left: 50px; }
.leaf.c { transform: rotate(0deg); top: 78px; left: 58px; }
.leaf.d { transform: rotate(28deg); top: 98px; left: 48px; }
.leaf.e { transform: rotate(52deg); top: 114px; left: 26px; }

.leafset.left { left: 4px; bottom: 252px; }
.leafset.right { right: -6px; bottom: 215px; transform: scale(.92); }

.floating-card {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	bottom: 146px;
	width: min(86%, 372px);
	background: rgba(255,255,255,.88);
	border-radius: 28px;
	padding: 22px;
	box-shadow: var(--shadow);
	text-align: center;
}

.floating-card h3 {
	margin: 0;
	font-family: 'Baloo 2', cursive;
	font-size: 1.85rem;
	line-height: 1;
}

.floating-card p {
	margin: 10px 0 0;
	font-size: .97rem;
	line-height: 1.65;
}

.section {
	max-width: var(--max);
	margin: 0 auto;
	padding: 18px 20px 30px;
}

.section-heading {
	display: flex;
	align-items: end;
	justify-content: space-between;
	gap: 18px;
	flex-wrap: wrap;
	margin-bottom: 18px;
}

.section-heading h3 {
	margin: 0;
	font-family: 'Baloo 2', cursive;
	font-size: clamp(2rem, 4vw, 3rem);
	line-height: .95;
}

.section-heading p {
	margin: 0;
	max-width: 650px;
	line-height: 1.7;
	font-weight: 500;
}

.grid-3,
.promo-grid,
.link-grid,
.footer-grid {
	display: grid;
	gap: 18px;
}

.grid-3,
.promo-grid,
.link-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.footer-grid { grid-template-columns: 1.1fr .9fr; }

.card,
.promo-card,
.link-card,
.footer-card {
	border-radius: 28px;
	padding: 22px;
	transition: .24s ease;
}

.card:hover,
.promo-card:hover,
.link-card:hover { transform: translateY(-5px); }

.emoji {
	font-size: 2rem;
	margin-bottom: 10px;
	display: inline-block;
}

h4 {
	margin: 0;
	font-family: 'Baloo 2', cursive;
	font-size: 1.65rem;
	line-height: 1;
}

.card p,
.promo-card p,
.link-card p,
.footer-card p,
.footer-card li {
	line-height: 1.7;
}

.card p,
.promo-card p,
.link-card p,
.footer-card p {
	margin: 12px 0 0;
}

.chips {
	margin-top: 14px;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.chip {
	padding: 8px 12px;
	border-radius: 999px;
	background: rgba(184,217,79,.18);
	color: var(--pear-dark);
	font-size: .84rem;
	font-weight: 800;
}

.promo-card.featured {
	background: linear-gradient(135deg, rgba(245, 199, 47, 0.78), rgba(255,255,255,.6));
	border: 1px solid rgba(255,255,255,.68);
}

.promo-links {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 16px;
}

a.inline-link,
.promo-card a,
.link-card a,
.footer-card a {
	color: var(--deep-ocean);
	font-weight: 800;
	text-decoration: none;
}

a.inline-link:hover,
.promo-card a:hover,
.link-card a:hover,
.footer-card a:hover {
	text-decoration: underline;
}

.promo-card ul,
.link-card ul,
.footer-card ul {
	list-style: none;
	margin: 14px 0 0;
	padding: 0;
	display: grid;
	gap: 12px;
}

.promo-card li,
.link-card li,
.footer-card li {
	background: rgba(255,255,255,.55);
	padding: 12px 14px;
	border-radius: 16px;
	font-weight: 700;
}

.cta {
	max-width: var(--max);
	margin: 8px auto 30px;
	padding: 0 20px;
}

.cta-inner {
	border-radius: 34px;
	padding: 30px;
	background: linear-gradient(135deg, rgba(184,217,79,.92), rgba(255,190,85,.94), rgba(57,198,218,.93));
	box-shadow: var(--shadow);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	flex-wrap: wrap;
}

.cta-inner h3 {
	margin: 0;
	font-family: 'Baloo 2', cursive;
	font-size: clamp(2rem, 4vw, 3rem);
	line-height: .95;
	color: #3d2b00;
}

.cta-inner p {
	margin: 10px 0 0;
	max-width: 650px;
	line-height: 1.7;
	color: #503700;
	font-weight: 700;
}

.tiktok-bg {
		position: relative;
		overflow: hidden;
}

.tiktok-bg::before {
		content: "";
		position: absolute;
		inset: 0;
		background-image: url("/assets/img/violation.png");
		background-size: contain;
		background-position: center;
		background-repeat: no-repeat;
		opacity: 0.5;
		z-index: 0;
}


footer {
	max-width: var(--max);
	margin: 0 auto;
	padding: 0 20px 44px;
}

.tiny {
	margin-top: 18px;
	text-align: center;
	font-size: .92rem;
	font-weight: 700;
	color: rgba(64,45,45,.74);
}

/* === FEATURE LINK CARDS (Homepage Internal Linking) === */

.feature-links {
max-width: var(--max);
margin: 20px auto 40px;
padding: 0 20px;
}

.feature-grid {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 18px;
}

.feature-card {
display: block;
text-decoration: none;
padding: 22px;
border-radius: 28px;
background: rgba(255,255,255,.72);
border: 1px solid rgba(255,255,255,.58);
box-shadow: var(--shadow);
backdrop-filter: blur(14px);
transition: .24s ease;
color: var(--text);
}

.feature-card:hover {
transform: translateY(-5px);
}

.feature-card h2 {
margin: 0;
font-family: 'Baloo 2', cursive;
font-size: 1.7rem;
line-height: 1;
}

.feature-card p {
margin: 12px 0 0;
line-height: 1.7;
font-weight: 500;
}

/* Optional subtle color accents per card */
.feature-card:nth-child(1) {
background: linear-gradient(135deg, rgba(184,217,79,.25), rgba(255,255,255,.7));
}

.feature-card:nth-child(2) {
background: linear-gradient(135deg, rgba(57,198,218,.25), rgba(255,255,255,.7));
}

.feature-card:nth-child(3) {
background: linear-gradient(135deg, rgba(255,190,85,.25), rgba(255,255,255,.7));
}

/* Mobile */
@media (max-width: 900px) {
.feature-grid {
	grid-template-columns: 1fr;
}
}


@media (max-width: 1050px) {
	.hero,
	.grid-3,
	.promo-grid,
	.link-grid,
	.footer-grid {
		grid-template-columns: 1fr 1fr;
	}

	.hero { grid-template-columns: 1fr; }
	.footer-grid { grid-template-columns: 1fr; }
}

@media (max-width: 700px) {
	.nav {
		flex-direction: column;
		align-items: stretch;
	}

	.brand,
	.nav-links { justify-content: center; }

	.hero-copy,
	.hero-art,
	.card,
	.promo-card,
	.link-card,
	.footer-card,
	.cta-inner {
		border-radius: 24px;
		padding: 20px;
	}

	.grid-3,
	.promo-grid,
	.link-grid { grid-template-columns: 1fr; }

	.sun { width: 104px; height: 104px; }
	.floating-card { bottom: 136px; }
	.palm.left { left: 54px; }
	.palm.right { right: 52px; }
}

.social-list li {
	display: flex;
	align-items: center;
}

.social-list li a {
	display: flex;
	align-items: center;
	gap: 12px;
}

.social-list img {
	width: 22px;
	height: 22px;
	object-fit: contain;
	flex-shrink: 0;
}


		.lightbox {
	position: fixed;
	inset: 0;
	background: rgba(7, 10, 15, .94);
	display: none;
	align-items: center;
	justify-content: center;
	z-index: 9999;
	padding: 20px;
}

.lightbox.active {
	display: flex;
}

.lightbox-inner {
	position: relative;
	width: min(100%, 1400px);
	height: 100vh;
	box-sizing: border-box;
	padding-top: 72px;
	padding-bottom: 110px; /* extra room for controls + caption */
}

.lightbox-media {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}

.lightbox-media img {
	display: block;
	max-width: 100%;
	max-height: 100%;
	width: auto;
	height: auto;
	border-radius: 18px;
	background: #000;
	box-shadow: 0 18px 55px rgba(0,0,0,.45);
}

.lightbox-media video {
	display: block;
	width: 100%;
	height: 100%;
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
	border-radius: 18px;
	background: #000;
	box-shadow: 0 18px 55px rgba(0,0,0,.45);
}

.lightbox-close {
	position: absolute;
	top: 12px;
	left: 0;
	border: 0;
	border-radius: 999px;
	padding: 12px 18px;
	font-weight: 800;
	font-family: inherit;
	cursor: pointer;
	background: rgba(255,255,255,.9);
	color: #111;
	box-shadow: 0 10px 28px rgba(0,0,0,.25);
	z-index: 3;
}

.lightbox-caption {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	bottom: 12px;
	width: min(100%, 920px);
	text-align: center;
	color: #fff;
	font-weight: 700;
	line-height: 1.6;
	padding: 0;
	z-index: 3;
}

@media (max-width: 700px) {
	.lightbox {
		padding: 12px;
	}

	.lightbox-inner {
		padding-top: 76px;
		padding-bottom: 120px;
	}

	.lightbox-close {
		top: 8px;
		left: 0;
	}
}

.visually-hidden {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}