/* =================================================================
 * NXTL SaaS product pages — Satka-aligned: black canvas, single accent.
 * Matches Data Pricing / Why NXTL (primary #ff5e70 from theme tokens).
 * ================================================================= */

.nxtl-saas-product {
	--saas-bg: #000000;
	--saas-elevated: #111111;
	--saas-card: #151515;
	--saas-border: rgba(255, 255, 255, 0.08);
	--saas-border-strong: rgba(255, 255, 255, 0.14);
	--saas-accent: #ff5e70;
	--saas-text: #f3f4f6;
	--saas-muted: rgba(255, 255, 255, 0.62);
	--saas-radius: 16px;
	--saas-radius-sm: 10px;
	--saas-section-x: clamp(20px, 5vw, 56px);
	--saas-section-y: clamp(56px, 8vw, 88px);

	position: relative;
	display: block;
	color: var(--saas-text);
	background-color: var(--saas-bg);
	/* Very subtle depth — Satka-black canvas + faint warmth + micro-grid */
	background-image:
		radial-gradient(ellipse 130% 70% at 50% -15%, rgba(255, 94, 112, 0.055), transparent 52%),
		radial-gradient(ellipse 70% 45% at 100% 30%, rgba(255, 255, 255, 0.025), transparent 50%),
		linear-gradient(180deg, rgba(255, 255, 255, 0.018) 0%, transparent 28%);
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	padding: 0;
	box-sizing: border-box;
	font-family: inherit;
	overflow-x: hidden;
}

.nxtl-saas-product::after {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	z-index: 0;
	opacity: 0.22;
	background-image: radial-gradient(rgba(255, 255, 255, 0.09) 0.6px, transparent 0.6px);
	background-size: 22px 22px;
	mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.65), rgba(0, 0, 0, 0.25));
}

.nxtl-saas-product > * {
	position: relative;
	z-index: 1;
}

.nxtl-saas-product code {
	font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace;
	font-size: 0.92em;
	background: rgba(255, 255, 255, 0.06);
	padding: 2px 6px;
	border-radius: 4px;
	color: var(--saas-text);
}

.nxtl-saas-product a {
	color: inherit;
}

/* Sections */
.nxtl-saas-section {
	padding: var(--saas-section-y) var(--saas-section-x);
	position: relative;
}

.nxtl-saas-section--alt {
	background: rgba(255, 255, 255, 0.02);
}

.nxtl-saas-section + .nxtl-saas-section {
	border-top: 1px solid var(--saas-border);
}

.nxtl-saas-section-head {
	max-width: 720px;
	margin: 0 auto clamp(32px, 4vw, 48px);
	text-align: center;
}

.nxtl-saas-section-eyebrow {
	display: inline-block;
	margin: 0 0 12px;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--saas-accent);
}

.nxtl-saas-section-head h2 {
	margin: 0 0 12px;
	font-size: clamp(1.65rem, 3.2vw, 2.35rem);
	line-height: 1.18;
	letter-spacing: -0.02em;
	font-weight: 700;
	color: var(--saas-text);
}

/* Hero — minimal atmosphere, no neon gradients */
.nxtl-saas-hero {
	position: relative;
	padding: clamp(88px, 12vw, 128px) var(--saas-section-x) clamp(44px, 6vw, 72px);
	overflow: hidden;
	isolation: isolate;
}

.nxtl-saas-hero-glow {
	position: absolute;
	inset: -20% -30% auto -30%;
	height: 95%;
	max-height: 520px;
	background: radial-gradient(
		65% 55% at 50% 0%,
		rgba(255, 94, 112, 0.07),
		transparent 68%
	);
	pointer-events: none;
	z-index: -1;
}

.nxtl-saas-hero-inner {
	max-width: 1080px;
	margin: 0 auto;
	text-align: center;
}

.nxtl-saas-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
	justify-content: center;
	margin: 0 0 18px;
}

.nxtl-saas-eyebrow-pill {
	display: inline-block;
	padding: 5px 12px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	background: rgba(255, 94, 112, 0.12);
	border: 1px solid rgba(255, 94, 112, 0.35);
	color: var(--saas-accent);
}

.nxtl-saas-eyebrow-tag {
	font-size: 12px;
	color: var(--saas-muted);
}

.nxtl-saas-hero-title {
	margin: 0 0 18px;
	font-size: clamp(2rem, 5vw, 3.25rem);
	line-height: 1.06;
	letter-spacing: -0.03em;
	font-weight: 800;
	color: var(--saas-text);
}

.nxtl-saas-hero-lead {
	margin: 0 auto 32px;
	max-width: 720px;
	font-size: clamp(1rem, 1.45vw, 1.12rem);
	line-height: 1.65;
	color: var(--saas-muted);
}

/* Buy card */
.nxtl-saas-buy-card {
	max-width: 640px;
	margin: 0 auto;
	padding: clamp(22px, 3vw, 32px);
	border-radius: var(--saas-radius);
	background: var(--saas-card);
	border: 1px solid var(--saas-border);
	box-shadow: 0 24px 48px -32px rgba(0, 0, 0, 0.85);
	text-align: left;
}

.nxtl-saas-buy-card-price {
	display: flex;
	align-items: baseline;
	gap: 14px;
	flex-wrap: wrap;
	margin: 0 0 18px;
}

.nxtl-saas-buy-card-price-label {
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--saas-muted);
	width: 100%;
	margin-bottom: 4px;
}

.nxtl-saas-buy-card-price-value {
	font-size: clamp(1.5rem, 3vw, 2rem);
	font-weight: 700;
	font-variant-numeric: tabular-nums;
	letter-spacing: -0.02em;
	color: var(--saas-text);
	flex: 1 1 auto;
	min-width: 0;
}

.nxtl-saas-buy-card-price-value--placeholder {
	font-size: clamp(1.25rem, 2.4vw, 1.65rem);
	font-weight: 600;
	color: var(--saas-text);
}

.nxtl-saas-buy-card-price-value .woocommerce-Price-amount,
.nxtl-saas-buy-card-price-value .amount {
	color: inherit;
}

.nxtl-saas-buy-card-price-value del {
	color: var(--saas-muted);
	font-size: 0.72em;
	margin-right: 6px;
}

.nxtl-saas-buy-card-rating {
	margin-left: auto;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 13px;
	color: var(--saas-muted);
	flex-shrink: 0;
}

.nxtl-saas-stars {
	color: #d4a853;
	letter-spacing: 1px;
	font-size: 13px;
}

.nxtl-saas-variation-note {
	margin: 0 0 14px;
	padding: 10px 12px;
	font-size: 13px;
	line-height: 1.5;
	color: var(--saas-muted);
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid var(--saas-border);
	border-radius: var(--saas-radius-sm);
	text-align: center;
}

.nxtl-saas-credit-callout {
	margin: 0;
	padding: 14px 16px;
	border-radius: var(--saas-radius-sm);
	border: 1px solid rgba(255, 94, 112, 0.22);
	background: rgba(255, 94, 112, 0.06);
	text-align: left;
}

@media (max-width: 540px) {
	.nxtl-saas-credit-callout {
		padding: 12px 14px;
	}
	.nxtl-saas-credit-callout__text {
		font-size: 12.5px;
	}
}

.nxtl-saas-credit-callout__title {
	margin: 0 0 8px;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--saas-accent);
}

.nxtl-saas-credit-callout__text {
	margin: 0;
	font-size: 13px;
	line-height: 1.58;
	color: var(--saas-muted);
}

.nxtl-saas-buy-card-form {
	margin: 0;
}

/*
 * eSIM buy column: use flex + gap so spacing between the info boxes and the
 * WooCommerce form is predictable. Relying only on margin-top on `form.cart`
 * stacks with Satka/WC rules below and reads as a huge empty band.
 */
.nxtl-saas-product--esim .nxtl-saas-buy-card-form {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 12px;
}

.nxtl-saas-product--esim .nxtl-saas-buy-card-form .nxtl-saas-variation-note {
	margin-bottom: 0 !important;
}

/*
 * Hide attribute picker — default variation applied via JS.
 * WC core applies `form.cart table { border-bottom: 1px }`; kill it so no hairline
 * stacks with the form rule below (otherwise two rules appear above quantity).
 */
.nxtl-saas-product--esim .nxtl-saas-buy-card-form table.variations,
.nxtl-saas-product--esim .nxtl-saas-buy-card-form .variations {
	display: none !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
	border-bottom: none !important;
	height: 0 !important;
	min-height: 0 !important;
	overflow: hidden !important;
}

.nxtl-saas-product--esim .nxtl-saas-buy-card-form .reset_variations {
	display: none !important;
}

/*
 * Single centered column for both products — quantity / amount input +
 * primary CTA stack inside a balanced 420px column, the same layout
 * the Top-Up amount selection already uses. Centered with auto margins.
 */
.nxtl-saas-buy-card-form .cart {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 12px;
	width: 100%;
	max-width: 420px;
	margin: 0 auto;
}

/*
 * Balance top-up (simple product — not variable): Satka sets
 * `.woocommerce div.product form.cart { margin-top: 1.5rem }`,
 * `.woocommerce div.product form.cart div.quantity { margin-right: 1rem }`,
 * and `.woocommerce form .form-row { padding: 3px 0 }` (`style.css`). WC layout
 * adds `.woocommerce form .form-row { margin: 0 0 6px }` (bundled CSS). Those
 * stack with flex `gap` so the amount field ↔ “Top up” looks looser than eSIM.
 *
 * Collapse everything to 0, then add ONE deliberate offset on the button only.
 */
.nxtl-saas-product--topup .nxtl-saas-buy-card-form form.cart {
	gap: 0 !important;
	row-gap: 0 !important;
	column-gap: 0 !important;
	margin-block: 0 !important;
	margin-inline: auto !important;
	padding: 0 !important;
}

body.nxtl-saas-product-topup.woocommerce .nxtl-saas-buy-card-form form.cart,
body.nxtl-saas-product-topup .woocommerce div.product .nxtl-saas-buy-card-form form.cart {
	gap: 0 !important;
	margin-block: 0 !important;
	margin-inline: auto !important;
}

/* Beat Satka `.woocommerce form .form-row { padding: 3px 0 }` on nested rows. */
.nxtl-saas-product--topup .nxtl-saas-buy-card-form form.cart > *,
.nxtl-saas-product--topup .nxtl-saas-buy-card-form form.cart .woocommerce-form-row,
.nxtl-saas-product--topup .nxtl-saas-buy-card-form form.cart .form-row {
	margin-block: 0 !important;
	margin-inline: 0 !important;
	margin: 0 !important;
	padding-block: 0 !important;
	padding-inline: 0 !important;
	padding: 0 !important;
}

/*
 * Satka line ~3651 — quantity sits beside inline buttons on default PDP; here it’s
 * full-width stacked — strip horizontal margin so it doesn’t interact oddly.
 */
.nxtl-saas-product--topup .nxtl-saas-buy-card-form form.cart div.quantity,
body.nxtl-saas-product-topup .woocommerce div.product .nxtl-saas-buy-card-form form.cart div.quantity {
	margin: 0 !important;
	margin-right: 0 !important;
	margin-bottom: 0 !important;
	padding: 0 !important;
	box-sizing: border-box !important;
}

.nxtl-saas-product--topup .nxtl-saas-buy-card-form form.cart .quantity {
	display: flex !important;
	flex-direction: column !important;
	align-items: stretch !important;
	gap: 0 !important;
	row-gap: 0 !important;
}

/* Visible label + input inside `.quantity` — SaaS label rule uses margin-bottom: 6px */
.nxtl-saas-product--topup .nxtl-saas-buy-card-form form.cart .quantity label:not(.screen-reader-text) {
	margin-bottom: 4px !important;
}

.nxtl-saas-product--topup .nxtl-saas-buy-card-form form.cart .quantity input.input-text,
.nxtl-saas-product--topup .nxtl-saas-buy-card-form form.cart .quantity input.qty {
	margin-block: 0 !important;
	vertical-align: top !important;
}

.nxtl-saas-product--topup .nxtl-saas-buy-card-form form.cart br {
	display: none !important;
}

.nxtl-saas-product--topup .nxtl-saas-buy-card-form form.cart p:empty {
	display: none !important;
	margin: 0 !important;
	padding: 0 !important;
	min-height: 0 !important;
}

/*
 * Single offset under the amount control (simple product — no
 * `.woocommerce-variation-add-to-cart` wrapper).
 */
.nxtl-saas-product--topup .nxtl-saas-buy-card-form form.cart .single_add_to_cart_button,
.nxtl-saas-product--topup .nxtl-saas-buy-card-form form.cart button[type="submit"] {
	margin-top: 6px !important;
	margin-bottom: 0 !important;
}

/*
 * eSIM variable form mirrors the Top-Up simple form: 420px centered
 * column, no borders/separators above quantity, no inherited gap.
 */
.nxtl-saas-product--esim .nxtl-saas-buy-card-form form.cart.variations_form {
	gap: 0 !important;
	row-gap: 0 !important;
	column-gap: 0 !important;
	border: none !important;
	border-top: none !important;
	border-bottom: none !important;
	outline: none !important;
	box-shadow: none !important;
	margin: 0 auto !important;
	margin-block: 0 !important;
	padding: 0 !important;
	width: 100% !important;
	max-width: 420px !important;
}

.nxtl-saas-product--esim .nxtl-saas-buy-card-form form.cart.variations_form > *,
.nxtl-saas-product--esim .nxtl-saas-buy-card-form form.cart.variations_form hr {
	border-top: 0 !important;
	border-bottom: 0 !important;
	box-shadow: none !important;
}

.nxtl-saas-product--esim .nxtl-saas-buy-card-form form.cart.variations_form hr {
	display: none !important;
}

.nxtl-saas-buy-card-form .cart::before,
.nxtl-saas-buy-card-form .cart::after {
	display: none !important;
}

.nxtl-saas-buy-card-form label {
	color: var(--saas-text);
	font-weight: 600;
	font-size: 13px;
	display: block;
	margin-bottom: 6px;
}

.nxtl-saas-buy-card-form .quantity,
.nxtl-saas-buy-card-form .quantity.buttons_added {
	display: flex;
	align-items: stretch;
	width: 100%;
	max-width: 100%;
}

.nxtl-saas-buy-card-form .quantity input,
.nxtl-saas-buy-card-form .topup-amount-input,
.nxtl-saas-buy-card-form input[type="number"],
.nxtl-saas-buy-card-form input[type="text"],
.nxtl-saas-buy-card-form input[type="email"] {
	box-sizing: border-box;
	width: 100% !important;
	max-width: none !important;
	background: var(--saas-elevated) !important;
	color: var(--saas-text) !important;
	border: 1px solid var(--saas-border-strong) !important;
	border-radius: var(--saas-radius-sm) !important;
	padding: 12px 14px !important;
	min-height: 48px !important;
	font-size: 15px !important;
	font-weight: 600;
	min-width: 0;
}

.nxtl-saas-buy-card-form input:focus {
	outline: 2px solid rgba(255, 94, 112, 0.45) !important;
	outline-offset: 1px;
}

.nxtl-saas-buy-card-form .single_add_to_cart_button,
.nxtl-saas-buy-card-form button[type="submit"] {
	background: var(--saas-accent) !important;
	color: #fff !important;
	border: 0 !important;
	border-radius: var(--saas-radius-sm) !important;
	padding: 14px 22px !important;
	font-weight: 700 !important;
	font-size: 15px !important;
	min-height: 48px !important;
	box-shadow: none !important;
	transition: filter 120ms ease, transform 120ms ease;
	cursor: pointer;
	white-space: nowrap;
	width: 100%;
}

.nxtl-saas-buy-card-form .single_add_to_cart_button:hover,
.nxtl-saas-buy-card-form button[type="submit"]:hover {
	filter: brightness(1.06);
	transform: translateY(-1px);
}

.nxtl-saas-buy-card-form .single_variation_wrap {
	margin-top: 8px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	width: 100%;
	align-items: stretch;
}

.nxtl-saas-product--esim .nxtl-saas-buy-card-form .single_variation_wrap {
	margin: 0 !important;
	padding: 0 !important;
	border: none !important;
	box-shadow: none !important;
	background: transparent !important;
	gap: 0 !important;
	width: 100% !important;
}

/*
 * Variation data placeholder — hide completely so variations.js can still
 * update inner HTML without reserving vertical space.
 */
.nxtl-saas-product--esim .nxtl-saas-buy-card-form .woocommerce-variation-add-to-cart {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 10px;
	width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	border: none !important;
	border-top: none !important;
	box-shadow: none !important;
}

/*
 * Quantity + Buy now — gap below callout is `margin-top` on
 * `form.cart.variations_form`; avoid stacking extra margins here.
 */
.nxtl-saas-product--esim .nxtl-saas-buy-card-form .woocommerce-variation-add-to-cart .quantity {
	width: 100% !important;
	max-width: none !important;
	margin: 0 !important;
}

.nxtl-saas-product--esim .nxtl-saas-buy-card-form .woocommerce-variation-add-to-cart .single_add_to_cart_button,
.nxtl-saas-product--esim .nxtl-saas-buy-card-form .woocommerce-variation-add-to-cart button[type="submit"] {
	width: 100% !important;
	min-width: 0 !important;
}

.nxtl-saas-product--esim .nxtl-saas-buy-card-form .woocommerce-variation-price,
.nxtl-saas-product--esim .nxtl-saas-buy-card-form .woocommerce-variation-availability,
.nxtl-saas-product--esim .nxtl-saas-buy-card-form .woocommerce-variation-description,
.nxtl-saas-product--esim .nxtl-saas-buy-card-form .woocommerce-variation-add-to-cart .stock {
	display: none !important;
	height: 0 !important;
	min-height: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
}

.nxtl-saas-buy-card-form .woocommerce-variation-price {
	margin-top: 4px;
}

.nxtl-saas-buy-card-form .price {
	color: var(--saas-text);
	font-size: 15px;
}

.nxtl-saas-buy-card-form .stock {
	color: var(--saas-muted);
	font-size: 13px;
}

.nxtl-saas-buy-card-form .woocommerce-variation-description {
	display: none !important;
}

body.nxtl-saas-product-esim.woocommerce .nxtl-saas-buy-card-form form.cart.variations_form,
body.nxtl-saas-product-esim .woocommerce div.product .nxtl-saas-buy-card-form form.cart.variations_form {
	margin-block: 0 !important;
	margin-inline: auto !important;
}

/*
 * Kill phantom vertical rhythm inside the variable form: WC/Satka margins on
 * `.woocommerce-variation-price`, `.variations` table spacing, etc.
 */
.nxtl-saas-product--esim .nxtl-saas-buy-card-form form.cart.variations_form > * {
	margin-top: 0 !important;
	margin-bottom: 0 !important;
}

.nxtl-saas-product--esim .nxtl-saas-buy-card-form form.cart.variations_form > table.variations {
	display: none !important;
}

/* Between hidden `.variations` table and `.single_variation_wrap` — SR-only node */
.nxtl-saas-product--esim .nxtl-saas-buy-card-form .reset_variations_alert {
	position: absolute !important;
	width: 1px !important;
	height: 1px !important;
	padding: 0 !important;
	margin: -1px !important;
	overflow: hidden !important;
	clip: rect(0, 0, 0, 0) !important;
	border: 0 !important;
}

.nxtl-saas-product--esim .nxtl-saas-buy-card-form .woocommerce-variation-price,
.nxtl-saas-product--esim .nxtl-saas-buy-card-form .woocommerce-variation-price .price {
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
	display: none !important;
}

.nxtl-saas-product--esim .nxtl-saas-buy-card-form .single_variation_wrap {
	flex-shrink: 0;
	min-height: 0 !important;
}

.nxtl-saas-product--esim .nxtl-saas-buy-card-form form.cart .woocommerce-variation,
.nxtl-saas-product--esim .nxtl-saas-buy-card-form form.cart .woocommerce-variation:empty {
	display: none !important;
	height: 0 !important;
	min-height: 0 !important;
	max-height: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	overflow: hidden !important;
}

.nxtl-saas-product--esim .nxtl-saas-buy-card-form form.cart .single_variation_wrap > p,
.nxtl-saas-product--esim .nxtl-saas-buy-card-form form.cart .single_variation_wrap > br,
.nxtl-saas-product--esim .nxtl-saas-buy-card-form form.cart > p,
.nxtl-saas-product--esim .nxtl-saas-buy-card-form form.cart > br {
	display: none !important;
}

.nxtl-saas-buy-card-trust {
	list-style: none;
	margin: 12px auto 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 10px;
	width: 100%;
	max-width: 420px;
	font-size: 12px;
	line-height: 1.45;
	color: var(--saas-muted);
	border-top: none;
	box-sizing: border-box;
}

.nxtl-saas-buy-card-trust li {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	gap: 10px;
	align-items: flex-start;
	justify-content: flex-start;
	text-align: left;
	padding: 10px 12px;
	box-sizing: border-box;
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid var(--saas-border);
	border-radius: var(--saas-radius-sm);
	width: 100%;
}

@media (min-width: 560px) {
	.nxtl-saas-buy-card-trust {
		flex-direction: row;
		flex-wrap: nowrap;
		justify-content: space-between;
		align-items: stretch;
		gap: 10px;
		padding-left: 0;
		padding-right: 0;
	}

	.nxtl-saas-buy-card-trust li {
		flex: 1 1 0;
		min-width: 0;
		justify-content: center;
		text-align: center;
		flex-direction: column;
		align-items: center;
		padding: 12px 8px;
	}

	.nxtl-saas-buy-card-trust .nxtl-saas-trust-icon {
		margin-top: 0;
	}
}

.nxtl-saas-trust-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 20px;
	height: 20px;
	flex-shrink: 0;
	margin-top: 2px;
	color: var(--saas-accent);
}

.nxtl-saas-trust-icon svg {
	width: 16px;
	height: 16px;
}

/* Feature grid */
.nxtl-saas-feature-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
	max-width: 1120px;
	margin: 0 auto;
}

@media (max-width: 960px) {
	.nxtl-saas-feature-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 600px) {
	.nxtl-saas-feature-grid {
		grid-template-columns: 1fr;
	}
}

.nxtl-saas-feature-card {
	padding: 24px;
	border-radius: var(--saas-radius);
	background: var(--saas-card);
	border: 1px solid var(--saas-border);
	transition: border-color 0.15s ease;
}

.nxtl-saas-feature-card:hover {
	border-color: rgba(255, 94, 112, 0.22);
}

.nxtl-saas-feature-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	margin: 0 0 14px;
	border-radius: 10px;
	background: rgba(255, 94, 112, 0.08);
	border: 1px solid rgba(255, 94, 112, 0.2);
	color: var(--saas-accent);
}

.nxtl-saas-feature-icon svg {
	width: 20px;
	height: 20px;
}

.nxtl-saas-feature-card h3 {
	margin: 0 0 8px;
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--saas-text);
}

.nxtl-saas-feature-card p {
	margin: 0;
	font-size: 14px;
	line-height: 1.62;
	color: var(--saas-muted);
}

/* Process */
.nxtl-saas-process {
	list-style: none;
	margin: 0 auto;
	padding: 0;
	max-width: 1040px;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}

@media (max-width: 760px) {
	.nxtl-saas-process {
		grid-template-columns: 1fr;
	}
}

.nxtl-saas-process-step {
	padding: 24px;
	border-radius: var(--saas-radius);
	background: var(--saas-card);
	border: 1px solid var(--saas-border);
}

.nxtl-saas-process-num {
	display: inline-block;
	margin: 0 0 12px;
	font-size: 32px;
	font-weight: 800;
	font-variant-numeric: tabular-nums;
	letter-spacing: -0.02em;
	color: var(--saas-accent);
	line-height: 1;
}

.nxtl-saas-process-step h3 {
	margin: 0 0 8px;
	font-size: 1.08rem;
	font-weight: 700;
	color: var(--saas-text);
}

.nxtl-saas-process-step p {
	margin: 0;
	font-size: 14px;
	line-height: 1.62;
	color: var(--saas-muted);
}

/* Reviews */
.nxtl-saas-review-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
	max-width: 1120px;
	margin: 0 auto;
}

@media (max-width: 880px) {
	.nxtl-saas-review-grid {
		grid-template-columns: 1fr;
	}
}

.nxtl-saas-review-card {
	padding: 24px;
	border-radius: var(--saas-radius);
	background: var(--saas-card);
	border: 1px solid var(--saas-border);
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.nxtl-saas-review-stars {
	color: #d4a853;
	font-size: 16px;
	letter-spacing: 1px;
}

.nxtl-saas-review-quote {
	margin: 0;
	font-size: 14px;
	line-height: 1.62;
	color: var(--saas-muted);
	font-style: normal;
}

.nxtl-saas-review-author {
	margin: 0;
	font-size: 13px;
	color: var(--saas-muted);
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.nxtl-saas-review-author strong {
	color: var(--saas-text);
	font-weight: 700;
	font-style: normal;
}

/* FAQ */
.nxtl-saas-faq {
	max-width: 780px;
	margin: 0 auto;
}

.nxtl-saas-faq-item {
	border-bottom: 1px solid var(--saas-border);
	padding: 4px 0;
}

.nxtl-saas-faq-item summary {
	list-style: none;
	cursor: pointer;
	padding: 16px 4px;
	font-size: 1.02rem;
	font-weight: 600;
	color: var(--saas-text);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
}

.nxtl-saas-faq-item summary::-webkit-details-marker {
	display: none;
}

.nxtl-saas-faq-item summary::after {
	content: '+';
	font-size: 20px;
	font-weight: 400;
	color: var(--saas-accent);
	flex-shrink: 0;
	line-height: 1;
}

.nxtl-saas-faq-item[open] summary::after {
	content: '−';
}

.nxtl-saas-faq-item p {
	margin: 0 0 14px;
	padding: 0 4px;
	font-size: 14px;
	line-height: 1.62;
	color: var(--saas-muted);
	max-width: 70ch;
}

/* Final CTA */
.nxtl-saas-final-cta {
	padding: var(--saas-section-y) var(--saas-section-x);
	background: linear-gradient(180deg, rgba(255, 94, 112, 0.05), transparent);
	border-top: 1px solid var(--saas-border);
	text-align: center;
}

.nxtl-saas-final-cta-inner {
	max-width: 720px;
	margin: 0 auto;
}

.nxtl-saas-final-cta h2 {
	margin: 0 0 12px;
	font-size: clamp(1.65rem, 3.2vw, 2.35rem);
	line-height: 1.15;
	color: var(--saas-text);
	font-weight: 700;
}

.nxtl-saas-final-cta-lead {
	margin: 0 auto 28px;
	font-size: 1.02rem;
	line-height: 1.6;
	color: var(--saas-muted);
}

.nxtl-saas-product .nxtl-saas-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 14px 26px;
	border-radius: var(--saas-radius-sm);
	font-weight: 700;
	font-size: 15px;
	line-height: 1;
	border: 1px solid transparent;
	cursor: pointer;
	transition: filter 0.12s ease, transform 0.12s ease;
	text-decoration: none;
}

.nxtl-saas-product .nxtl-saas-btn-lg {
	padding: 14px 28px;
}

.nxtl-saas-product .nxtl-saas-btn-primary {
	background: var(--saas-accent);
	color: #fff;
}

.nxtl-saas-product .nxtl-saas-btn-primary:hover {
	filter: brightness(1.06);
	transform: translateY(-1px);
}

/* Woo notices */
.nxtl-saas-product .woocommerce-message,
.nxtl-saas-product .woocommerce-info,
.nxtl-saas-product .woocommerce-error,
.nxtl-saas-product .woocommerce-notices-wrapper > * {
	background: rgba(255, 255, 255, 0.04) !important;
	color: var(--saas-text) !important;
	border-radius: var(--saas-radius-sm) !important;
	border: 1px solid var(--saas-border-strong) !important;
	padding: 12px 16px !important;
	margin: 12px auto !important;
	max-width: 640px;
}

.nxtl-saas-product .woocommerce-message::before,
.nxtl-saas-product .woocommerce-info::before {
	color: var(--saas-accent) !important;
}

