/* =========================================================
   Section: home_hero (editorial)
   ========================================================= */

.home-hero {
	background:
		radial-gradient(80% 60% at 0% 0%, rgba(46, 90, 69, 0.06) 0%, transparent 60%),
		var(--color-bg-base);
	padding-top: var(--space-7);
}
.home-hero__inner {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
	gap: var(--space-8);
	align-items: center;
}
@media (max-width: 960px) {
	.home-hero__inner { grid-template-columns: 1fr; gap: var(--space-6); }
}

.home-hero__copy { max-width: 36rem; }

.home-hero__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	color: var(--color-brand-primary);
	margin: 0 0 var(--space-4);
}
.home-hero__eyebrow-dot {
	display: inline-block;
	width: 7px; height: 7px;
	background: var(--color-success);
	border-radius: 50%;
}

.home-hero__title {
	font-family: var(--font-display);
	font-size: clamp(2.25rem, 5vw, 4.25rem);
	line-height: 1.04;
	letter-spacing: -0.02em;
	font-weight: 500;
	color: var(--color-ink-primary);
	margin: 0 0 var(--space-4);
	max-width: 18ch;
}

.home-hero__sub {
	font-size: var(--fs-body-l);
	color: var(--color-ink-secondary);
	line-height: 1.55;
	margin: 0 0 var(--space-6);
	max-width: 48ch;
}

.home-hero__ctas {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
	margin-bottom: var(--space-6);
}

.home-hero__signals {
	display: flex;
	flex-wrap: wrap;
	gap: 10px var(--space-5);
	list-style: none;
	padding: 0;
	margin: 0;
	font-size: var(--fs-body-s);
	color: var(--color-ink-muted);
}
.home-hero__signals li {
	position: relative;
	padding-left: 18px;
	margin: 0;
}
.home-hero__signals li::before {
	content: "";
	position: absolute;
	left: 0; top: 50%;
	transform: translateY(-50%);
	width: 8px; height: 8px;
	border-radius: 50%;
	background: var(--color-secondary);
}

/* Media */
.home-hero__media {
	position: relative;
	margin: 0;
}
.home-hero__image {
	aspect-ratio: 5 / 6;
	border-radius: var(--radius-lg);
	overflow: hidden;
	background: var(--color-bg-subtle);
	box-shadow: var(--shadow-md);
}
.home-hero__image-placeholder {
	background:
		radial-gradient(60% 40% at 30% 20%, rgba(250, 244, 232, 0.55) 0%, transparent 70%),
		radial-gradient(50% 40% at 80% 80%, rgba(226, 106, 76, 0.18) 0%, transparent 70%),
		linear-gradient(135deg, var(--color-secondary-soft) 0%, var(--color-brand-primary-soft) 100%);
}
.home-hero__caption {
	position: absolute;
	left: var(--space-4); bottom: var(--space-4);
	background: rgba(28, 38, 32, 0.75);
	color: var(--color-bg-base);
	font-size: var(--fs-caption);
	padding: 6px 12px;
	border-radius: var(--radius-pill);
	backdrop-filter: blur(8px);
}

/* Floating social-proof badge */
.home-hero__badge {
	position: absolute;
	left: calc(-1 * var(--space-5));
	bottom: 15%;
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 16px;
	background: var(--color-bg-surface);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-lg);
	max-width: 280px;
}
.home-hero__badge-stars {
	display: inline-flex;
	gap: 2px;
	color: var(--color-secondary);
	flex: 0 0 auto;
}
.home-hero__badge-rating {
	margin: 0;
	font-size: var(--fs-body-s);
	color: var(--color-ink-primary);
	line-height: 1.3;
}
.home-hero__badge-rating strong {
	font-family: var(--font-display);
	font-size: 1.0625rem;
	font-weight: 600;
}
.home-hero__badge-rating span {
	color: var(--color-ink-muted);
	font-weight: 400;
	font-size: var(--fs-caption);
}
.home-hero__badge-context {
	margin: 2px 0 0;
	font-size: 11px;
	color: var(--color-ink-muted);
	letter-spacing: 0.02em;
}

/* Floating delivery chip */
.home-hero__chip {
	position: absolute;
	right: calc(-1 * var(--space-3));
	top: 12%;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 16px;
	background: var(--color-ink-primary);
	color: var(--color-bg-base);
	font-size: var(--fs-body-s);
	font-weight: 500;
	border-radius: var(--radius-pill);
	box-shadow: var(--shadow-md);
	max-width: 260px;
}
.home-hero__chip-dot {
	width: 8px; height: 8px;
	background: var(--color-success);
	border-radius: 50%;
	flex: 0 0 auto;
	box-shadow: 0 0 0 4px rgba(90, 125, 90, 0.25);
	animation: heroPulse 2.4s ease-in-out infinite;
}
@keyframes heroPulse {
	0%, 100% { box-shadow: 0 0 0 4px rgba(90, 125, 90, 0.25); }
	50%      { box-shadow: 0 0 0 8px rgba(90, 125, 90, 0); }
}

@media (max-width: 960px) {
	.home-hero__image { aspect-ratio: 4 / 3; }
	.home-hero__badge {
		left: var(--space-3);
		bottom: var(--space-3);
		max-width: 240px;
	}
	.home-hero__chip {
		right: var(--space-3);
		top: var(--space-3);
		max-width: 220px;
	}
}
@media (max-width: 540px) {
	.home-hero__badge { display: none; }
	.home-hero__chip {
		font-size: var(--fs-caption);
		padding: 8px 12px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.home-hero__chip-dot { animation: none; }
}
