/* ─── Homepage Hero (centered) ────────────────────────────────────── */

.dp-home-hero {
	position: relative;
	padding: clamp(4rem, 9vw, 7rem) 0 clamp(3rem, 6vw, 5rem);
	overflow: hidden;
}

.dp-home-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	background:
		radial-gradient(60% 50% at 50% 0%, color-mix(in srgb, var(--dp-primary) 7%, transparent), transparent 70%);
	z-index: 0;
}

.dp-home-hero .dp-container {
	position: relative;
	z-index: 1;
}

.dp-home-hero__inner {
	max-width: 760px;
	margin: 0 auto;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.dp-home-hero__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 13px;
	font-weight: 500;
	color: var(--dp-text-2);
	background: var(--dp-surface);
	border: 1px solid var(--dp-border);
	border-radius: 999px;
	padding: 6px 14px;
	margin: 0 0 24px;
}

.dp-home-hero__eyebrow strong {
	color: var(--dp-text);
	font-weight: 700;
}

.dp-home-hero__eyebrow-dot {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--dp-primary);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--dp-primary) 18%, transparent);
}

.dp-home-hero__title {
	font-size: var(--dp-fs-hero);
	font-weight: 700;
	letter-spacing: -0.045em;
	line-height: 1.05;
	color: var(--dp-text);
	margin: 0 0 20px;
	max-width: 14ch;
}

.dp-home-hero__title em {
	font-style: normal;
	background: linear-gradient(135deg, var(--dp-primary), var(--dp-primary-300));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.dp-home-hero__sub {
	font-size: clamp(16px, 1.5vw, 18px);
	color: var(--dp-text-2);
	margin: 0 0 32px;
	line-height: 1.6;
	max-width: 56ch;
}

.dp-home-hero__actions {
	display: flex;
	gap: 12px;
	margin-bottom: clamp(2.5rem, 5vw, 4rem);
	flex-wrap: wrap;
	justify-content: center;
}

.dp-home-hero__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	min-height: var(--dp-btn-h);
	padding: var(--dp-btn-py-lg) var(--dp-btn-px-lg);
	font-family: var(--dp-font);
	font-size: var(--dp-btn-fs);
	font-weight: 600;
	line-height: 1;
	border: 1px solid transparent;
	border-radius: var(--dp-btn-r);
	cursor: pointer;
	text-decoration: none;
	transition: color 0.15s, background-color 0.15s, border-color 0.15s, transform 0.15s;
}

.dp-home-hero__btn--filled {
	background-color: var(--dp-primary);
	color: #fff;
	box-shadow: 0 8px 24px color-mix(in srgb, var(--dp-primary) 28%, transparent);
}

.dp-home-hero__btn--filled:hover {
	background-color: var(--dp-primary-hover);
	color: #fff;
	transform: translateY(-1px);
}

.dp-home-hero__btn--ghost {
	background-color: var(--dp-surface);
	color: var(--dp-text);
	border-color: var(--dp-border);
}

.dp-home-hero__btn--ghost:hover {
	border-color: var(--dp-border-hover);
	background-color: var(--dp-bg-alt);
}

/* Plugin icon strip — quiet horizontal proof row */
.dp-home-hero__strip {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	justify-content: center;
}

.dp-home-hero__strip-item {
	display: grid;
	place-items: center;
	width: 56px;
	height: 56px;
	background: var(--dp-surface);
	border: 1px solid var(--dp-border);
	border-radius: 14px;
	transition: transform 0.18s ease, border-color 0.18s, box-shadow 0.18s;
}

.dp-home-hero__strip-item:hover {
	transform: translateY(-2px);
	border-color: var(--dp-primary-200);
	box-shadow: 0 8px 18px color-mix(in srgb, var(--dp-primary) 12%, transparent);
}

.dp-home-hero__strip-item img {
	width: 36px;
	height: 36px;
	border-radius: 9px;
}

@media (max-width: 540px) {
	.dp-home-hero__strip-item {
		width: 48px;
		height: 48px;
		border-radius: 12px;
	}

	.dp-home-hero__strip-item img {
		width: 30px;
		height: 30px;
	}

	.dp-home-hero__actions {
		flex-direction: column;
		width: 100%;
	}

	.dp-home-hero__btn {
		width: 100%;
	}
}

/* ─── Performance Section (.dp-home-perf) ────────────────────────── */

.dp-home-perf__head {
	display: grid;
	grid-template-columns: 1.2fr 1fr;
	gap: clamp(2rem, 4vw, 4rem);
	align-items: end;
	margin-bottom: clamp(2.5rem, 5vw, 4rem);
}

.dp-home-perf__kicker {
	display: inline-flex;
	align-items: center;
	gap: var(--dp-sp-2);
	font-family: var(--dp-font-mono);
	font-size: var(--dp-fs-xs);
	font-weight: 400;
	letter-spacing: 0.08em;
	color: var(--dp-text-3);
	text-transform: uppercase;
	margin-bottom: var(--dp-sp-5);
}

.dp-home-perf__kicker-dot {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--dp-primary);
}

.dp-home-perf__title {
	font-size: var(--dp-fs-section);
	font-weight: 700;
	letter-spacing: -0.03em;
	line-height: 1.08;
	color: var(--dp-text);
}

.dp-home-perf__sub {
	font-size: var(--dp-fs-base);
	color: var(--dp-text-2);
	line-height: 1.6;
	max-width: 42ch;
}

.dp-home-perf__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
}

.dp-home-perf__card {
	background: var(--dp-surface);
	border: 1px solid var(--dp-border-subtle);
	border-radius: var(--dp-r-lg);
	padding: var(--dp-sp-6) var(--dp-sp-6) var(--dp-sp-8);
	transition: border-color var(--dp-duration) var(--dp-ease), transform var(--dp-duration) var(--dp-ease);
}

.dp-home-perf__card:hover {
	border-color: var(--dp-border-hover);
	transform: translateY(-2px);
}

.dp-home-perf__icon {
	display: grid;
	place-items: center;
	width: 44px;
	height: 44px;
	border-radius: 12px;
	background: color-mix(in srgb, var(--dp-primary) 8%, var(--dp-surface));
	color: var(--dp-primary);
	margin-bottom: var(--dp-sp-6);
}

.dp-home-perf__name {
	font-size: var(--dp-fs-base);
	font-weight: 700;
	color: var(--dp-text);
	margin-bottom: var(--dp-sp-2);
	letter-spacing: -0.01em;
}

.dp-home-perf__desc {
	font-size: var(--dp-fs-sm);
	color: var(--dp-text-2);
	line-height: 1.55;
}

@media (max-width: 900px) {
	.dp-home-perf__head {
		grid-template-columns: 1fr;
		align-items: start;
	}

	.dp-home-perf__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 600px) {
	.dp-home-perf__grid {
		grid-template-columns: 1fr;
	}
}

/* ─── Plugins Page Hero (legacy, used by older homepage variant) ── */

.dp-plugins-hero {
	text-align: center;
	max-width: 640px;
	margin: 0 auto;
}

.dp-plugins-hero .dp-home-hero__badge {
	margin-inline: auto;
}

.dp-plugins-hero .dp-home-hero__sub {
	margin-left: auto;
	margin-right: auto;
}

.dp-plugins-hero .dp-home-hero__actions {
	justify-content: center;
}

/* ─── /plugins index ─────────────────────────────────────────────── */

.dp-plugins-page__hero {
	padding-bottom: clamp(2rem, 4vw, 3rem);
}

.dp-plugins-page__head {
	max-width: 680px;
	margin: 0 auto;
	text-align: center;
}

.dp-plugins-page__eyebrow {
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--dp-primary);
	margin: 0 0 14px;
}

.dp-plugins-page__title {
	font-size: clamp(2rem, 4vw, 3rem);
	font-weight: 700;
	letter-spacing: -0.035em;
	line-height: 1.1;
	color: var(--dp-text);
	margin: 0 0 16px;
}

.dp-plugins-page__sub {
	font-size: clamp(16px, 1.6vw, 18px);
	color: var(--dp-text-2);
	line-height: 1.6;
	margin: 0;
}

.dp-section--tight {
	padding-block: clamp(1.5rem, 3vw, 2.5rem);
}

.dp-plugins-page__group-head {
	margin-bottom: clamp(1.25rem, 2.5vw, 2rem);
}

.dp-plugins-page__group-title {
	font-size: clamp(1.25rem, 2vw, 1.5rem);
	font-weight: 600;
	letter-spacing: -0.02em;
	color: var(--dp-text);
	margin: 0 0 6px;
}

.dp-plugins-page__group-sub {
	font-size: var(--dp-fs-sm);
	color: var(--dp-text-3);
	margin: 0;
}

/* Homepage flagships grid — 3-up when there are 3, 2-up otherwise. */
.dp-flagships-grid {
	display: grid;
	gap: 16px;
}

.dp-flagships-grid--2 {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

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

@media (max-width: 900px) {
	.dp-flagships-grid--2,
	.dp-flagships-grid--3 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 600px) {
	.dp-flagships-grid--2,
	.dp-flagships-grid--3 {
		grid-template-columns: 1fr;
	}
}

/* Compact "Also free" strip at the bottom of /plugins/. */
.dp-plugins-page__free {
	border-top: 1px solid var(--dp-border);
}

.dp-plugins-page__free-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	justify-content: center;
}

.dp-plugins-page__free-card {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 8px 14px 8px 10px;
	background: var(--dp-surface);
	border: 1px solid var(--dp-border);
	border-radius: 999px;
	text-decoration: none;
	transition: border-color 0.15s, color 0.15s, transform 0.15s;
}

.dp-plugins-page__free-card:hover {
	border-color: color-mix(in srgb, #10B981 35%, var(--dp-border));
	transform: translateY(-1px);
}

.dp-plugins-page__free-icon {
	width: 28px;
	height: 28px;
	border-radius: 7px;
	flex-shrink: 0;
	object-fit: contain;
}

.dp-plugins-page__free-name {
	font-size: 13px;
	font-weight: 600;
	color: var(--dp-text);
	letter-spacing: -0.005em;
}

.dp-plugins-page__free-tag {
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: #10B981;
	background: color-mix(in srgb, #10B981 14%, transparent);
	padding: 2px 8px;
	border-radius: 999px;
}

.dp-plugins-page__free-all {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: 18px;
	width: 100%;
	justify-content: center;
	font-size: 13px;
	font-weight: 600;
	color: var(--dp-primary);
	text-decoration: none;
}

.dp-plugins-page__free-all svg {
	transition: transform 0.15s;
}

.dp-plugins-page__free-all:hover svg {
	transform: translateX(2px);
}


/* ─── Once Page Hero (dark, split) ─────────────────────────────── */

.dp-once-hero {
	background:
		radial-gradient(60% 80% at 0% 0%, color-mix(in srgb, var(--dp-primary) 28%, transparent), transparent 65%),
		radial-gradient(50% 70% at 100% 100%, color-mix(in srgb, var(--dp-primary) 18%, transparent), transparent 60%),
		var(--dp-dark-bg);
	padding: clamp(4rem, 10vw, 7rem) 0 clamp(3rem, 6vw, 5rem);
	position: relative;
	overflow: hidden;
}

/* Hairline brand accent at the top edge for visual continuity. */
.dp-once-hero::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 1px;
	background: linear-gradient(
		90deg,
		transparent,
		color-mix(in srgb, var(--dp-primary) 60%, transparent) 50%,
		transparent
	);
	pointer-events: none;
}

.dp-once-hero__grid {
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: clamp(2rem, 5vw, 5rem);
	align-items: center;
}

.dp-once-hero__copy {
	max-width: 520px;
}

.dp-once-hero__kicker {
	font-size: var(--dp-fs-xs);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--dp-primary-200);
	margin-bottom: var(--dp-sp-4);
}

.dp-once-hero__title {
	font-size: var(--dp-fs-hero);
	font-weight: 700;
	letter-spacing: -0.045em;
	line-height: 1.08;
	color: var(--dp-dark-text);
	margin-bottom: 20px;
}

.dp-once-hero__title em {
	font-style: normal;
	background: linear-gradient(135deg, var(--dp-primary-200), var(--dp-primary));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.dp-once-hero__sub {
	font-size: var(--dp-fs-lg);
	color: var(--dp-dark-text-2);
	line-height: 1.55;
	margin-bottom: 32px;
}

.dp-once-hero__actions {
	display: flex;
	margin-bottom: 16px;
}

.dp-once-hero__trust {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: var(--dp-fs-sm);
	color: var(--dp-dark-text-3);
}

.dp-once-hero__trust .dp-once-check {
	width: 14px;
	height: 14px;
	color: var(--swatch--green-500);
}

/* Icon grid — right side */
.dp-once-hero__icon-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px;
}

.dp-once-hero__icon-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
	padding: 22px 14px;
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(255, 255, 255, 0.06);
	border-radius: var(--dp-r-md);
	transition: background var(--dp-duration) var(--dp-ease),
	            border-color var(--dp-duration) var(--dp-ease);
}

.dp-once-hero__icon-card:hover {
	background: rgba(255, 255, 255, 0.08);
	border-color: rgba(255, 255, 255, 0.12);
}

.dp-once-hero__icon-card img {
	width: 40px;
	height: 40px;
	border-radius: var(--dp-r-sm);
}

.dp-once-hero__icon-name {
	font-size: 11px;
	font-weight: 500;
	color: var(--dp-dark-text-2);
	text-align: center;
	line-height: 1.2;
}


/* ─── Once Bundles ───────────────────────────────────────────────── */

.dp-once-bundles {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
	margin-bottom: var(--dp-sp-8);
}

.dp-once-bundle {
	background: var(--dp-surface);
	border: 1px solid var(--dp-border);
	border-radius: var(--dp-r-xl);
	padding: 32px;
	display: flex;
	flex-direction: column;
	transition: border-color 0.2s, box-shadow 0.2s;
}

.dp-once-bundle:hover {
	border-color: var(--dp-primary-200);
	box-shadow: 0 4px 20px rgba(91, 58, 232, 0.06);
}

.dp-once-bundle--featured {
	border-top: 3px solid var(--dp-primary);
}

.dp-once-bundle p {
	padding-bottom: 0;
}

.dp-once-bundle__badge {
	display: inline-flex;
	align-self: flex-start;
	background: var(--dp-primary-50);
	color: var(--dp-primary);
	font-size: var(--dp-fs-xs);
	font-weight: 600;
	padding: 4px 12px;
	border-radius: var(--dp-r-pill);
	white-space: nowrap;
	margin-bottom: 16px;
}

.dp-once-bundle__name {
	font-size: clamp(1.5rem, 2.5vw, 1.75rem);
	font-weight: 700;
	letter-spacing: -0.02em;
	line-height: 1.2;
	color: var(--dp-text);
	margin: 0 0 var(--dp-sp-3);
}

.dp-once-bundle__desc {
	font-size: var(--dp-fs-sm);
	color: var(--dp-text-2);
	line-height: 1.5;
	margin: 0 0 var(--dp-sp-3);
}

.dp-once-bundle__price {
	display: flex;
	align-items: baseline;
	gap: 6px;
	margin-bottom: 4px;
	flex-wrap: wrap;
}

.dp-once-bundle__orig {
	font-size: var(--dp-fs-sm);
	color: var(--dp-text-3);
	text-decoration: line-through;
}

.dp-once-bundle__amount {
	font-size: clamp(2rem, 3vw, 2.5rem);
	font-weight: 700;
	color: var(--dp-text);
	letter-spacing: -0.03em;
	line-height: 1;
}

.dp-once-bundle__period {
	font-size: var(--dp-fs-sm);
	color: var(--dp-text-3);
	margin-bottom: var(--dp-sp-6);
}

.dp-once-bundle .dp-btn {
	margin-bottom: var(--dp-sp-6);
}

/* Plugin list inside bundle */
.dp-once-bundle__list {
	list-style: none;
	padding: var(--dp-sp-4) 0 0;
	margin: 0;
	border-top: 1px solid var(--dp-border-subtle);
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.dp-once-bundle__list li {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: var(--dp-fs-sm);
	color: var(--dp-text-2);
	line-height: 1.4;
}

.dp-once-bundle__list li img {
	width: 20px;
	height: 20px;
	border-radius: 4px;
	flex-shrink: 0;
}

/* Perks list */
.dp-once-bundle__perks {
	list-style: none;
	padding: var(--dp-sp-3) 0 0;
	margin: var(--dp-sp-3) 0 0;
	border-top: 1px solid var(--dp-border-subtle);
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.dp-once-bundle__perks li {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: var(--dp-fs-xs);
	color: var(--dp-text-3);
	line-height: 1.4;
}

.dp-once-check {
	width: 14px;
	height: 14px;
	flex-shrink: 0;
	color: var(--dp-success);
}

/* Trust bar */
.dp-once-trust {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: var(--dp-sp-6);
	font-size: var(--dp-fs-sm);
	color: var(--dp-text-3);
	flex-wrap: wrap;
}

.dp-once-trust .dp-once-check {
	color: var(--dp-text-3);
}

/* ─── Once Products (What's Included) ────────────────────────────── */

.dp-once-products {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
}

.dp-once-product {
	display: flex;
	align-items: center;
	gap: 16px;
	background: var(--dp-surface);
	border: 1px solid var(--dp-border-subtle);
	border-radius: var(--dp-r);
	padding: 16px 20px;
	text-decoration: none;
	color: inherit;
	transition: border-color var(--dp-duration) var(--dp-ease);
}

.dp-once-product:hover {
	border-color: var(--dp-border-hover);
}

.dp-once-product__icon {
	width: 44px;
	height: 44px;
	flex-shrink: 0;
	border-radius: var(--dp-r);
}

.dp-once-product__body {
	flex: 1;
	min-width: 0;
}

.dp-once-product__name {
	font-size: var(--dp-fs-base);
	font-weight: 600;
	color: var(--dp-text);
	line-height: 1.3;
	margin: 0 0 2px;
}

.dp-once-product__tagline {
	font-size: var(--dp-fs-sm);
	color: var(--dp-text-2);
	line-height: 1.45;
	margin: 0;
}

.dp-once-product__meta {
	font-size: var(--dp-fs-xs);
	color: var(--dp-text-3);
	margin-top: 4px;
	display: block;
}

.dp-once-product__price {
	text-align: right;
	flex-shrink: 0;
}

.dp-once-product__orig {
	font-size: var(--dp-fs-xs);
	color: var(--dp-text-3);
	text-decoration: line-through;
	display: block;
}

.dp-once-product__amount {
	font-size: var(--dp-fs-base);
	font-weight: 700;
	color: var(--dp-text);
}

.dp-once-products__footnote {
	text-align: center;
	margin-top: var(--dp-sp-6);
	font-size: var(--dp-fs-sm);
	color: var(--dp-text-3);
}

.dp-once-products__footnote a {
	font-weight: 600;
	color: var(--dp-primary);
}

/* ─── Once Responsive ────────────────────────────────────────────── */

@media (max-width: 1024px) {
	.dp-once-bundles {
		grid-template-columns: 1fr 1fr;
	}

	.dp-once-bundle:last-child {
		grid-column: 1 / -1;
		max-width: 480px;
		margin-inline: auto;
		width: 100%;
	}

}

@media (max-width: 768px) {
	.dp-once-bundles {
		grid-template-columns: 1fr;
	}

	.dp-once-bundle:last-child {
		grid-column: auto;
		max-width: none;
	}

	.dp-once-products {
		grid-template-columns: 1fr;
	}

	.dp-once-hero__grid {
		grid-template-columns: 1fr;
		text-align: center;
	}

	.dp-once-hero__copy {
		margin-inline: auto;
	}

	.dp-once-hero__actions {
		justify-content: center;
	}

	.dp-once-hero__trust {
		justify-content: center;
	}

	.dp-once-hero__icon-grid {
		grid-template-columns: repeat(3, 1fr);
		max-width: 400px;
		margin-inline: auto;
	}
}

/* ─── Scroll Animations ──────────────────────────────────────────── */

[data-a] {
	opacity: 0;
	transform: translateY(16px);
	transition:
		opacity 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94),
		transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

[data-a].v {
	opacity: 1;
	transform: none;
}

/* ─── Responsive ─────────────────────────────────────────────────── */

@media (max-width: 768px) {
	.dp-home-hero__grid {
		grid-template-columns: 1fr;
		text-align: center;
	}

	.dp-home-hero__copy {
		max-width: none;
	}

	.dp-home-hero__actions {
		justify-content: center;
		flex-direction: column;
		align-items: center;
	}

	.dp-home-hero__icon-grid {
		max-width: 320px;
		margin-inline: auto;
	}
}

@media (max-width: 480px) {
	.dp-home-hero__actions {
		width: 100%;
	}

	.dp-home-hero__btn {
		width: 100%;
		justify-content: center;
	}
}

