/**
 * Pricing Page Frontend CSS
 *
 * Gusto-style pricing page with interactive toggle,
 * plan cards, and comparison grid.
 *
 * @package RCP_Modal_Registration
 * @since 2025-12-27.1
 */

/* ==========================================================================
   CSS Variables
   ========================================================================== */

.rcp-pricing-page {
	--pricing-primary: #4568dc;
	--pricing-secondary: #b06ab3;
	--pricing-gradient: linear-gradient(135deg, #4568dc 0%, #b06ab3 100%);
	--pricing-white: #ffffff;
	--pricing-black: #1a1a2e;
	--pricing-gray-100: #f8f9fa;
	--pricing-gray-200: #e9ecef;
	--pricing-gray-300: #dee2e6;
	--pricing-gray-500: #6c757d;
	--pricing-gray-700: #495057;
	--pricing-success: #28a745;
	--pricing-card-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
	--pricing-card-shadow-hover: 0 8px 30px rgba(69, 104, 220, 0.15);
	--pricing-featured-border: 3px solid var(--pricing-primary);
	--pricing-transition: 0.3s ease;
	--pricing-radius: 12px;
	--pricing-radius-sm: 8px;
}

/* ==========================================================================
   Base Layout
   ========================================================================== */

.rcp-pricing-page {
	font-family: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif;
	color: var(--pricing-black);
	line-height: 1.6;
	background: var(--pricing-white);
}

.rcp-pricing-container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 20px;
}

/* ==========================================================================
   Hero Section
   ========================================================================== */

.rcp-pricing-hero {
	padding: 60px 0 40px;
	text-align: center;
	background: var(--pricing-gray-100);
}

.rcp-pricing-headline {
	font-size: 2.75rem;
	font-weight: 700;
	margin: 0 0 16px;
	line-height: 1.2;
	background: var(--pricing-gradient);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.rcp-pricing-subheadline {
	font-size: 1.25rem;
	color: var(--pricing-gray-500);
	margin: 0 0 32px;
	max-width: 600px;
	margin-left: auto;
	margin-right: auto;
}

/* ==========================================================================
   Billing Toggle
   ========================================================================== */

.rcp-pricing-toggle {
	display: inline-flex;
	align-items: center;
	gap: 16px;
	background: var(--pricing-white);
	padding: 8px 20px;
	border-radius: 50px;
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08);
}

.toggle-label {
	font-size: 0.9375rem;
	font-weight: 500;
	color: var(--pricing-gray-500);
	transition: color var(--pricing-transition);
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: 8px;
}

.toggle-label.active {
	color: var(--pricing-black);
}

.toggle-badge {
	background: var(--pricing-gradient);
	color: var(--pricing-white);
	font-size: 0.75rem;
	font-weight: 600;
	padding: 3px 10px;
	border-radius: 20px;
}

.toggle-switch {
	position: relative;
	width: 56px;
	height: 28px;
	cursor: pointer;
}

.toggle-switch input {
	opacity: 0;
	width: 0;
	height: 0;
}

.toggle-slider {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: var(--pricing-gray-300);
	border-radius: 28px;
	transition: background var(--pricing-transition);
}

.toggle-slider::before {
	content: '';
	position: absolute;
	height: 22px;
	width: 22px;
	left: 3px;
	bottom: 3px;
	background: var(--pricing-white);
	border-radius: 50%;
	transition: transform var(--pricing-transition);
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
}

.toggle-switch input:checked + .toggle-slider {
	background: var(--pricing-gradient);
}

.toggle-switch input:checked + .toggle-slider::before {
	transform: translateX(28px);
}

/* ==========================================================================
   Plans Grid
   ========================================================================== */

.rcp-pricing-plans {
	padding: 60px 0;
}

.rcp-pricing-grid {
	display: grid;
	gap: 24px;
	align-items: start;
}

.rcp-pricing-grid-1 {
	grid-template-columns: 1fr;
	max-width: 400px;
	margin: 0 auto;
}

.rcp-pricing-grid-2 {
	grid-template-columns: repeat(2, 1fr);
	max-width: 800px;
	margin: 0 auto;
}

.rcp-pricing-grid-3 {
	grid-template-columns: repeat(3, 1fr);
}

.rcp-pricing-grid-4 {
	grid-template-columns: repeat(4, 1fr);
}

.rcp-pricing-grid-5 {
	grid-template-columns: repeat(5, 1fr);
}

@media (max-width: 1024px) {
	.rcp-pricing-grid-3,
	.rcp-pricing-grid-4,
	.rcp-pricing-grid-5 {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 640px) {
	.rcp-pricing-grid-2,
	.rcp-pricing-grid-3,
	.rcp-pricing-grid-4,
	.rcp-pricing-grid-5 {
		grid-template-columns: 1fr;
	}
}

/* ==========================================================================
   Plan Cards
   ========================================================================== */

.rcp-pricing-card {
	background: var(--pricing-white);
	border: 1px solid var(--pricing-gray-200);
	border-radius: var(--pricing-radius);
	padding: 32px 28px;
	box-shadow: var(--pricing-card-shadow);
	transition: transform var(--pricing-transition), box-shadow var(--pricing-transition);
	position: relative;
	display: flex;
	flex-direction: column;
}

.rcp-pricing-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--pricing-card-shadow-hover);
}

.rcp-pricing-card.featured {
	border: var(--pricing-featured-border);
	transform: scale(1.02);
	z-index: 1;
}

.rcp-pricing-card.featured:hover {
	transform: scale(1.02) translateY(-4px);
}

/* Custom Plan Card - "Let's Talk" style */
.rcp-pricing-card.custom-plan {
	border: 2px solid var(--pricing-accent, #4f46e5);
}

.rcp-pricing-card.custom-plan:hover {
	border-color: var(--pricing-accent-hover, #4338ca);
}

.plan-price-custom {
	margin-bottom: 16px;
}

.plan-price-custom .price-text {
	font-size: 1.75rem;
	font-weight: 600;
	color: var(--pricing-accent, #4f46e5);
}

.rcp-pricing-badge {
	position: absolute;
	top: -12px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--pricing-gradient);
	color: var(--pricing-white);
	font-size: 0.75rem;
	font-weight: 600;
	padding: 5px 16px;
	border-radius: 20px;
	white-space: nowrap;
}

.plan-name {
	font-size: 1.25rem;
	font-weight: 600;
	margin: 0 0 16px;
	color: var(--pricing-black);
}

.plan-price {
	display: flex;
	align-items: baseline;
	gap: 4px;
	margin-bottom: 16px;
}

.price-currency {
	font-size: 1.5rem;
	font-weight: 600;
	color: var(--pricing-black);
}

.price-amount {
	font-size: 3rem;
	font-weight: 700;
	line-height: 1;
	color: var(--pricing-black);
}

.price-suffix {
	font-size: 0.9375rem;
	color: var(--pricing-gray-500);
}

.plan-description {
	font-size: 0.9375rem;
	color: var(--pricing-gray-500);
	margin: 0 0 20px;
	flex-grow: 0;
}

.plan-features {
	list-style: none;
	padding: 0;
	margin: 0 0 24px;
	flex-grow: 1;
}

.plan-features li {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	font-size: 0.9375rem;
	color: var(--pricing-gray-700);
	margin-bottom: 12px;
}

.plan-features li:last-child {
	margin-bottom: 0;
}

.plan-features .checkmark-icon {
	flex-shrink: 0;
	color: var(--pricing-success);
	margin-top: 3px;
}

.plan-cta {
	display: block;
	width: 100%;
	padding: 14px 24px;
	font-size: 1rem;
	font-weight: 600;
	text-align: center;
	text-decoration: none;
	border-radius: var(--pricing-radius-sm);
	transition: all var(--pricing-transition);
	background: var(--pricing-gradient);
	color: var(--pricing-white);
	border: none;
	cursor: pointer;
}

.plan-cta:hover {
	opacity: 0.9;
	transform: translateY(-2px);
	color: var(--pricing-white);
}

.rcp-pricing-card.featured .plan-cta {
	box-shadow: 0 4px 15px rgba(69, 104, 220, 0.4);
}

.plan-cta-secondary {
	background: var(--pricing-white);
	color: var(--pricing-primary);
	border: 2px solid var(--pricing-primary);
}

.plan-cta-secondary:hover {
	background: var(--pricing-primary);
	color: var(--pricing-white);
}

.plan-cta-custom {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	background: var(--pricing-gray-700);
}

.plan-cta-custom:hover {
	background: var(--pricing-black);
}

.external-icon {
	flex-shrink: 0;
}

/* ==========================================================================
   Free Plan Section
   ========================================================================== */

.rcp-pricing-free-section {
	padding: 40px 0;
	background: var(--pricing-gray-100);
}

.rcp-pricing-free-box {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 40px;
	background: var(--pricing-white);
	border: 1px solid var(--pricing-gray-200);
	border-radius: var(--pricing-radius);
	padding: 32px 40px;
	box-shadow: var(--pricing-card-shadow);
}

.free-box-content {
	flex: 1;
}

.free-plan-name {
	font-size: 1.5rem;
	font-weight: 600;
	margin: 0 0 8px;
	color: var(--pricing-black);
}

.free-plan-description {
	font-size: 1rem;
	color: var(--pricing-gray-500);
	margin: 0 0 16px;
}

.free-plan-features {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 12px 24px;
}

.free-plan-features li {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 0.9375rem;
	color: var(--pricing-gray-700);
}

.free-plan-features .checkmark-icon {
	color: var(--pricing-success);
}

.free-box-cta {
	flex-shrink: 0;
}

.free-box-cta .plan-cta {
	width: auto;
	padding: 14px 32px;
}

@media (max-width: 768px) {
	.rcp-pricing-free-box {
		flex-direction: column;
		text-align: center;
		padding: 28px;
	}

	.free-plan-features {
		justify-content: center;
	}

	.free-box-cta .plan-cta {
		width: 100%;
	}
}

/* ==========================================================================
   Pay As You Go Section
   ========================================================================== */

.rcp-pricing-payg-section {
	padding: 40px 0;
	background: var(--pricing-gray-100);
}

.rcp-pricing-payg-box {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 40px;
	background: var(--pricing-white);
	border-radius: var(--pricing-radius);
	padding: 32px 40px;
	box-shadow: var(--pricing-card-shadow);
}

.payg-box-content {
	flex: 1;
}

.payg-plan-name {
	font-size: 1.5rem;
	font-weight: 700;
	margin: 0 0 8px;
	color: var(--pricing-black);
}

.payg-plan-price {
	display: flex;
	align-items: baseline;
	gap: 4px;
	margin-bottom: 12px;
}

.payg-price-amount {
	font-size: 2rem;
	font-weight: 700;
	color: var(--pricing-primary);
}

.payg-price-suffix {
	font-size: 1rem;
	color: var(--pricing-gray-600);
}

.payg-plan-description {
	font-size: 1rem;
	color: var(--pricing-gray-700);
	margin: 0 0 16px;
	max-width: 600px;
}

.payg-plan-features {
	display: flex;
	flex-wrap: wrap;
	gap: 12px 24px;
	list-style: none;
	padding: 0;
	margin: 0;
}

.payg-plan-features li {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 0.938rem;
	color: var(--pricing-gray-700);
}

.payg-plan-features .checkmark-icon {
	color: var(--pricing-primary);
	flex-shrink: 0;
}

.payg-box-cta {
	flex-shrink: 0;
}

.payg-box-cta .plan-cta {
	width: auto;
	padding: 14px 32px;
}

@media (max-width: 768px) {
	.rcp-pricing-payg-box {
		flex-direction: column;
		text-align: center;
		padding: 28px;
	}

	.payg-plan-price {
		justify-content: center;
	}

	.payg-plan-features {
		justify-content: center;
	}

	.payg-box-cta .plan-cta {
		width: 100%;
	}
}

/* ==========================================================================
   Comparison Grid
   ========================================================================== */

.rcp-pricing-comparison {
	padding: 60px 0;
	background: var(--pricing-gray-100);
}

.comparison-headline {
	font-size: 2rem;
	font-weight: 700;
	text-align: center;
	margin: 0 0 40px;
	color: var(--pricing-black);
}

.rcp-comparison-wrapper {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	border-radius: var(--pricing-radius);
	background: var(--pricing-white);
	box-shadow: var(--pricing-card-shadow);
}

.rcp-comparison-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.9375rem;
	min-width: 700px;
}

.rcp-comparison-table th,
.rcp-comparison-table td {
	padding: 16px 20px;
	text-align: center;
	border-bottom: 1px solid var(--pricing-gray-200);
}

.rcp-comparison-table thead th {
	background: var(--pricing-white);
	font-weight: 600;
	color: var(--pricing-black);
	position: sticky;
	top: 0;
	z-index: 10;
	border-bottom: 2px solid var(--pricing-gray-200);
}

.comparison-feature-col {
	text-align: left !important;
	min-width: 200px;
}

.comparison-plan-col {
	min-width: 120px;
}

.comparison-featured-col {
	background: rgba(69, 104, 220, 0.05);
}

.comparison-category-row td {
	background: var(--pricing-gray-100);
	font-weight: 600;
	text-align: left !important;
	font-size: 0.875rem;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	color: var(--pricing-gray-500);
	padding: 12px 20px;
}

.comparison-feature-row:last-child td {
	border-bottom: none;
}

.comparison-feature-name {
	text-align: left !important;
	color: var(--pricing-gray-700);
	display: flex;
	align-items: center;
	gap: 6px;
}

.feature-tooltip {
	color: var(--pricing-gray-500);
	cursor: help;
	display: inline-flex;
}

.feature-tooltip:hover {
	color: var(--pricing-primary);
}

.comparison-value {
	color: var(--pricing-gray-700);
}

.comparison-check {
	color: var(--pricing-success);
	display: inline-flex;
}

.comparison-x {
	color: var(--pricing-gray-300);
	display: inline-flex;
}

.comparison-dash {
	color: var(--pricing-gray-300);
}

.comparison-text {
	font-size: 0.875rem;
}

/* Mobile comparison: sticky first column */
@media (max-width: 768px) {
	.rcp-comparison-table .comparison-feature-col,
	.rcp-comparison-table .comparison-feature-name {
		position: sticky;
		left: 0;
		background: var(--pricing-white);
		z-index: 5;
	}

	.comparison-category-row td {
		position: sticky;
		left: 0;
		z-index: 5;
	}

	.rcp-comparison-table thead th:first-child {
		position: sticky;
		left: 0;
		z-index: 15;
	}
}

/* ==========================================================================
   Responsive Adjustments
   ========================================================================== */

@media (max-width: 768px) {
	.rcp-pricing-hero {
		padding: 40px 0 30px;
	}

	.rcp-pricing-headline {
		font-size: 2rem;
	}

	.rcp-pricing-subheadline {
		font-size: 1.0625rem;
	}

	.rcp-pricing-toggle {
		padding: 6px 16px;
		gap: 12px;
	}

	.toggle-label {
		font-size: 0.875rem;
	}

	.toggle-badge {
		font-size: 0.6875rem;
		padding: 2px 8px;
	}

	.rcp-pricing-plans {
		padding: 40px 0;
	}

	.rcp-pricing-card {
		padding: 28px 24px;
	}

	.price-amount {
		font-size: 2.5rem;
	}

	.comparison-headline {
		font-size: 1.5rem;
	}
}

@media (max-width: 480px) {
	.rcp-pricing-headline {
		font-size: 1.75rem;
	}

	.toggle-switch {
		width: 48px;
		height: 24px;
	}

	.toggle-slider::before {
		height: 18px;
		width: 18px;
	}

	.toggle-switch input:checked + .toggle-slider::before {
		transform: translateX(24px);
	}
}

/* ==========================================================================
   Print Styles
   ========================================================================== */

@media print {
	.rcp-pricing-toggle {
		display: none;
	}

	.rcp-pricing-card {
		break-inside: avoid;
		box-shadow: none;
		border: 1px solid #ccc;
	}

	.plan-cta {
		background: #fff;
		color: #000;
		border: 2px solid #000;
	}
}
