/**
 * RCP Modal Registration Styles
 *
 * Mobile-first responsive design for the multi-step registration modal.
 *
 * @package RCP_Modal_Registration
 */

/* CSS Variables */
:root {
	--rcp-modal-primary: #4568dc;
	--rcp-modal-primary-dark: #3551b5;
	--rcp-modal-secondary: #b06ab3;
	--rcp-modal-gradient: linear-gradient(135deg, #4568dc 0%, #b06ab3 100%);
	--rcp-modal-text: #333333;
	--rcp-modal-text-light: #666666;
	--rcp-modal-border: #dddddd;
	--rcp-modal-background: #ffffff;
	--rcp-modal-overlay: rgba(0, 0, 0, 0.6);
	--rcp-modal-error: #d63638;
	--rcp-modal-success: #00a32a;
	--rcp-modal-radius: 12px;
	--rcp-modal-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
}

/* Body scroll lock when modal is open */
body.rcp-modal-open {
	overflow: hidden;
}

/* Loading state */
.rcp-modal-loading {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 200px;
	color: var(--rcp-modal-text-light);
}

.rcp-modal-loading p {
	font-size: 16px;
}

/* Modal Overlay */
.rcp-modal-overlay {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: var(--rcp-modal-overlay);
	z-index: 999999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 20px;
	box-sizing: border-box;
}

/* Modal Container */
.rcp-modal-container {
	position: relative;
	width: 100%;
	max-width: 550px;
	max-height: 90vh;
	background: var(--rcp-modal-background);
	border-radius: var(--rcp-modal-radius);
	box-shadow: var(--rcp-modal-shadow);
	display: flex;
	flex-direction: column;
	overflow: hidden;
}

/* Close Button */
.rcp-modal-close {
	position: absolute;
	top: 15px;
	right: 15px;
	width: 36px;
	height: 36px;
	border: none;
	background: transparent;
	font-size: 28px;
	line-height: 1;
	color: var(--rcp-modal-text-light);
	cursor: pointer;
	z-index: 10;
	border-radius: 50%;
	transition: all 0.2s ease;
}

.rcp-modal-close:hover {
	background: #f0f0f0;
	color: var(--rcp-modal-text);
}

/* Modal Header */
.rcp-modal-header {
	padding: 30px 30px 20px;
	text-align: center;
	border-bottom: 1px solid var(--rcp-modal-border);
	flex-shrink: 0;
}

.rcp-modal-welcome {
	margin: 0 0 20px;
	font-size: 24px;
	font-weight: 600;
	color: var(--rcp-modal-text);
}

/* Progress Bar */
.rcp-modal-progress {
	margin-top: 15px;
}

.rcp-modal-progress-bar {
	height: 6px;
	background: #e0e0e0;
	border-radius: 3px;
	overflow: hidden;
	margin-bottom: 12px;
}

.rcp-modal-progress-fill {
	height: 100%;
	background: var(--rcp-modal-gradient);
	border-radius: 3px;
	transition: width 0.3s ease;
}

/* Step Indicators */
.rcp-modal-steps {
	display: flex;
	justify-content: space-between;
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.rcp-modal-step {
	color: #999999;
	font-weight: 500;
	transition: color 0.2s ease;
}

.rcp-modal-step.active {
	color: var(--rcp-modal-primary);
	font-weight: 600;
}

.rcp-modal-step.completed {
	color: var(--rcp-modal-secondary);
}

/* Modal Body */
.rcp-modal-body {
	padding: 25px 30px;
	overflow-y: auto;
	flex: 1;
}

/* Hide original RCP header in modal */
.rcp-modal-body .rcp_header,
.rcp-modal-body .rcp_login_link {
	display: none;
}

/* Hide group account fields (from rcp-group-accounts plugin) */
.rcp-modal-body .rcpga-group-fields,
.rcp-modal-body .rcpga-group-fieldset,
.rcp-modal-body .rcpga-group-per-seat-fields,
.rcp-modal-body #rcpga-group-name-wrap,
.rcp-modal-body #rcpga-group-description-wrap,
.rcp-modal-body #rcpga-group-number-seats-wrap,
.rcp-modal-body [id*="rcpga"],
.rcp-modal-body [class*="rcpga"] {
	display: none !important;
}

/* Hide hidden input fields - prevent showing as bordered boxes */
.rcp-modal-body input[type="hidden"] {
	display: none !important;
	border: none !important;
	padding: 0 !important;
	margin: 0 !important;
	width: 0 !important;
	height: 0 !important;
}

/* Hide any empty paragraph wrappers that may contain hidden fields */
.rcp-modal-body p:empty,
.rcp-modal-body div:empty {
	display: none !important;
}

/* Step Fieldsets */
.rcp-modal-step-fieldset {
	border: none;
	margin: 0;
	padding: 0;
}

.rcp-modal-step-title {
	font-size: 18px;
	font-weight: 600;
	color: var(--rcp-modal-text);
	margin: 0 0 20px;
	padding: 0;
}

/* Form Fields */
.rcp-modal-body p {
	margin: 0 0 18px;
}

.rcp-modal-body label {
	display: block;
	margin-bottom: 6px;
	font-size: 14px;
	font-weight: 500;
	color: var(--rcp-modal-text);
}

.rcp-modal-body input[type="text"],
.rcp-modal-body input[type="email"],
.rcp-modal-body input[type="password"],
.rcp-modal-body input[type="url"],
.rcp-modal-body select {
	width: 100%;
	padding: 12px 14px;
	font-size: 16px;
	border: 1px solid var(--rcp-modal-border);
	border-radius: 6px;
	background: var(--rcp-modal-background);
	color: var(--rcp-modal-text);
	box-sizing: border-box;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.rcp-modal-body input:focus,
.rcp-modal-body select:focus {
	outline: none;
	border-color: var(--rcp-modal-primary);
	box-shadow: 0 0 0 3px rgba(69, 104, 220, 0.15);
}

/* Required Field Indicator */
.rcp-required {
	color: var(--rcp-modal-error);
}

/* Select placeholder styling - ensure consistent black text */
.rcp-modal-body select option {
	color: var(--rcp-modal-text);
}

.rcp-modal-body select option[value=""] {
	color: var(--rcp-modal-text-light);
}

/* Field Error State */
.rcp-modal-field-error {
	border-color: var(--rcp-modal-error) !important;
}

.rcp-modal-error {
	display: block;
	color: var(--rcp-modal-error);
	font-size: 13px;
	margin-top: 5px;
}

/* Real-time Field Validation States */
.rcp-modal-field-checking {
	border-color: var(--rcp-modal-primary) !important;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24'%3E%3Cstyle%3E.spinner{animation:rotate 1s linear infinite;transform-origin:center}@keyframes rotate{100%{transform:rotate(360deg)}}%3C/style%3E%3Ccircle class='spinner' cx='12' cy='12' r='10' fill='none' stroke='%234568dc' stroke-width='2' stroke-dasharray='31.4' stroke-linecap='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 12px center;
	background-size: 18px;
	padding-right: 40px !important;
}

.rcp-modal-field-success {
	border-color: var(--rcp-modal-success) !important;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%2322c55e' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 12px center;
	background-size: 18px;
	padding-right: 40px !important;
}

.rcp-modal-field-error {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23dc2626' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cline x1='15' y1='9' x2='9' y2='15'/%3E%3Cline x1='9' y1='9' x2='15' y2='15'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 12px center;
	background-size: 18px;
	padding-right: 40px !important;
}

/* Validation Status Messages */
.rcp-modal-field-status {
	display: block;
	font-size: 13px;
	margin-top: 5px;
	font-weight: 500;
}

.rcp-modal-status-checking {
	color: var(--rcp-modal-primary);
}

.rcp-modal-status-success {
	color: var(--rcp-modal-success);
}

.rcp-modal-status-error {
	color: var(--rcp-modal-error);
}

/* Membership Levels (Step 4) */
#rcp_subscription_levels {
	list-style: none;
	margin: 0;
	padding: 0;
}

#rcp_subscription_levels li {
	margin-bottom: 12px;
	padding: 15px;
	border: 2px solid var(--rcp-modal-border);
	border-radius: 8px;
	transition: all 0.2s ease;
	cursor: pointer;
}

#rcp_subscription_levels li:hover {
	border-color: var(--rcp-modal-primary);
	background: rgba(69, 104, 220, 0.03);
}

#rcp_subscription_levels li:has(input:checked) {
	border-color: var(--rcp-modal-primary);
	background: rgba(69, 104, 220, 0.08);
}

#rcp_subscription_levels input[type="radio"] {
	margin-right: 10px;
	accent-color: var(--rcp-modal-primary);
}

#rcp_subscription_levels label {
	display: inline;
	cursor: pointer;
}

.rcp_subscription_level_name {
	font-weight: 600;
	color: var(--rcp-modal-text);
}

.rcp_price {
	color: var(--rcp-modal-primary);
	font-weight: 600;
}

.rcp_level_duration {
	color: var(--rcp-modal-text-light);
}

.rcp_level_description {
	margin-top: 8px;
	font-size: 13px;
	color: var(--rcp-modal-text-light);
	line-height: 1.5;
}

/* Order Summary */
/* Hide RCP's auto-inserted order summary OUTSIDE our designated containers */
.rcp-modal-body .rcp_registration_total {
	display: none !important;
}
/* But show it inside our order summary containers */
.rcp-modal-body .rcp-modal-order-summary .rcp_registration_total {
	display: block !important;
}

.rcp-modal-body .rcp-modal-order-summary {
	margin-top: 20px;
	padding-top: 20px;
	border-top: 1px solid var(--rcp-modal-border);
}

.rcp-modal-body .rcp-modal-order-summary:empty {
	display: none;
}

.rcp-modal-body .rcp-modal-order-summary .rcp_registration_total_details {
	width: 100%;
	border-collapse: collapse;
}

.rcp-modal-body .rcp-modal-order-summary .rcp_registration_total_details thead.membership-amount th {
	text-align: left;
	font-size: 16px;
	font-weight: 600;
	color: var(--rcp-modal-text);
	padding-bottom: 12px;
	border-bottom: 2px solid var(--rcp-modal-border);
}

.rcp-modal-body .rcp-modal-order-summary .rcp_registration_total_details tbody tr,
.rcp-modal-body .rcp-modal-order-summary .rcp_registration_total_details tfoot tr {
	display: flex;
	justify-content: space-between;
	padding: 10px 0;
	border-bottom: 1px solid #eee;
}

.rcp-modal-body .rcp-modal-order-summary .rcp_registration_total_details tbody tr:last-child {
	border-bottom: none;
}

.rcp-modal-body .rcp-modal-order-summary .rcp_registration_total_details td {
	padding: 0;
	font-size: 14px;
	color: var(--rcp-modal-text);
}

.rcp-modal-body .rcp-modal-order-summary .rcp_registration_total_details td:last-child {
	font-weight: 500;
	text-align: right;
}

.rcp-modal-body .rcp-modal-order-summary .rcp_registration_total_details .discounts-fees th {
	font-size: 13px;
	font-weight: 600;
	color: var(--rcp-modal-text-light);
	text-transform: uppercase;
	letter-spacing: 0.5px;
	padding-top: 12px;
	padding-bottom: 8px;
}

.rcp-modal-body .rcp-modal-order-summary .rcp_registration_total_details tfoot tr {
	border-bottom: none;
	padding-top: 12px;
}

.rcp-modal-body .rcp-modal-order-summary .rcp_registration_total_details tfoot .rcp-total td {
	font-size: 16px;
	font-weight: 600;
	color: var(--rcp-modal-primary);
}

.rcp-modal-body .rcp-modal-order-summary .rcp_registration_total_details tfoot .rcp-recurring-total td {
	font-size: 13px;
	color: var(--rcp-modal-text-light);
}

/* Discount Code Field */
.rcp_discounts_fieldset {
	margin-top: 20px;
	padding-top: 20px;
	border-top: 1px solid var(--rcp-modal-border);
}

.rcp_discount_code_field_wrap {
	display: flex;
	gap: 10px;
	align-items: stretch;
}

.rcp-modal-body .rcp_discount_code_field_wrap input,
.rcp-modal-body .rcp_discount_code_field_wrap input#rcp_discount_code {
	flex: 1;
	height: 46px !important;
	padding: 12px 14px !important;
	box-sizing: border-box !important;
	margin: 0 !important;
}

.rcp-modal-body .rcp_discount_code_field_wrap button,
.rcp-modal-body .rcp_discount_code_field_wrap button.rcp_button,
.rcp-modal-body #rcp_apply_discount {
	padding: 12px 20px !important;
	height: 46px !important;
	background: var(--rcp-modal-primary) !important;
	color: white !important;
	border: none !important;
	border-radius: 6px !important;
	font-size: 14px !important;
	font-weight: 500 !important;
	cursor: pointer;
	transition: background 0.2s ease;
	line-height: 1 !important;
	box-sizing: border-box !important;
	white-space: nowrap;
	flex-shrink: 0;
	margin: 0 !important;
	display: flex;
	align-items: center;
	justify-content: center;
}

.rcp-modal-body .rcp_discount_code_field_wrap button:hover,
.rcp-modal-body #rcp_apply_discount:hover {
	background: var(--rcp-modal-primary-dark) !important;
}

.rcp_discount_valid {
	color: var(--rcp-modal-success);
	font-weight: 500;
}

.rcp_discount_invalid {
	color: var(--rcp-modal-error);
	font-weight: 500;
}

/* Payment Gateways (Step 5) */
.rcp-gateway-legend {
	font-weight: 600;
	margin-bottom: 12px;
	color: var(--rcp-modal-text);
}

#rcp_payment_gateways {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.rcp_gateway_option_label {
	display: flex !important;
	align-items: center;
	padding: 12px 15px;
	border: 2px solid var(--rcp-modal-border);
	border-radius: 8px;
	cursor: pointer;
	transition: all 0.2s ease;
}

.rcp_gateway_option_label:hover {
	border-color: var(--rcp-modal-primary);
}

.rcp_gateway_option_label:has(input:checked) {
	border-color: var(--rcp-modal-primary);
	background: rgba(69, 104, 220, 0.08);
}

.rcp_gateway_option_input {
	margin-right: 10px;
	accent-color: var(--rcp-modal-primary);
}

/* Registration Error Messages */
.rcp-modal-errors,
.rcp-modal-payment-error {
	background-color: #fef2f2;
	border: 1px solid #fecaca;
	border-radius: 8px;
	padding: 12px 16px;
	margin-bottom: 20px;
}

.rcp-modal-errors .rcp_message.error,
.rcp-modal-payment-error .rcp_message.error,
.rcp-modal-errors .rcp_message,
.rcp-modal-payment-error .rcp_message {
	background: transparent;
	border: none;
	padding: 0;
	margin: 0;
}

.rcp-modal-errors .rcp_error,
.rcp-modal-payment-error .rcp_error,
.rcp-modal-errors p,
.rcp-modal-payment-error p {
	color: #dc2626;
	font-size: 14px;
	margin: 0;
	padding: 4px 0;
}

.rcp-modal-errors .rcp_error::before,
.rcp-modal-payment-error .rcp_error::before {
	content: "⚠ ";
}

/* Stripe card element errors */
#rcp-card-element-errors {
	margin-top: 10px;
}

#rcp-card-element-errors .rcp_message.error {
	background-color: #fef2f2;
	border: 1px solid #fecaca;
	border-radius: 8px;
	padding: 12px 16px;
}

#rcp-card-element-errors .rcp_error {
	color: #dc2626;
	font-size: 14px;
	margin: 0;
}

/* Stripe Card Fields */
#rcp_gateway_extra_fields {
	margin-top: 20px;
	padding-top: 20px;
	border-top: 1px solid var(--rcp-modal-border);
}

.rcp-modal-body .rcp_card_fieldset {
	border: none;
	margin: 0;
	padding: 0;
}

.rcp-modal-body #rcp_card_name_wrap,
.rcp-modal-body #rcp_card_wrap {
	margin-bottom: 18px;
}

.rcp-modal-body #rcp_card_name_wrap label,
.rcp-modal-body #rcp_card_wrap label {
	display: block;
	margin-bottom: 6px;
	font-size: 14px;
	font-weight: 500;
	color: var(--rcp-modal-text);
}

.rcp-modal-body .rcp_card_name,
.rcp-modal-body #rcp-card-name {
	width: 100%;
	padding: 12px 14px;
	font-size: 16px;
	border: 1px solid var(--rcp-modal-border);
	border-radius: 6px;
	background: var(--rcp-modal-background);
	color: var(--rcp-modal-text);
	box-sizing: border-box;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.rcp-modal-body .rcp_card_name:focus,
.rcp-modal-body #rcp-card-name:focus {
	outline: none;
	border-color: var(--rcp-modal-primary);
	box-shadow: 0 0 0 3px rgba(69, 104, 220, 0.15);
}

/* Stripe Card Element container */
.rcp-modal-body #rcp-card-element {
	padding: 12px 14px;
	border: 1px solid var(--rcp-modal-border);
	border-radius: 6px;
	background: var(--rcp-modal-background);
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.rcp-modal-body #rcp-card-element.StripeElement--focus {
	border-color: var(--rcp-modal-primary);
	box-shadow: 0 0 0 3px rgba(69, 104, 220, 0.15);
}

.rcp-modal-body #rcp-card-element.StripeElement--invalid {
	border-color: var(--rcp-modal-error);
}

/* Stripe error messages */
.rcp-modal-body #rcp-card-element-errors {
	color: var(--rcp-modal-error);
	font-size: 13px;
	margin-top: 8px;
}

/* Payment Request Button (Apple Pay) */
#rcp-payment-request-wrapper {
	margin-top: 20px;
	text-align: center;
}

.rcp-payment-request-divider {
	color: var(--rcp-modal-text-light);
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 1px;
	margin-bottom: 15px;
}

#rcp-payment-request-button {
	max-width: 300px;
	margin: 0 auto;
}

/* Terms & Privacy Checkboxes */
.rcp_agree_to_terms_fieldset,
.rcp_agree_to_privacy_policy_fieldset {
	margin-top: 20px;
}

.rcp_agree_to_terms_fieldset p,
.rcp_agree_to_privacy_policy_fieldset p {
	display: flex;
	align-items: flex-start;
}

.rcp_agree_to_terms_fieldset input[type="checkbox"],
.rcp_agree_to_privacy_policy_fieldset input[type="checkbox"] {
	margin-right: 10px;
	margin-top: 3px;
	accent-color: var(--rcp-modal-primary);
}

.rcp_agree_to_terms_fieldset label,
.rcp_agree_to_privacy_policy_fieldset label {
	display: inline;
	font-size: 14px;
}

.rcp_agree_to_terms_fieldset a,
.rcp_agree_to_privacy_policy_fieldset a {
	color: var(--rcp-modal-primary);
	text-decoration: none;
}

.rcp_agree_to_terms_fieldset a:hover,
.rcp_agree_to_privacy_policy_fieldset a:hover {
	text-decoration: underline;
}

/* Hide original RCP submit button in modal */
.rcp-modal-submit-wrap {
	display: none;
}

/* Modal Footer */
.rcp-modal-footer {
	padding: 20px 30px;
	border-top: 1px solid var(--rcp-modal-border);
	display: flex;
	justify-content: space-between;
	gap: 15px;
	flex-shrink: 0;
	background: #fafafa;
}

/* Navigation Buttons */
.rcp-modal-back,
.rcp-modal-next,
.rcp-modal-submit {
	padding: 14px 28px;
	font-size: 16px;
	font-weight: 600;
	border-radius: 8px;
	cursor: pointer;
	transition: all 0.2s ease;
	flex: 1;
}

.rcp-modal-back {
	background: transparent;
	border: 2px solid var(--rcp-modal-border);
	color: var(--rcp-modal-text-light);
}

.rcp-modal-back:hover {
	border-color: var(--rcp-modal-text-light);
	color: var(--rcp-modal-text);
}

.rcp-modal-next,
.rcp-modal-submit {
	background: var(--rcp-modal-gradient);
	border: none;
	color: white;
}

.rcp-modal-next:hover,
.rcp-modal-submit:hover {
	opacity: 0.9;
	transform: translateY(-1px);
}

/* RCP Error Messages in Modal */
.rcp-modal-body .rcp_message {
	padding: 12px 15px;
	margin-bottom: 20px;
	border-radius: 6px;
	font-size: 14px;
}

.rcp-modal-body .rcp_error {
	background: rgba(214, 54, 56, 0.1);
	border: 1px solid var(--rcp-modal-error);
	color: var(--rcp-modal-error);
}

.rcp-modal-body .rcp_success {
	background: rgba(0, 163, 42, 0.1);
	border: 1px solid var(--rcp-modal-success);
	color: var(--rcp-modal-success);
}

/* Responsive Styles */

/* Tablet and below */
@media (max-width: 768px) {
	.rcp-modal-overlay {
		padding: 15px;
	}

	.rcp-modal-container {
		max-height: 95vh;
	}

	.rcp-modal-header {
		padding: 25px 20px 15px;
	}

	.rcp-modal-welcome {
		font-size: 20px;
	}

	.rcp-modal-steps {
		display: none;
	}

	.rcp-modal-body {
		padding: 20px;
	}

	.rcp-modal-footer {
		padding: 15px 20px;
		flex-direction: column;
	}

	.rcp-modal-back,
	.rcp-modal-next,
	.rcp-modal-submit {
		width: 100%;
	}

	.rcp-modal-back {
		order: 2;
	}

	.rcp-modal-next,
	.rcp-modal-submit {
		order: 1;
	}
}

/* Small mobile */
@media (max-width: 480px) {
	.rcp-modal-overlay {
		padding: 10px;
	}

	.rcp-modal-header {
		padding: 20px 15px 12px;
	}

	.rcp-modal-welcome {
		font-size: 18px;
		padding-right: 30px;
	}

	.rcp-modal-close {
		top: 10px;
		right: 10px;
		width: 32px;
		height: 32px;
		font-size: 24px;
	}

	.rcp-modal-body {
		padding: 15px;
	}

	.rcp-modal-body input[type="text"],
	.rcp-modal-body input[type="email"],
	.rcp-modal-body input[type="password"],
	.rcp-modal-body select {
		padding: 10px 12px;
		font-size: 16px; /* Prevents zoom on iOS */
	}

	.rcp_discount_code_field_wrap {
		flex-direction: column;
	}

	.rcp_discount_code_field_wrap button {
		width: 100%;
	}

	#rcp_subscription_levels li {
		padding: 12px;
	}

	.rcp-modal-footer {
		padding: 12px 15px;
	}

	.rcp-modal-back,
	.rcp-modal-next,
	.rcp-modal-submit {
		padding: 12px 20px;
		font-size: 15px;
	}
}

/* Fallback page styles (non-modal) */
.rcp-modal-form-wrapper:not(.rcp-modal-body .rcp-modal-form-wrapper) {
	max-width: 550px;
	margin: 40px auto;
	padding: 30px;
	background: var(--rcp-modal-background);
	border-radius: var(--rcp-modal-radius);
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

.rcp-modal-form-wrapper:not(.rcp-modal-body .rcp-modal-form-wrapper) .rcp-modal-step-fieldset {
	display: block !important;
	margin-bottom: 30px;
	padding-bottom: 30px;
	border-bottom: 1px solid var(--rcp-modal-border);
}

.rcp-modal-form-wrapper:not(.rcp-modal-body .rcp-modal-form-wrapper) .rcp-modal-step-fieldset:last-of-type {
	border-bottom: none;
	margin-bottom: 0;
	padding-bottom: 0;
}

.rcp-modal-form-wrapper:not(.rcp-modal-body .rcp-modal-form-wrapper) .rcp-modal-submit-wrap {
	display: block;
}

.rcp-modal-form-wrapper:not(.rcp-modal-body .rcp-modal-form-wrapper) #rcp_submit {
	display: block !important;
	width: 100%;
	padding: 14px 28px;
	font-size: 16px;
	font-weight: 600;
	background: var(--rcp-modal-gradient);
	border: none;
	border-radius: 8px;
	color: white;
	cursor: pointer;
	transition: all 0.2s ease;
}

.rcp-modal-form-wrapper:not(.rcp-modal-body .rcp-modal-form-wrapper) #rcp_submit:hover {
	opacity: 0.9;
}

/* ============================================
   Password Strength Meter
   ============================================ */

.rcp-password-strength-meter {
	display: block;
	width: 100%;
	height: 4px;
	background: var(--rcp-modal-border);
	border-radius: 2px;
	margin-top: 8px;
	overflow: hidden;
}

.rcp-password-strength-bar {
	display: block;
	height: 100%;
	width: 0;
	border-radius: 2px;
	transition: width 0.3s ease, background-color 0.3s ease;
}

.rcp-password-strength-bar.weak {
	background-color: #dc3545;
}

.rcp-password-strength-bar.medium {
	background-color: #ffc107;
}

.rcp-password-strength-bar.strong {
	background-color: #28a745;
}

.rcp-password-strength-bar.very-strong {
	background-color: #20c997;
}

.rcp-password-strength-text {
	display: block;
	font-size: 12px;
	margin-top: 4px;
	min-height: 16px;
}

.rcp-password-strength-text.weak {
	color: #dc3545;
}

.rcp-password-strength-text.medium {
	color: #856404;
}

.rcp-password-strength-text.strong {
	color: #28a745;
}

.rcp-password-strength-text.very-strong {
	color: #20c997;
}

/* ============================================
   Pricing Announcement Banner
   ============================================ */

.rcp-modal-announcement {
	background: linear-gradient(135deg, #f8f9ff 0%, #fff5f8 100%);
	border: 1px solid #e0e4f0;
	border-left: 4px solid var(--rcp-modal-primary);
	border-radius: 8px;
	padding: 20px;
	margin-bottom: 24px;
	font-size: 14px;
	line-height: 1.6;
}

.rcp-modal-announcement-title {
	font-size: 16px;
	font-weight: 700;
	color: var(--rcp-modal-primary);
	margin: 0 0 16px 0;
	padding: 0;
	line-height: 1.4;
}

.rcp-modal-announcement h3 {
	font-size: 14px;
	font-weight: 600;
	color: var(--rcp-modal-text);
	margin: 16px 0 8px 0;
	padding: 0;
}

.rcp-modal-announcement h3:first-of-type {
	margin-top: 0;
}

.rcp-modal-announcement p {
	margin: 0 0 12px 0;
	color: var(--rcp-modal-text);
	font-size: 13px;
}

.rcp-modal-announcement p:last-child {
	margin-bottom: 0;
}

.rcp-modal-announcement-list {
	margin: 12px 0;
	padding-left: 0;
	list-style: none;
}

.rcp-modal-announcement-list li {
	position: relative;
	padding-left: 16px;
	margin-bottom: 8px;
	font-size: 13px;
	color: var(--rcp-modal-text);
}

.rcp-modal-announcement-list li:last-child {
	margin-bottom: 0;
}

.rcp-modal-announcement-list li::before {
	content: "•";
	position: absolute;
	left: 0;
	color: var(--rcp-modal-primary);
	font-weight: bold;
}

.rcp-modal-announcement-list li strong {
	color: var(--rcp-modal-text);
}

/* Responsive adjustments for announcement */
@media (max-width: 480px) {
	.rcp-modal-announcement {
		padding: 16px;
		margin-bottom: 20px;
	}

	.rcp-modal-announcement-title {
		font-size: 15px;
	}

	.rcp-modal-announcement h3 {
		font-size: 13px;
	}

	.rcp-modal-announcement p,
	.rcp-modal-announcement-list li {
		font-size: 12px;
	}
}
