/* ============================================================
   ONVORE.com — site stylesheet (standalone static-site version)
   Loaded once via <link rel="stylesheet"> on every page.
   ============================================================ */

/* ---------- Global resets for standalone site ---------- */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
	color: #3a3447;
	background: #ffffff;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	line-height: 1.6;
}
img { max-width: 100%; height: auto; display: block; }
button { font-family: inherit; }

/* ---------- Site shell layout ---------- */
.onvore-site {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}
.onvore-site__main {
	flex: 1 0 auto;
}

/* ---------- Logo (header + footer) ---------- */
.onvore-logo {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	text-decoration: none;
	color: inherit;
	font-weight: 800;
	letter-spacing: -0.01em;
	font-size: 20px;
	line-height: 1;
}
.onvore-logo:hover { text-decoration: none; color: inherit; }
.onvore-logo__mark {
	display: inline-flex;
	width: 32px;
	height: 32px;
	flex-shrink: 0;
}
.onvore-logo__mark svg { display: block; }
.onvore-logo__text { color: #0e0a1f; }

/* ---------- Header ---------- */
.onvore-header {
	position: sticky;
	top: 0;
	z-index: 50;
	background: rgba(255, 255, 255, 0.92);
	backdrop-filter: saturate(180%) blur(10px);
	-webkit-backdrop-filter: saturate(180%) blur(10px);
	border-bottom: 1px solid transparent;
	transition: border-color 200ms ease, box-shadow 200ms ease, background 200ms ease;
}
.onvore-header--scrolled {
	background: rgba(255, 255, 255, 0.98);
	border-bottom-color: #e7e4ec;
	box-shadow: 0 4px 18px rgba(14, 10, 31, 0.05);
}
.onvore-header__inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 14px 24px;
	display: flex;
	align-items: center;
	gap: 24px;
}
.onvore-header__cta {
	margin-left: auto;
	display: flex;
	gap: 12px;
	align-items: center;
}
.onvore-header__cta .onvore-btn {
	padding: 10px 18px;
	font-size: 14px;
}
.onvore-btn--account {
	background: transparent;
	color: #1a0e2e;
	border-color: #d8d4df;
	font-weight: 600;
}
.onvore-btn--account:hover {
	background: #f6f3fa;
	border-color: #bd1e51;
	color: #bd1e51;
	text-decoration: none;
}
.onvore-btn--account svg { flex-shrink: 0; }
@media (max-width: 720px) {
	.onvore-header__cta .onvore-btn--account span { display: none; }
	.onvore-header__cta .onvore-btn--account { padding: 9px 11px; }
}

/* ---------- Nav ---------- */
.onvore-nav {
	margin-left: auto;
	display: flex;
}
.onvore-nav__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	align-items: center;
	gap: 4px;
}
.onvore-nav__item {
	position: relative;
}
.onvore-nav__link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 10px 14px;
	font-size: 15px;
	font-weight: 500;
	color: #3a3447;
	background: none;
	border: 0;
	border-radius: 8px;
	cursor: pointer;
	text-decoration: none;
	transition: color 150ms ease, background 150ms ease;
}
.onvore-nav__link:hover,
.onvore-nav__link:focus-visible {
	color: #bd1e51;
	background: #f7f5fa;
	text-decoration: none;
	outline: none;
}
.onvore-nav__caret {
	width: 10px;
	height: 10px;
	transition: transform 200ms ease;
	opacity: 0.6;
}
.onvore-nav__item--open > .onvore-nav__link .onvore-nav__caret,
.onvore-nav__item--has-mega:hover > .onvore-nav__link .onvore-nav__caret {
	transform: rotate(180deg);
}
.onvore-nav__item--open > .onvore-nav__link {
	color: #bd1e51;
	background: #f7f5fa;
}

/* ---------- Mega menu ---------- */
.onvore-mega {
	position: absolute;
	top: calc(100% + 8px);
	left: 50%;
	transform: translateX(-50%) translateY(-4px);
	min-width: 720px;
	max-width: 92vw;
	background: #ffffff;
	border: 1px solid #e7e4ec;
	border-radius: 16px;
	box-shadow: 0 4px 12px rgba(14, 10, 31, 0.08), 0 24px 56px rgba(14, 10, 31, 0.12);
	padding: 20px;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity 180ms ease, transform 180ms ease, visibility 180ms ease;
	z-index: 60;
}
.onvore-mega::before {
	/* hover gap bridge so cursor can travel from link to menu */
	content: '';
	position: absolute;
	top: -8px;
	left: 0;
	right: 0;
	height: 8px;
}
.onvore-nav__item--has-mega:hover > .onvore-mega,
.onvore-nav__item--has-mega:focus-within > .onvore-mega,
.onvore-nav__item--open > .onvore-mega {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: translateX(-50%) translateY(0);
}
.onvore-mega--narrow { min-width: 560px; }
.onvore-mega--wide,
.onvore-nav__item--has-mega:has(> .onvore-mega .onvore-mega__grid--three) > .onvore-mega { min-width: 920px; }
.onvore-mega__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 8px;
}
.onvore-mega__grid--three { grid-template-columns: repeat(3, 1fr); }
.onvore-mega-card {
	display: flex;
	gap: 14px;
	align-items: flex-start;
	padding: 14px;
	border-radius: 12px;
	text-decoration: none;
	transition: background 150ms ease;
}
.onvore-mega-card:hover {
	background: #f7f5fa;
	text-decoration: none;
}
.onvore-mega-card__icon {
	width: 40px;
	height: 40px;
	border-radius: 10px;
	background: #fce4ec;
	color: #bd1e51;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.onvore-mega-card__icon--gold { background: #fff4d6; color: #b8810a; }
.onvore-mega-card__icon--green { background: #e8f5d8; color: #5b8a2a; }
.onvore-mega-card__icon--ink { background: #ede9f5; color: #0e0a1f; }
.onvore-mega-card__icon--purple { background: #ede4f7; color: #7f54b3; }
.onvore-mega-card__title {
	font-size: 15px;
	font-weight: 600;
	color: #0e0a1f;
	margin: 0 0 2px;
	display: flex;
	align-items: center;
	gap: 8px;
}
.onvore-mega-card__badge {
	display: inline-block;
	background: #bd1e51;
	color: #ffffff;
	font-size: 10px;
	font-weight: 700;
	padding: 2px 6px;
	border-radius: 4px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}
.onvore-mega-card__desc {
	font-size: 13px;
	color: #766f82;
	line-height: 1.45;
	margin: 0;
}
.onvore-mega__footer {
	margin-top: 12px;
	padding-top: 14px;
	border-top: 1px solid #e7e4ec;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	font-size: 13px;
	color: #766f82;
}
.onvore-mega__footer a {
	color: #bd1e51;
	font-weight: 600;
	text-decoration: none;
}
.onvore-mega__footer a:hover { text-decoration: underline; }

/* ---------- Mobile menu toggle ---------- */
.onvore-header__toggle {
	display: none;
	background: none;
	border: 0;
	width: 40px;
	height: 40px;
	cursor: pointer;
	padding: 0;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 5px;
	border-radius: 8px;
}
.onvore-header__toggle:hover { background: #f7f5fa; }
.onvore-header__toggle span {
	display: block;
	width: 20px;
	height: 2px;
	background: #0e0a1f;
	border-radius: 2px;
	transition: transform 200ms ease, opacity 200ms ease;
}
.onvore-header--open .onvore-header__toggle span:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}
.onvore-header--open .onvore-header__toggle span:nth-child(2) { opacity: 0; }
.onvore-header--open .onvore-header__toggle span:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

@media (max-width: 980px) {
	.onvore-header__toggle { display: inline-flex; }
	.onvore-header__cta { margin-left: auto; }
	.onvore-header__cta .onvore-btn { display: none; }
	.onvore-header__cta .onvore-btn--account { display: inline-flex; }
	.onvore-nav {
		position: fixed;
		top: 0;
		right: 0;
		bottom: 0;
		width: min(360px, 88vw);
		background: #ffffff;
		border-left: 1px solid #e7e4ec;
		box-shadow: -20px 0 60px rgba(14, 10, 31, 0.12);
		padding: 80px 20px 32px;
		transform: translateX(100%);
		transition: transform 280ms cubic-bezier(0.4, 0, 0.2, 1);
		overflow-y: auto;
		display: block;
	}
	.onvore-header--open .onvore-nav {
		transform: translateX(0);
	}
	.onvore-nav__list {
		flex-direction: column;
		align-items: stretch;
		gap: 4px;
	}
	.onvore-nav__link {
		justify-content: space-between;
		padding: 14px 16px;
		font-size: 16px;
		width: 100%;
		text-align: left;
	}
	.onvore-mega {
		position: static;
		transform: none;
		min-width: 0;
		max-width: none;
		width: 100%;
		border: 0;
		box-shadow: none;
		padding: 8px 0 8px 12px;
		border-radius: 0;
		opacity: 0;
		visibility: hidden;
		max-height: 0;
		overflow: hidden;
		pointer-events: none;
		transition: opacity 180ms ease, max-height 280ms ease, visibility 180ms ease;
	}
	.onvore-nav__item--open > .onvore-mega {
		opacity: 1;
		visibility: visible;
		max-height: 800px;
		pointer-events: auto;
		transform: none;
	}
	.onvore-mega__grid,
	.onvore-mega__grid--three { grid-template-columns: 1fr; }
	.onvore-nav__item--has-mega:hover > .onvore-mega { /* disable hover-open on mobile */
		opacity: 0;
		visibility: hidden;
		max-height: 0;
	}
	.onvore-nav__item--has-mega.onvore-nav__item--open:hover > .onvore-mega {
		opacity: 1;
		visibility: visible;
		max-height: 800px;
	}
	.onvore-nav__mobile-cta {
		display: block;
		margin-top: 16px;
		padding-top: 16px;
		border-top: 1px solid #e7e4ec;
	}
	.onvore-nav__mobile-cta .onvore-btn {
		width: 100%;
		justify-content: center;
	}
	body.onvore-no-scroll { overflow: hidden; }
}
@media (min-width: 981px) {
	.onvore-nav__mobile-cta { display: none; }
}

/* Backdrop for open mobile menu */
.onvore-header__backdrop {
	display: none;
	position: fixed;
	inset: 0;
	background: rgba(14, 10, 31, 0.4);
	opacity: 0;
	transition: opacity 220ms ease;
	z-index: 40;
}
.onvore-header--open .onvore-header__backdrop {
	display: block;
	opacity: 1;
}

/* ---------- Footer ---------- */
.onvore-footer {
	background: linear-gradient(180deg, #0e0a1f 0%, #14102a 100%);
	color: rgba(255, 255, 255, 0.7);
	padding: 72px 0 28px;
	margin-top: 80px;
}
.onvore-footer .onvore-container { padding: 0 24px; max-width: 1200px; margin: 0 auto; }
.onvore-footer__grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr;
	gap: 48px;
	padding-bottom: 48px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
@media (max-width: 900px) {
	.onvore-footer__grid { grid-template-columns: repeat(2, 1fr); gap: 32px; }
	.onvore-footer__brand { grid-column: 1 / -1; }
}
@media (max-width: 540px) {
	.onvore-footer__grid { grid-template-columns: 1fr; }
}
.onvore-footer__brand .onvore-logo__text { color: #ffffff; }
.onvore-footer__tagline {
	color: rgba(255, 255, 255, 0.6);
	font-size: 14px;
	line-height: 1.6;
	margin: 16px 0 20px;
	max-width: 360px;
}
.onvore-footer__upwork {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: rgba(108, 191, 28, 0.12);
	border: 1px solid rgba(108, 191, 28, 0.3);
	color: #b8e986;
	padding: 8px 14px;
	border-radius: 999px;
	font-size: 13px;
	font-weight: 600;
	text-decoration: none;
	transition: background 150ms ease;
}
.onvore-footer__upwork:hover {
	background: rgba(108, 191, 28, 0.2);
	text-decoration: none;
	color: #b8e986;
}
.onvore-footer__col h4 {
	color: #ffffff;
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	margin: 0 0 18px;
}
.onvore-footer__col ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
.onvore-footer__col li { margin: 0 0 10px; }
.onvore-footer__col a {
	color: rgba(255, 255, 255, 0.65);
	font-size: 14px;
	text-decoration: none;
	transition: color 150ms ease;
}
.onvore-footer__col a:hover { color: #ffffff; text-decoration: none; }
.onvore-footer__bottom {
	padding-top: 24px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
	flex-wrap: wrap;
	font-size: 13px;
	color: rgba(255, 255, 255, 0.45);
}
.onvore-footer__legal {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: 20px;
	flex-wrap: wrap;
}
.onvore-footer__legal a {
	color: rgba(255, 255, 255, 0.55);
	font-size: 13px;
	text-decoration: none;
}
.onvore-footer__legal a:hover { color: #ffffff; }

/* Footer needs page selectors to not inherit the body font-color over its background */
.onvore-footer a, .onvore-footer p, .onvore-footer span, .onvore-footer li { color: inherit; }

/* Skip-to-content (accessibility) */
.onvore-skip {
	position: absolute;
	left: -9999px;
	top: 0;
	background: #bd1e51;
	color: #ffffff;
	padding: 12px 16px;
	z-index: 100;
	font-weight: 600;
	border-radius: 0 0 8px 0;
	text-decoration: none;
}
.onvore-skip:focus { left: 0; }



/* ---------- Design tokens ---------- */
.onvore-page {
	--onvore-brand:        #bd1e51;
	--onvore-brand-hover:  #9c1742;
	--onvore-brand-soft:   #fce4ec;
	--onvore-gold:         #f7b500;
	--onvore-gold-soft:    #fff4d6;
	--onvore-ink:          #0e0a1f;
	--onvore-ink-soft:     #3a3447;
	--onvore-muted:        #766f82;
	--onvore-line:         #e7e4ec;
	--onvore-bg:           #ffffff;
	--onvore-bg-soft:      #f7f5fa;
	--onvore-bg-card:      #ffffff;
	--onvore-success:      #16a34a;
	--onvore-radius:       12px;
	--onvore-radius-lg:    20px;
	--onvore-shadow:       0 1px 3px rgba(14, 10, 31, 0.06), 0 8px 24px rgba(14, 10, 31, 0.06);
	--onvore-shadow-lg:    0 4px 12px rgba(14, 10, 31, 0.08), 0 24px 56px rgba(14, 10, 31, 0.10);
	--onvore-font:         'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
}

/* ---------- Base ---------- */
.onvore-page,
.onvore-page * {
	box-sizing: border-box;
}

.onvore-page {
	font-family: var(--onvore-font);
	color: var(--onvore-ink-soft);
	line-height: 1.6;
	font-size: 16px;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.onvore-page h1,
.onvore-page h2,
.onvore-page h3,
.onvore-page h4 {
	color: var(--onvore-ink);
	font-weight: 700;
	line-height: 1.2;
	margin: 0 0 16px;
	letter-spacing: -0.01em;
}

.onvore-page h1 { font-size: clamp(36px, 5vw, 56px); font-weight: 800; letter-spacing: -0.02em; }
.onvore-page h2 { font-size: clamp(28px, 3.5vw, 40px); }
.onvore-page h3 { font-size: clamp(20px, 2.5vw, 24px); }
.onvore-page h4 { font-size: 18px; }

.onvore-page p {
	margin: 0 0 16px;
}

.onvore-page a {
	color: var(--onvore-brand);
	text-decoration: none;
	transition: color 150ms ease;
}
.onvore-page a:hover {
	color: var(--onvore-brand-hover);
	text-decoration: underline;
}

.onvore-page ul,
.onvore-page ol {
	margin: 0 0 16px;
	padding-left: 20px;
}
.onvore-page li {
	margin-bottom: 8px;
}

/* ---------- Layout ---------- */
.onvore-container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 24px;
}
.onvore-container--narrow {
	max-width: 800px;
}

.onvore-section {
	padding: 80px 0;
}
.onvore-section--soft {
	background: var(--onvore-bg-soft);
}
.onvore-section--tight {
	padding: 48px 0;
}
@media (max-width: 768px) {
	.onvore-section { padding: 56px 0; }
}

.onvore-section__header {
	text-align: center;
	max-width: 720px;
	margin: 0 auto 56px;
}
.onvore-section__eyebrow {
	display: inline-block;
	color: var(--onvore-brand);
	font-weight: 600;
	font-size: 14px;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	margin-bottom: 12px;
}
.onvore-section__subtitle {
	color: var(--onvore-muted);
	font-size: 18px;
	margin-top: 8px;
}

/* ---------- Buttons ---------- */
.onvore-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 14px 28px;
	border-radius: 999px;
	font-weight: 600;
	font-size: 16px;
	line-height: 1;
	text-decoration: none;
	border: 2px solid transparent;
	cursor: pointer;
	transition: all 150ms ease;
}
.onvore-btn--primary {
	background: var(--onvore-brand);
	color: #ffffff;
	border-color: var(--onvore-brand);
}
.onvore-btn--primary:hover {
	background: var(--onvore-brand-hover);
	border-color: var(--onvore-brand-hover);
	color: #ffffff;
	text-decoration: none;
	transform: translateY(-1px);
}
.onvore-btn--ghost {
	background: transparent;
	color: var(--onvore-ink);
	border-color: var(--onvore-line);
}
.onvore-btn--ghost:hover {
	background: var(--onvore-bg-soft);
	color: var(--onvore-ink);
	text-decoration: none;
}
.onvore-btn--lg {
	padding: 16px 36px;
	font-size: 17px;
}
.onvore-btn--block {
	display: flex;
	width: 100%;
}

/* ---------- Hero ---------- */
.onvore-hero {
	padding: 80px 0 64px;
}
.onvore-hero__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 64px;
	align-items: center;
}
.onvore-hero__eyebrow {
	display: inline-block;
	background: var(--onvore-brand-soft);
	color: var(--onvore-brand);
	padding: 6px 14px;
	border-radius: 999px;
	font-weight: 600;
	font-size: 13px;
	letter-spacing: 0.03em;
	margin-bottom: 20px;
}
.onvore-hero__title {
	margin-bottom: 20px;
}
.onvore-hero__title em {
	font-style: normal;
	color: var(--onvore-brand);
}
.onvore-hero__title .onvore-accent-gold {
	color: var(--onvore-gold);
}
.onvore-hero__lead {
	font-size: 19px;
	color: var(--onvore-muted);
	margin-bottom: 32px;
}
.onvore-hero__actions {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
}
.onvore-hero__media {
	background: linear-gradient(135deg, var(--onvore-brand-soft) 0%, var(--onvore-gold-soft) 100%);
	border-radius: var(--onvore-radius-lg);
	padding: 48px;
	min-height: 340px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	color: var(--onvore-ink);
	font-weight: 600;
}
@media (max-width: 900px) {
	.onvore-hero__grid {
		grid-template-columns: 1fr;
		gap: 40px;
	}
	.onvore-hero { padding: 48px 0; }
}

/* ---------- Feature grids ---------- */
.onvore-feature-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}
.onvore-feature-grid--two { grid-template-columns: repeat(2, 1fr); }
.onvore-feature-grid--four { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px) {
	.onvore-feature-grid,
	.onvore-feature-grid--two,
	.onvore-feature-grid--four { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
	.onvore-feature-grid,
	.onvore-feature-grid--two,
	.onvore-feature-grid--four { grid-template-columns: 1fr; }
}

.onvore-feature {
	background: var(--onvore-bg-card);
	border: 1px solid var(--onvore-line);
	border-radius: var(--onvore-radius);
	padding: 28px;
	transition: all 200ms ease;
}
.onvore-feature:hover {
	border-color: var(--onvore-brand);
	transform: translateY(-2px);
	box-shadow: var(--onvore-shadow);
}
.onvore-feature__icon {
	width: 44px;
	height: 44px;
	background: var(--onvore-brand-soft);
	color: var(--onvore-brand);
	border-radius: var(--onvore-radius);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 22px;
	font-weight: 700;
	margin-bottom: 16px;
}
.onvore-feature__icon--gold {
	background: var(--onvore-gold-soft);
	color: #b8810a;
}
.onvore-feature h3 {
	font-size: 18px;
	margin-bottom: 8px;
}
.onvore-feature p {
	color: var(--onvore-muted);
	font-size: 15px;
	margin: 0;
}

/* ---------- Plugin card (used on Plugins index) ---------- */
.onvore-plugin-card {
	background: var(--onvore-bg-card);
	border: 1px solid var(--onvore-line);
	border-radius: var(--onvore-radius-lg);
	padding: 40px;
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: 40px;
	align-items: center;
	transition: all 200ms ease;
}
.onvore-plugin-card:hover {
	border-color: var(--onvore-brand);
	box-shadow: var(--onvore-shadow);
}
.onvore-plugin-card__badge {
	display: inline-block;
	background: var(--onvore-brand-soft);
	color: var(--onvore-brand);
	padding: 4px 12px;
	border-radius: 999px;
	font-weight: 600;
	font-size: 12px;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	margin-bottom: 12px;
}
.onvore-plugin-card__media {
	background: linear-gradient(135deg, #f1ecf7 0%, #fdf2c7 100%);
	border-radius: var(--onvore-radius);
	min-height: 200px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	font-weight: 600;
	color: var(--onvore-muted);
}
.onvore-plugin-card__meta {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
	margin: 16px 0 20px;
}
.onvore-plugin-card__tag {
	background: var(--onvore-bg-soft);
	color: var(--onvore-ink-soft);
	padding: 4px 12px;
	border-radius: 999px;
	font-size: 13px;
	font-weight: 500;
}
@media (max-width: 800px) {
	.onvore-plugin-card { grid-template-columns: 1fr; padding: 28px; gap: 24px; }
}

/* ---------- Pricing ---------- */
.onvore-pricing {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	align-items: stretch;
}
@media (max-width: 900px) {
	.onvore-pricing { grid-template-columns: 1fr; max-width: 480px; margin: 0 auto; }
}

.onvore-price-card {
	background: var(--onvore-bg-card);
	border: 1px solid var(--onvore-line);
	border-radius: var(--onvore-radius-lg);
	padding: 36px 32px;
	display: flex;
	flex-direction: column;
}
.onvore-price-card--featured {
	border-color: var(--onvore-brand);
	border-width: 2px;
	box-shadow: var(--onvore-shadow-lg);
	position: relative;
}
.onvore-price-card--featured::before {
	content: 'Best value';
	position: absolute;
	top: -14px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--onvore-brand);
	color: #ffffff;
	padding: 4px 14px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.05em;
}
.onvore-price-card__name {
	font-size: 18px;
	font-weight: 600;
	color: var(--onvore-ink);
	margin-bottom: 4px;
}
.onvore-price-card__tagline {
	color: var(--onvore-muted);
	font-size: 14px;
	margin-bottom: 24px;
}
.onvore-price-card__price {
	display: flex;
	align-items: baseline;
	gap: 4px;
	margin-bottom: 4px;
}
.onvore-price-card__amount {
	font-size: 44px;
	font-weight: 800;
	color: var(--onvore-ink);
	letter-spacing: -0.02em;
}
.onvore-price-card__cycle {
	color: var(--onvore-muted);
	font-size: 16px;
}
.onvore-price-card__yearly {
	color: var(--onvore-muted);
	font-size: 13px;
	margin-bottom: 28px;
}
.onvore-price-card__features {
	list-style: none;
	padding: 0;
	margin: 0 0 28px;
	flex-grow: 1;
}
.onvore-price-card__features li {
	padding-left: 28px;
	position: relative;
	margin-bottom: 12px;
	font-size: 15px;
	color: var(--onvore-ink-soft);
}
.onvore-price-card__features li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 7px;
	width: 18px;
	height: 18px;
	background: var(--onvore-brand);
	border-radius: 50%;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='white' d='M6.3 11.5L2.7 7.9l1.4-1.4 2.2 2.2 5-5 1.4 1.4z'/></svg>");
	background-repeat: no-repeat;
	background-position: center;
}
.onvore-price-card__features li.disabled {
	color: var(--onvore-muted);
	text-decoration: line-through;
	opacity: 0.7;
}
.onvore-price-card__features li.disabled::before {
	background: var(--onvore-line);
	background-image: none;
}

/* ---------- FAQ accordion ---------- */
.onvore-faq__group + .onvore-faq__group { margin-top: 56px; }
.onvore-faq__group-title {
	font-size: 22px;
	font-weight: 700;
	color: var(--onvore-ink);
	margin-bottom: 20px;
	padding-bottom: 12px;
	border-bottom: 2px solid var(--onvore-line);
}
.onvore-faq__item {
	border-bottom: 1px solid var(--onvore-line);
}
.onvore-faq__question {
	width: 100%;
	background: transparent;
	border: none;
	padding: 20px 0;
	text-align: left;
	font-family: inherit;
	font-size: 17px;
	font-weight: 600;
	color: var(--onvore-ink);
	cursor: pointer;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 24px;
}
.onvore-faq__question::after {
	content: '+';
	font-size: 24px;
	font-weight: 400;
	color: var(--onvore-brand);
	flex-shrink: 0;
	transition: transform 200ms ease;
}
.onvore-faq__item[open] .onvore-faq__question::after {
	transform: rotate(45deg);
}
.onvore-faq__answer {
	padding: 0 0 20px;
	color: var(--onvore-ink-soft);
	font-size: 16px;
	line-height: 1.7;
}
.onvore-faq__answer p:last-child { margin-bottom: 0; }

/* ---------- Trust strip ---------- */
.onvore-trust {
	background: var(--onvore-bg-soft);
	padding: 32px 0;
	border-top: 1px solid var(--onvore-line);
	border-bottom: 1px solid var(--onvore-line);
}
.onvore-trust__row {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 48px;
	flex-wrap: wrap;
	color: var(--onvore-muted);
	font-weight: 500;
	font-size: 14px;
	letter-spacing: 0.03em;
}
.onvore-trust__row span {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

/* ---------- CTA strip ---------- */
.onvore-cta {
	background: linear-gradient(135deg, #1a0e2e 0%, #3d0c4a 100%);
	border-radius: var(--onvore-radius-lg);
	padding: 56px;
	text-align: center;
	color: #ffffff;
}
.onvore-cta h2 {
	color: #ffffff;
	margin-bottom: 12px;
}
.onvore-cta p {
	color: rgba(255, 255, 255, 0.8);
	font-size: 18px;
	margin-bottom: 32px;
}
@media (max-width: 600px) {
	.onvore-cta { padding: 40px 24px; }
}

/* ---------- Long-form content (legal pages, FAQ intro, etc.) ---------- */
.onvore-prose {
	max-width: 760px;
	margin: 0 auto;
}
.onvore-prose h2 {
	margin-top: 48px;
}
.onvore-prose h2:first-of-type {
	margin-top: 0;
}
.onvore-prose h3 {
	margin-top: 32px;
	font-size: 20px;
}
.onvore-prose ul li,
.onvore-prose ol li {
	margin-bottom: 8px;
}
.onvore-prose__meta {
	color: var(--onvore-muted);
	font-size: 14px;
	margin-bottom: 32px;
	padding-bottom: 24px;
	border-bottom: 1px solid var(--onvore-line);
}

/* ---------- Page header (for inner pages) ---------- */
.onvore-page-header {
	padding: 80px 0 48px;
	text-align: center;
}
.onvore-page-header__title {
	margin-bottom: 16px;
}
.onvore-page-header__subtitle {
	font-size: 19px;
	color: var(--onvore-muted);
	max-width: 640px;
	margin: 0 auto;
}

/* ---------- Contact form ---------- */
.onvore-form {
	display: grid;
	gap: 16px;
	max-width: 560px;
	margin: 0 auto;
}
.onvore-form__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}
@media (max-width: 540px) {
	.onvore-form__row { grid-template-columns: 1fr; }
}
.onvore-form input,
.onvore-form textarea {
	width: 100%;
	padding: 14px 16px;
	border: 1px solid var(--onvore-line);
	border-radius: var(--onvore-radius);
	font-family: inherit;
	font-size: 16px;
	color: var(--onvore-ink);
	background: var(--onvore-bg);
	transition: border-color 150ms ease;
}
.onvore-form input:focus,
.onvore-form textarea:focus {
	outline: none;
	border-color: var(--onvore-brand);
	box-shadow: 0 0 0 3px rgba(189, 30, 81, 0.1);
}
.onvore-form textarea {
	min-height: 140px;
	resize: vertical;
}
.onvore-form button {
	justify-self: start;
}

/* ---------- Utility ---------- */
.onvore-center { text-align: center; }
.onvore-muted { color: var(--onvore-muted); }
.onvore-mb-16 { margin-bottom: 16px; }
.onvore-mb-24 { margin-bottom: 24px; }
.onvore-mb-32 { margin-bottom: 32px; }
.onvore-mb-40 { margin-bottom: 40px; }
.onvore-mt-32 { margin-top: 32px; }

/* ============================================================
   v2 components — services-focused homepage and service pages
   ============================================================ */

/* ---------- Services hero (banner) ---------- */
.onvore-banner {
	position: relative;
	background: linear-gradient(135deg, #1a0e2e 0%, #2d1245 45%, #3d0c4a 100%);
	color: #ffffff;
	padding: 96px 0 88px;
	overflow: hidden;
	isolation: isolate;
}
.onvore-banner::before,
.onvore-banner::after {
	content: '';
	position: absolute;
	border-radius: 50%;
	filter: blur(80px);
	opacity: 0.45;
	z-index: -1;
	pointer-events: none;
}
.onvore-banner::before {
	width: 520px;
	height: 520px;
	background: radial-gradient(circle, #bd1e51 0%, transparent 70%);
	top: -120px;
	right: -120px;
}
.onvore-banner::after {
	width: 460px;
	height: 460px;
	background: radial-gradient(circle, #f7b500 0%, transparent 70%);
	bottom: -180px;
	left: -100px;
	opacity: 0.25;
}
.onvore-banner__grid {
	display: grid;
	grid-template-columns: 1.05fr 1fr;
	gap: 64px;
	align-items: center;
	position: relative;
}
.onvore-banner__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.15);
	color: #ffffff;
	padding: 8px 16px;
	border-radius: 999px;
	font-weight: 500;
	font-size: 13px;
	letter-spacing: 0.04em;
	margin-bottom: 24px;
	backdrop-filter: blur(8px);
}
.onvore-banner__eyebrow .onvore-dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: #f7b500;
	box-shadow: 0 0 0 4px rgba(247, 181, 0, 0.2);
}
.onvore-page .onvore-banner__title,
.onvore-banner__title {
	font-size: clamp(38px, 5vw, 60px);
	line-height: 1.08;
	font-weight: 800;
	color: #ffffff;
	margin: 0 0 24px;
	letter-spacing: -0.025em;
	text-shadow: 0 2px 8px rgba(0, 0, 0, 0.35);
}
.onvore-page .onvore-banner__title em,
.onvore-banner__title em {
	font-style: normal;
	color: #ffd24a;
	background: linear-gradient(135deg, #ffd24a 0%, #ff9a59 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}
@supports not (-webkit-background-clip: text) {
	.onvore-banner__title em { color: #ffd24a; -webkit-text-fill-color: currentColor; background: none; }
}
.onvore-page .onvore-banner__title .onvore-banner__accent,
.onvore-banner__title .onvore-banner__accent {
	color: #ffd24a;
}
.onvore-page .onvore-banner__lead,
.onvore-banner__lead {
	font-size: 19px;
	line-height: 1.6;
	color: rgba(255, 255, 255, 0.88);
	margin-bottom: 32px;
	max-width: 540px;
}
.onvore-banner__actions {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
	margin-bottom: 32px;
}
.onvore-page .onvore-banner__actions .onvore-btn--primary,
.onvore-page .onvore-banner__actions a.onvore-btn--primary,
.onvore-page .onvore-banner__actions a.onvore-btn--primary:link,
.onvore-page .onvore-banner__actions a.onvore-btn--primary:visited {
	background: #ffd24a;
	color: #1a0e2e;
	border-color: #ffd24a;
	font-weight: 700;
	box-shadow: 0 6px 18px rgba(247, 181, 0, 0.25);
}
.onvore-page .onvore-banner__actions a.onvore-btn--primary:hover,
.onvore-page .onvore-banner__actions a.onvore-btn--primary:focus {
	background: #ffffff;
	color: #1a0e2e;
	border-color: #ffffff;
	box-shadow: 0 8px 22px rgba(255, 255, 255, 0.22);
}
.onvore-page .onvore-banner__actions .onvore-btn--ghost,
.onvore-page .onvore-banner__actions a.onvore-btn--ghost,
.onvore-page .onvore-banner__actions a.onvore-btn--ghost:link,
.onvore-page .onvore-banner__actions a.onvore-btn--ghost:visited {
	background: rgba(255, 255, 255, 0.14);
	color: #ffffff;
	border-color: rgba(255, 255, 255, 0.85);
	font-weight: 600;
}
.onvore-page .onvore-banner__actions a.onvore-btn--ghost:hover,
.onvore-page .onvore-banner__actions a.onvore-btn--ghost:focus {
	background: #ffffff;
	color: #1a0e2e;
	border-color: #ffffff;
}
.onvore-banner__badges {
	display: flex;
	gap: 24px;
	flex-wrap: wrap;
	color: rgba(255, 255, 255, 0.65);
	font-size: 13px;
	font-weight: 500;
}
.onvore-banner__badges span {
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.onvore-banner__badges svg {
	color: #f7b500;
	flex-shrink: 0;
}
@media (max-width: 960px) {
	.onvore-banner__grid { grid-template-columns: 1fr; gap: 48px; }
	.onvore-banner { padding: 64px 0 56px; }
}

/* ---------- Banner visual (CSS dashboard mockup) ---------- */
.onvore-banner__visual {
	position: relative;
	aspect-ratio: 5 / 4;
	min-height: 380px;
}
.onvore-mock {
	position: absolute;
	background: linear-gradient(180deg, #ffffff 0%, #f7f5fa 100%);
	border-radius: 16px;
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 0.08) inset,
		0 20px 60px rgba(0, 0, 0, 0.35),
		0 4px 12px rgba(0, 0, 0, 0.2);
	overflow: hidden;
	color: var(--onvore-ink);
}
.onvore-mock--main {
	top: 6%;
	left: 6%;
	right: 6%;
	bottom: 6%;
	z-index: 2;
}
.onvore-mock__topbar {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 12px 16px;
	background: #ffffff;
	border-bottom: 1px solid var(--onvore-line);
}
.onvore-mock__dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: #e7e4ec;
}
.onvore-mock__dot--r { background: #ff6058; }
.onvore-mock__dot--y { background: #ffbe2e; }
.onvore-mock__dot--g { background: #29c940; }
.onvore-mock__url {
	flex: 1;
	background: var(--onvore-bg-soft);
	border-radius: 6px;
	padding: 4px 10px;
	font-size: 11px;
	color: var(--onvore-muted);
	margin-left: 8px;
}
.onvore-mock__body {
	display: grid;
	grid-template-columns: 110px 1fr;
	height: calc(100% - 41px);
}
.onvore-mock__side {
	background: #faf8fd;
	border-right: 1px solid var(--onvore-line);
	padding: 14px 10px;
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.onvore-mock__brand {
	display: flex;
	align-items: center;
	gap: 6px;
	font-weight: 700;
	font-size: 12px;
	color: var(--onvore-brand);
	margin-bottom: 8px;
}
.onvore-mock__brand-dot {
	width: 18px;
	height: 18px;
	border-radius: 5px;
	background: linear-gradient(135deg, #bd1e51, #f7b500);
}
.onvore-mock__nav-item {
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 6px 8px;
	border-radius: 6px;
	font-size: 10px;
	color: var(--onvore-muted);
}
.onvore-mock__nav-item--active {
	background: var(--onvore-brand-soft);
	color: var(--onvore-brand);
	font-weight: 600;
}
.onvore-mock__nav-pip {
	width: 10px;
	height: 10px;
	border-radius: 3px;
	background: currentColor;
	opacity: 0.5;
}
.onvore-mock__main {
	padding: 16px;
	overflow: hidden;
}
.onvore-mock__heading {
	font-size: 13px;
	font-weight: 700;
	color: var(--onvore-ink);
	margin-bottom: 12px;
}
.onvore-mock__stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 8px;
	margin-bottom: 14px;
}
.onvore-mock__stat {
	background: #ffffff;
	border: 1px solid var(--onvore-line);
	border-radius: 8px;
	padding: 10px;
}
.onvore-mock__stat-label {
	font-size: 9px;
	color: var(--onvore-muted);
	margin-bottom: 4px;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}
.onvore-mock__stat-value {
	font-size: 16px;
	font-weight: 800;
	color: var(--onvore-ink);
	letter-spacing: -0.01em;
}
.onvore-mock__stat-trend {
	font-size: 9px;
	color: var(--onvore-success);
	font-weight: 600;
	margin-top: 2px;
}
.onvore-mock__vendors {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 8px;
}
.onvore-mock__vendor {
	background: #ffffff;
	border: 1px solid var(--onvore-line);
	border-radius: 8px;
	padding: 8px;
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.onvore-mock__vendor-thumb {
	height: 36px;
	border-radius: 5px;
	background: linear-gradient(135deg, var(--onvore-brand-soft), var(--onvore-gold-soft));
}
.onvore-mock__vendor-thumb--alt {
	background: linear-gradient(135deg, #e7e4ec, #fce4ec);
}
.onvore-mock__vendor-thumb--alt2 {
	background: linear-gradient(135deg, #fff4d6, #f1ecf7);
}
.onvore-mock__vendor-name {
	font-size: 10px;
	font-weight: 600;
	color: var(--onvore-ink);
	line-height: 1.2;
}
.onvore-mock__vendor-meta {
	font-size: 9px;
	color: var(--onvore-muted);
}
/* Floating chips */
.onvore-chip {
	position: absolute;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 14px;
	background: #ffffff;
	border-radius: 999px;
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.25);
	font-size: 13px;
	font-weight: 600;
	color: var(--onvore-ink);
	z-index: 3;
}
.onvore-chip__icon {
	width: 22px;
	height: 22px;
	border-radius: 6px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: #ffffff;
	font-size: 12px;
	font-weight: 800;
}
.onvore-chip--dokan {
	top: 0;
	left: -6%;
}
.onvore-chip--dokan .onvore-chip__icon { background: linear-gradient(135deg, #bd1e51, #f7b500); }
.onvore-chip--woo {
	top: 28%;
	right: -8%;
}
.onvore-chip--woo .onvore-chip__icon { background: #7f54b3; }
.onvore-chip--shopify {
	bottom: 8%;
	left: -10%;
}
.onvore-chip--shopify .onvore-chip__icon { background: #96bf48; }
.onvore-chip--mobile {
	bottom: -2%;
	right: -2%;
}
.onvore-chip--mobile .onvore-chip__icon { background: #0e0a1f; }
@media (max-width: 960px) {
	.onvore-banner__visual { min-height: 320px; max-width: 520px; margin: 0 auto; width: 100%; }
	.onvore-chip--dokan { left: 0; }
	.onvore-chip--woo { right: 0; }
	.onvore-chip--shopify { left: 0; }
	.onvore-chip--mobile { right: 0; }
}
@media (max-width: 540px) {
	.onvore-banner__visual { min-height: 280px; }
	.onvore-chip { font-size: 11px; padding: 8px 12px; }
	.onvore-chip__icon { width: 18px; height: 18px; font-size: 10px; }
}

/* ---------- Services grid ---------- */
.onvore-services {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 28px;
}
.onvore-services--single { grid-template-columns: 1fr; }
@media (max-width: 800px) {
	.onvore-services { grid-template-columns: 1fr; }
}
.onvore-service-card {
	background: var(--onvore-bg-card);
	border: 1px solid var(--onvore-line);
	border-radius: var(--onvore-radius-lg);
	padding: 36px;
	display: flex;
	flex-direction: column;
	gap: 16px;
	position: relative;
	overflow: hidden;
	transition: all 200ms ease;
}
.onvore-service-card::before {
	content: '';
	position: absolute;
	inset: 0;
	border-radius: inherit;
	padding: 1px;
	background: linear-gradient(135deg, transparent, transparent);
	-webkit-mask: linear-gradient(#000, #000) content-box, linear-gradient(#000, #000);
	-webkit-mask-composite: xor;
	mask-composite: exclude;
	pointer-events: none;
	opacity: 0;
	transition: opacity 200ms ease;
}
.onvore-service-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--onvore-shadow-lg);
	border-color: transparent;
}
.onvore-service-card:hover::before {
	background: linear-gradient(135deg, var(--onvore-brand), var(--onvore-gold));
	opacity: 1;
}
.onvore-service-card--featured {
	background: linear-gradient(135deg, #ffffff 0%, #fff9f0 100%);
	border-color: var(--onvore-brand);
	border-width: 2px;
	grid-column: 1 / -1;
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	padding: 48px;
	gap: 40px;
}
@media (max-width: 800px) {
	.onvore-service-card--featured { grid-template-columns: 1fr; padding: 32px; }
}
.onvore-service-card__badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: var(--onvore-brand);
	color: #ffffff;
	padding: 6px 14px;
	border-radius: 999px;
	font-weight: 600;
	font-size: 12px;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	margin-bottom: 16px;
	align-self: flex-start;
}
.onvore-service-card__icon {
	width: 56px;
	height: 56px;
	border-radius: 14px;
	background: var(--onvore-brand-soft);
	color: var(--onvore-brand);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 8px;
}
.onvore-service-card__icon--gold { background: var(--onvore-gold-soft); color: #b8810a; }
.onvore-service-card__icon--green { background: #e8f5d8; color: #5b8a2a; }
.onvore-service-card__icon--purple { background: #ede4f7; color: #7f54b3; }
.onvore-service-card__icon--ink { background: #ede9f5; color: #0e0a1f; }
.onvore-service-card h3 {
	font-size: 24px;
	margin-bottom: 8px;
	color: var(--onvore-ink);
}
.onvore-service-card__lead {
	color: var(--onvore-muted);
	font-size: 16px;
	margin: 0;
}
.onvore-service-card__list {
	list-style: none;
	padding: 0;
	margin: 8px 0 0;
}
.onvore-service-card__list li {
	padding-left: 24px;
	position: relative;
	margin-bottom: 8px;
	font-size: 15px;
	color: var(--onvore-ink-soft);
}
.onvore-service-card__list li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 8px;
	width: 14px;
	height: 14px;
	border-radius: 50%;
	background: var(--onvore-brand);
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='white' d='M6.3 11.5L2.7 7.9l1.4-1.4 2.2 2.2 5-5 1.4 1.4z'/></svg>");
	background-repeat: no-repeat;
	background-position: center;
	background-size: 12px;
}
.onvore-service-card__cta {
	margin-top: auto;
	padding-top: 8px;
}

/* Featured Dokan illustration column */
.onvore-service-card__visual {
	background: linear-gradient(135deg, #1a0e2e 0%, #3d0c4a 100%);
	border-radius: var(--onvore-radius);
	padding: 28px;
	display: flex;
	flex-direction: column;
	gap: 12px;
	color: #ffffff;
	position: relative;
	overflow: hidden;
	min-height: 280px;
}
.onvore-service-card__visual::before {
	content: '';
	position: absolute;
	width: 240px;
	height: 240px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(247, 181, 0, 0.25), transparent 70%);
	top: -60px;
	right: -60px;
	pointer-events: none;
}
.onvore-vendor-tile {
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: 10px;
	padding: 12px 14px;
	display: flex;
	align-items: center;
	gap: 12px;
	backdrop-filter: blur(6px);
	position: relative;
	z-index: 1;
}
.onvore-vendor-tile__avatar {
	width: 36px;
	height: 36px;
	border-radius: 10px;
	background: linear-gradient(135deg, var(--onvore-brand), var(--onvore-gold));
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	font-size: 14px;
	color: #ffffff;
}
.onvore-vendor-tile__avatar--alt { background: linear-gradient(135deg, #7f54b3, #bd1e51); }
.onvore-vendor-tile__avatar--alt2 { background: linear-gradient(135deg, #f7b500, #ff7a59); }
.onvore-vendor-tile__name {
	font-size: 13px;
	font-weight: 600;
	color: #ffffff;
	margin: 0 0 2px;
}
.onvore-vendor-tile__meta {
	font-size: 11px;
	color: rgba(255, 255, 255, 0.6);
}
.onvore-vendor-tile__pill {
	margin-left: auto;
	background: rgba(247, 181, 0, 0.18);
	color: #f7b500;
	padding: 2px 8px;
	border-radius: 999px;
	font-size: 10px;
	font-weight: 600;
}

/* ---------- Upwork showcase ---------- */
.onvore-upwork {
	background: linear-gradient(135deg, #0a1f0a 0%, #14532d 100%);
	border-radius: var(--onvore-radius-lg);
	padding: 56px 48px;
	color: #ffffff;
	position: relative;
	overflow: hidden;
}
.onvore-upwork::before {
	content: '';
	position: absolute;
	width: 400px;
	height: 400px;
	background: radial-gradient(circle, rgba(108, 191, 28, 0.4), transparent 70%);
	border-radius: 50%;
	filter: blur(60px);
	top: -100px;
	right: -100px;
	pointer-events: none;
}
.onvore-upwork__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	margin-bottom: 40px;
	flex-wrap: wrap;
	position: relative;
}
.onvore-upwork__title-block h2 {
	color: #ffffff;
	font-size: clamp(26px, 3vw, 34px);
	margin-bottom: 8px;
}
.onvore-upwork__title-block p {
	color: rgba(255, 255, 255, 0.72);
	margin: 0;
	font-size: 16px;
}
.onvore-upwork__rated {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	background: rgba(108, 191, 28, 0.15);
	border: 1px solid rgba(108, 191, 28, 0.35);
	color: #b8e986;
	padding: 10px 16px;
	border-radius: 999px;
	font-weight: 600;
	font-size: 13px;
}
.onvore-upwork__stats {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 16px;
	position: relative;
}
@media (max-width: 900px) {
	.onvore-upwork__stats { grid-template-columns: repeat(3, 1fr); }
	.onvore-upwork { padding: 40px 28px; }
}
@media (max-width: 540px) {
	.onvore-upwork__stats { grid-template-columns: repeat(2, 1fr); }
}
.onvore-upwork-stat {
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: 14px;
	padding: 20px 16px;
	text-align: left;
	backdrop-filter: blur(8px);
}
.onvore-upwork-stat__icon {
	width: 36px;
	height: 36px;
	border-radius: 10px;
	background: rgba(108, 191, 28, 0.18);
	color: #b8e986;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 14px;
}
.onvore-upwork-stat__value {
	font-size: 26px;
	font-weight: 800;
	color: #ffffff;
	line-height: 1;
	margin-bottom: 4px;
	letter-spacing: -0.02em;
}
.onvore-upwork-stat__label {
	font-size: 13px;
	color: rgba(255, 255, 255, 0.65);
	line-height: 1.35;
}
.onvore-upwork__actions {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
	margin-top: 36px;
	position: relative;
}
.onvore-upwork__actions .onvore-btn--primary {
	background: #6cbf1c;
	border-color: #6cbf1c;
	color: #0a1f0a;
}
.onvore-upwork__actions .onvore-btn--primary:hover {
	background: #84d62e;
	border-color: #84d62e;
	color: #0a1f0a;
}
.onvore-upwork__actions .onvore-btn--ghost {
	background: transparent;
	color: #ffffff;
	border-color: rgba(255, 255, 255, 0.25);
}
.onvore-upwork__actions .onvore-btn--ghost:hover {
	background: rgba(255, 255, 255, 0.08);
	color: #ffffff;
	border-color: rgba(255, 255, 255, 0.45);
}

/* ---------- Inner service page header ---------- */
.onvore-service-hero {
	background: linear-gradient(135deg, #1a0e2e 0%, #3d0c4a 100%);
	color: #ffffff;
	padding: 88px 0 72px;
	position: relative;
	overflow: hidden;
	isolation: isolate;
}
.onvore-service-hero::before {
	content: '';
	position: absolute;
	width: 480px;
	height: 480px;
	background: radial-gradient(circle, rgba(189, 30, 81, 0.5), transparent 70%);
	border-radius: 50%;
	filter: blur(70px);
	top: -120px;
	right: -120px;
	z-index: -1;
	pointer-events: none;
}
.onvore-service-hero__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.18);
	color: #ffffff;
	padding: 6px 14px;
	border-radius: 999px;
	font-weight: 500;
	font-size: 13px;
	letter-spacing: 0.04em;
	margin-bottom: 20px;
}
.onvore-service-hero h1 {
	color: #ffffff;
	margin-bottom: 20px;
	max-width: 820px;
}
.onvore-service-hero h1 em {
	font-style: normal;
	color: var(--onvore-gold);
}
.onvore-service-hero__lead {
	font-size: 19px;
	color: rgba(255, 255, 255, 0.78);
	max-width: 720px;
	margin-bottom: 32px;
}
.onvore-service-hero__actions {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
}
.onvore-service-hero__actions .onvore-btn--primary {
	background: #ffffff;
	color: #1a0e2e;
	border-color: #ffffff;
}
.onvore-service-hero__actions .onvore-btn--primary:hover {
	background: var(--onvore-gold);
	color: #1a0e2e;
	border-color: var(--onvore-gold);
}
.onvore-service-hero__actions .onvore-btn--ghost {
	color: #ffffff;
	border-color: rgba(255, 255, 255, 0.25);
}
.onvore-service-hero__actions .onvore-btn--ghost:hover {
	background: rgba(255, 255, 255, 0.08);
	color: #ffffff;
	border-color: rgba(255, 255, 255, 0.45);
}

/* ---------- Checklist (used in service pages) ---------- */
.onvore-checklist {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 14px 28px;
}
@media (max-width: 700px) {
	.onvore-checklist { grid-template-columns: 1fr; }
}
.onvore-checklist li {
	padding-left: 32px;
	position: relative;
	font-size: 16px;
	color: var(--onvore-ink-soft);
	line-height: 1.5;
	margin: 0;
}
.onvore-checklist li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 4px;
	width: 20px;
	height: 20px;
	border-radius: 50%;
	background: var(--onvore-brand);
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='white' d='M6.3 11.5L2.7 7.9l1.4-1.4 2.2 2.2 5-5 1.4 1.4z'/></svg>");
	background-repeat: no-repeat;
	background-position: center;
	background-size: 14px;
}
.onvore-checklist--gold li::before { background-color: var(--onvore-gold); }

/* ---------- Process steps ---------- */
.onvore-process {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
	counter-reset: step;
}
@media (max-width: 900px) {
	.onvore-process { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
	.onvore-process { grid-template-columns: 1fr; }
}
.onvore-process__step {
	background: var(--onvore-bg-card);
	border: 1px solid var(--onvore-line);
	border-radius: var(--onvore-radius);
	padding: 28px 24px 24px;
	position: relative;
	transition: all 200ms ease;
}
.onvore-process__step:hover {
	transform: translateY(-2px);
	border-color: var(--onvore-brand);
	box-shadow: var(--onvore-shadow);
}
.onvore-process__step::before {
	counter-increment: step;
	content: counter(step, decimal-leading-zero);
	position: absolute;
	top: -18px;
	left: 24px;
	background: linear-gradient(135deg, var(--onvore-brand), #7f1741);
	color: #ffffff;
	width: 40px;
	height: 40px;
	border-radius: 12px;
	font-size: 15px;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 8px 20px rgba(189, 30, 81, 0.3);
}
.onvore-process__step h3 {
	font-size: 18px;
	margin: 16px 0 8px;
	color: var(--onvore-ink);
}
.onvore-process__step p {
	font-size: 14px;
	color: var(--onvore-muted);
	margin: 0;
	line-height: 1.55;
}

/* ---------- Tech stack chips ---------- */
.onvore-tech {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	justify-content: center;
}
.onvore-tech__chip {
	background: var(--onvore-bg-card);
	border: 1px solid var(--onvore-line);
	color: var(--onvore-ink-soft);
	padding: 10px 18px;
	border-radius: 999px;
	font-weight: 500;
	font-size: 14px;
	transition: all 150ms ease;
}
.onvore-tech__chip:hover {
	border-color: var(--onvore-brand);
	color: var(--onvore-brand);
}

/* ---------- Two-column "split" used in service pages ---------- */
.onvore-split {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 48px;
	align-items: center;
}
@media (max-width: 900px) {
	.onvore-split { grid-template-columns: 1fr; gap: 32px; }
}
.onvore-split--reverse > div:first-child { order: 2; }
@media (max-width: 900px) {
	.onvore-split--reverse > div:first-child { order: 0; }
}
.onvore-split__visual {
	background: linear-gradient(135deg, var(--onvore-brand-soft) 0%, var(--onvore-gold-soft) 100%);
	border-radius: var(--onvore-radius-lg);
	padding: 40px;
	min-height: 320px;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	overflow: hidden;
}
.onvore-split__visual--dark {
	background: linear-gradient(135deg, #1a0e2e 0%, #3d0c4a 100%);
	color: #ffffff;
}
.onvore-split__caption {
	display: inline-block;
	color: var(--onvore-brand);
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	margin-bottom: 12px;
}

/* ---------- Marketplace illustration tiles (for service page visuals) ---------- */
.onvore-illus {
	width: 100%;
	display: grid;
	gap: 10px;
}
.onvore-illus--stack {
	grid-template-columns: 1fr;
}
.onvore-illus--grid3 {
	grid-template-columns: repeat(3, 1fr);
}
.onvore-illus__tile {
	background: rgba(255, 255, 255, 0.85);
	border: 1px solid var(--onvore-line);
	border-radius: 12px;
	padding: 14px;
	font-size: 13px;
	color: var(--onvore-ink);
	font-weight: 600;
	display: flex;
	align-items: center;
	gap: 10px;
	box-shadow: 0 4px 12px rgba(14, 10, 31, 0.06);
}
.onvore-illus__tile small {
	display: block;
	font-weight: 400;
	color: var(--onvore-muted);
	font-size: 11px;
	margin-top: 2px;
}
.onvore-illus__tile-icon {
	width: 32px;
	height: 32px;
	border-radius: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #ffffff;
	flex-shrink: 0;
	background: linear-gradient(135deg, var(--onvore-brand), var(--onvore-gold));
}

/* ---------- Final CTA variant ---------- */
.onvore-cta--split {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: 40px;
	align-items: center;
	text-align: left;
	padding: 48px;
}
@media (max-width: 800px) {
	.onvore-cta--split { grid-template-columns: 1fr; text-align: center; padding: 36px 24px; }
}
.onvore-cta--split h2 { text-align: inherit; }
.onvore-cta--split .onvore-cta__actions {
	display: flex;
	gap: 14px;
	flex-wrap: wrap;
	justify-content: flex-end;
}
@media (max-width: 800px) {
	.onvore-cta--split .onvore-cta__actions { justify-content: center; }
}
