/**
 * WooCommerce Custom Styles for Download Template
 * Matches EDD download template styling
 */

/* Product page layout */
.single-product.custom-download-template .blog-wrapper {
	max-width: 100% !important;
	margin: 0 auto;
	padding: 0 20px;
}

/* Override container constraint for full-width banner */
body.single-product.woocommerce {
	overflow-x: hidden;
}

/* Download header styling - ALWAYS Full width banner at all screen sizes */
#download-header.hero-banner,
.woocommerce #download-header.hero-banner,
body.single-product #download-header.hero-banner {
	margin-bottom: 40px;
	width: 100vw !important;
	max-width: 100vw !important;
	position: relative;
	left: 50% !important;
	margin-left: -50vw !important;
	margin-right: -50vw !important;
	box-sizing: border-box;
	border-radius: 0 !important;
}

/* Also target with custom-download-template class for compatibility */
.single-product.custom-download-template .download-header,
.single-product.custom-download-template #download-header,
.single-product.custom-download-template #download-header.hero-banner {
	margin-bottom: 40px;
	width: 100vw !important;
	max-width: 100vw !important;
	position: relative;
	left: 50% !important;
	margin-left: -50vw !important;
	margin-right: -50vw !important;
	box-sizing: border-box;
}

.single-product.custom-download-template .hero-banner,
.single-product.custom-download-template #download-header.hero-banner {
	position: relative;
	width: 100vw !important;
	max-width: 100vw !important;
	height: 352px;
	overflow: hidden;
	border-radius: 0 !important; /* Full width - no rounded corners */
	padding: 0 !important;
}

.single-product.custom-download-template .bg-image-container {
	position: relative;
	width: 100%;
	height: 100%;
}

.single-product.custom-download-template .bg-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
}

/* Download content layout */
.single-product.custom-download-template .download-content {
	margin-bottom: 60px;
}

/* Main download container */
.single-product.custom-download-template .download-main {
	position: relative;
	background-color: #ffffff;
	margin-top: -240px;
	margin-bottom: 32px;
	padding: 48px 40px;
	border-radius: 4px;
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
	box-sizing: border-box;
}

.single-product.custom-download-template .download-top {
	overflow: auto;
	min-height: 240px;
	display: flex;
	flex-flow: row nowrap;
	justify-content: space-between;
	align-items: flex-start;
	gap: 60px;
	padding: 20px 0 40px 0;
}

@media all and (max-width: 767px) {
	.single-product.custom-download-template .download-top {
		flex-flow: column nowrap;
		justify-content: flex-start;
		align-items: flex-start;
		gap: 30px;
		padding: 16px 0 32px 0;
	}
}

.single-product.custom-download-template .download-title {
	flex: 1;
	min-width: 300px;
}

.single-product.custom-download-template .download-image {
	flex: 0 0 400px;
	height: 100%;
	max-width: 400px;
}

.single-product.custom-download-template .download-image img {
	width: 100%;
	height: auto;
	object-fit: contain;
	object-position: right center;
	box-shadow: 0 0 16px 0 rgba(0, 0, 0, 0.1);
	border-radius: 4px;
}

/* Typography */
.single-product.custom-download-template .page-title {
	font-size: 2.25rem;
	font-weight: 700;
	margin-bottom: 16px;
	color: #333;
	line-height: 1.2;
}

.single-product.custom-download-template .page-subtitle {
	font-size: 1.25rem;
	font-weight: 400;
	margin-bottom: 8px;
	color: #666;
	line-height: 1.6;
}

/* Product Price */
.single-product.custom-download-template .product-price {
	margin: 20px 0 24px 0;
}

.single-product.custom-download-template .product-price .price {
	font-size: 1.5rem;
	font-weight: 600;
	color: #208490;
}

/* Breadcrumbs */
.single-product.custom-download-template .product-breadcrumbs {
	margin-bottom: 20px;
}

.single-product.custom-download-template .product-breadcrumbs .woocommerce-breadcrumb {
	font-size: 0.9rem;
	color: #666;
}

.single-product.custom-download-template .product-breadcrumbs .woocommerce-breadcrumb a {
	color: #208490;
	text-decoration: none;
}

.single-product.custom-download-template .product-breadcrumbs .woocommerce-breadcrumb a:hover {
	text-decoration: underline;
}

/* Button styling */
.single-product.custom-download-template .download-btn,
.single-product.custom-download-template .woocommerce-direct-download-button .download-btn,
.single-product.custom-download-template .single_add_to_cart_button {
	display: inline-block;
	padding: 8px 16px;
	border-radius: 32px;
	font-size: 14px;
	font-weight: 700;
	background-color: #0e3c52 !important;
	border-color: #0e3c52;
	border-style: solid;
	border-width: 2px;
	color: #fff;
	text-align: center;
	min-width: 160px;
	text-decoration: none;
	transition: all 0.3s ease;
	cursor: pointer;
	margin-top: 16px;
}

.single-product.custom-download-template .download-btn:hover,
.single-product.custom-download-template .woocommerce-direct-download-button .download-btn:hover,
.single-product.custom-download-template .single_add_to_cart_button:hover {
	background-color: #fff !important;
	color: #0e3c52;
}

.single-product.custom-download-template .direct-download-btn {
	background-color: #28a745 !important;
	border-color: #28a745;
}

.single-product.custom-download-template .direct-download-btn:hover {
	background-color: #ffffff !important;
	color: #28a745;
}

.single-product.custom-download-template .purchase-btn {
	background-color: #dc3545 !important;
	border-color: #dc3545;
}

.single-product.custom-download-template .purchase-btn:hover {
	background-color: #ffffff !important;
	color: #dc3545;
}

.single-product.custom-download-template .download-btn.disabled,
.single-product.custom-download-template .single_add_to_cart_button.disabled {
	background-color: #616e7c !important;
	pointer-events: none;
}

/* Add to cart form styling */
.single-product.custom-download-template .cart {
	margin-bottom: 20px;
}

.single-product.custom-download-template .quantity {
	margin-bottom: 15px;
}

.single-product.custom-download-template .quantity input {
	padding: 8px 12px;
	border: 1px solid #ddd;
	border-radius: 4px;
	width: 80px;
}

/* Download bottom section */
.single-product.custom-download-template .download-bottom {
	margin-top: 40px;
}

.single-product.custom-download-template .download-summary {
	padding: 32px 42px;
	margin: 0 -32px;
	background-color: #d9e2ec;
	width: calc(100% + 64px);
	margin-bottom: 40px;
	line-height: 1.6;
}

.single-product.custom-download-template .download-summary h2 {
	font-size: 1.8rem;
	font-weight: 600;
	margin-bottom: 20px;
	color: #333;
}

/* Sponsor section */
.single-product.custom-download-template .sponsor-section {
	margin-bottom: 40px;
	padding: 30px;
	background-color: #f8f9fa;
	border-radius: 8px;
}

.single-product.custom-download-template .event-partners-header h2 {
	font-size: 1.5rem;
	font-weight: 600;
	margin-bottom: 20px;
	color: #333;
}

.single-product.custom-download-template .company-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	align-items: center;
}

/* Download highlights */
.single-product.custom-download-template .download-highlights {
	margin-top: 48px;
	margin-bottom: 40px;
	padding: 30px;
	background-color: #e8f4f8;
	border-radius: 8px;
	border-left: 4px solid #208490;
}

/* Modal styling */
.single-product.custom-download-template .download-modal {
	background: #ffffff;
	padding: 30px;
	border-radius: 8px;
	max-width: 500px;
	margin: 0 auto;
}

.single-product.custom-download-template .modal-content h3 {
	font-size: 1.5rem;
	font-weight: 600;
	margin-bottom: 15px;
	color: #333;
}

.single-product.custom-download-template .modal-content p {
	margin-bottom: 20px;
	color: #666;
	line-height: 1.5;
}

.single-product.custom-download-template .modal-actions {
	text-align: center;
}

.single-product.custom-download-template .modal-actions .button {
	display: inline-block;
	padding: 10px 20px;
	background-color: #208490;
	color: #ffffff;
	text-decoration: none;
	border: 2px solid #208490;
	border-radius: 6px;
	font-weight: 600;
	transition: all 0.3s ease;
}

.single-product.custom-download-template .modal-actions .button:hover {
	background-color: #ffffff;
	color: #208490;
}

/* Free download styling */
.single-product.custom-download-template .has-free-download .free-download-button {
	background-color: #28a745 !important;
	border-color: #28a745;
	margin-bottom: 10px;
}

.single-product.custom-download-template .has-free-download .free-download-button:hover {
	background-color: #ffffff !important;
	color: #28a745;
}

.single-product.custom-download-template .free-download-note {
	font-size: 0.9rem;
	color: #666;
	font-style: italic;
}

/* Back button styling */
.single-product.custom-download-template .back-btn {
	position: absolute;
	top: -64px;
	left: 0;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 16px;
	background-color: #ffffff;
	color: #208490;
	border: 2px solid #208490;
	border-radius: 6px;
	text-decoration: none;
	font-weight: 500;
	font-size: 0.9rem;
	transition: all 0.3s ease;
}

.single-product.custom-download-template .back-btn:hover {
	background-color: #208490;
	color: #ffffff;
}

.single-product.custom-download-template .back-btn.small-btn {
	padding: 6px 12px;
	font-size: 0.8rem;
}

.single-product.custom-download-template .arival-btn.small-btn.has-arrow.back-btn {
	padding: 8px 16px 8px 48px;
}

.single-product.custom-download-template .arival-btn.small-btn.has-arrow.back-btn:hover {
	background-color: #208490 !important;
}

.single-product.custom-download-template .arival-btn.small-btn.has-arrow.back-btn svg {
	right: unset;
	left: 12px;
	transform: rotate(180deg);
}

/* Responsive design */
@media (max-width: 768px) {
	.single-product.custom-download-template .download-top {
		flex-direction: column;
		gap: 20px;
	}
	
	.single-product.custom-download-template .download-title,
	.single-product.custom-download-template .download-image {
		flex: none;
		width: 100%;
	}
	
	.single-product.custom-download-template .page-title {
		font-size: 1.75rem;
	}
	
	.single-product.custom-download-template .hero-banner,
	.single-product.custom-download-template #download-header.hero-banner {
		height: 200px;
	}
	
	.single-product.custom-download-template .download-main {
		margin-top: -120px;
		padding: 24px 16px;
	}
	
	.single-product.custom-download-template .download-summary {
		padding: 24px 20px;
		margin: 0 -16px;
		width: calc(100% + 32px);
	}
}

/* Force full width banner at ALL screen sizes - tablet and up */
@media (min-width: 769px) {
	.single-product.custom-download-template .download-header,
	.single-product.custom-download-template #download-header,
	.single-product.custom-download-template .hero-banner,
	.single-product.custom-download-template #download-header.hero-banner {
		margin-left: calc(50% - 50vw) !important;
		margin-right: calc(50% - 50vw) !important;
		width: 100vw !important;
		max-width: 100vw !important;
		border-radius: 0 !important;
	}
}

/* Hide default WooCommerce elements for custom template (non-subscription products only) */
.single-product.custom-download-template .woocommerce-product-gallery,
.single-product.custom-download-template .entry-summary,
.single-product.custom-download-template .woocommerce-tabs,
.single-product.custom-download-template .upsells,
.single-product.custom-download-template .related {
	display: none;
}

/* ========================================
   Custom Checkout Fields Styling
   ======================================== */

/* Section Headings (outside boxes) */
.woocommerce-section-heading,
.woocommerce-billing-fields > h3,
.woocommerce-additional-fields > h3,
.woocommerce-shipping-fields > h3 {
	color: #2d3748 !important;
	font-size: 1.3em !important;
	font-weight: 600 !important;
	border-bottom: none !important;
	padding-bottom: 0 !important;
	margin-bottom: 20px !important;
	margin-top: 30px !important;
	text-transform: none !important;
	letter-spacing: normal !important;
}

/* Company Information heading - add extra top spacing */
.woocommerce-section-heading {
	margin-top: 40px !important;
}

/* Additional Information - consistent spacing */
.woocommerce-additional-fields > h3 {
	margin-top: 30px !important;
}

/* make stripe elements cover 2 columns */

#wc-stripe-express-checkout-element,#wc-stripe-express-checkout__order-attribution-inputs, #wc-stripe-express-checkout-button-separator {
	grid-column: span 2;
}

/* Hide Stripe attribution elements */
.wc-stripe-elements-field + p[style*="font-size: 10px"],
p[style*="stripe.com/docs/disputes/prevention/advanced-fraud-detection"] {
	display: none !important;
}

/* Company Information Section */
.woocommerce-company-info {
	background-color: #ffffff;
	padding: 30px;
	border-radius: 8px;
	border: 1px solid #e2e8f0;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
	margin-bottom: 30px;
	clear: both;
	width: 100%;
	box-sizing: border-box;
}

/* Flexbox row container for two-column layout */
.woocommerce-company-info .form-row-wrapper {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	margin-bottom: 20px;
}

.woocommerce-company-info .form-row-wrapper:last-child {
	margin-bottom: 0;
}

.woocommerce-company-info .form-row {
	margin-bottom: 0 !important;
	flex: 1 1 100%;
	min-width: 0;
	box-sizing: border-box;
}

/* Two column layout for some fields */
.woocommerce-company-info .form-row.form-row-first,
.woocommerce-company-info .form-row.form-row-last {
	flex: 1 1 calc(50% - 10px);
	min-width: 250px;
}

.woocommerce-company-info .form-row.form-row-wide {
	flex: 1 1 100%;
	width: 100%;
}

/* Label styling */
.woocommerce-company-info label {
	display: block;
	margin-bottom: 8px;
	font-weight: 600;
	color: #4a5568;
	font-size: 0.95em;
}

.woocommerce-company-info label .required {
	color: #dc3545;
	font-weight: 700;
	margin-left: 2px;
}

.woocommerce-company-info label abbr.required {
	color: #dc3545;
	text-decoration: none;
	border: 0;
}

/* Input and select styling */
.woocommerce-company-info input[type="text"],
.woocommerce-company-info select {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid #e2e8f0;
	border-radius: 6px;
	font-size: 1em;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	box-sizing: border-box;
	color: #4a5568;
}

.woocommerce-company-info input[type="text"]:focus,
.woocommerce-company-info select:focus {
	border-color: #208490;
	outline: none;
	box-shadow: 0 0 0 3px rgba(32, 132, 144, 0.15);
}

/* Select2 container within company info section */
.woocommerce-company-info .select2-container {
	width: 100% !important;
	max-width: 100%;
}

.woocommerce-company-info .select2-container .select2-selection {
	height: auto;
	min-height: 44px;
	border: 1px solid #ddd;
	border-radius: 4px;
}

.woocommerce-company-info .select2-container .select2-selection--single {
	height: 44px;
}

.woocommerce-company-info .select2-container .select2-selection__rendered {
	line-height: 44px;
	padding-left: 12px;
	padding-right: 12px;
}

.woocommerce-company-info .select2-container .select2-selection--multiple .select2-selection__rendered {
	padding: 4px 8px;
	line-height: normal;
}

.woocommerce-company-info .select2-container--default .select2-selection--multiple .select2-selection__choice {
	background-color: #208490;
	border: 1px solid #208490;
	color: #fff;
	margin: 4px 4px 4px 0;
	padding: 4px 10px;
	border-radius: 3px;
}

.woocommerce-company-info .select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
	color: #fff;
	margin-right: 8px;
}

.woocommerce-company-info .select2-container--default .select2-selection--multiple .select2-selection__choice__remove:hover {
	color: #fff;
	opacity: 0.8;
}

/* Radio button styling for operator type */
.woocommerce-company-info .radio-option {
	display: flex;
	align-items: flex-start;
	margin-bottom: 16px;
	padding: 16px;
	background-color: #fff;
	border: 2px solid #e0e0e0;
	border-radius: 6px;
	transition: all 0.2s ease;
	cursor: pointer;
}

.woocommerce-company-info .radio-option:last-child {
	margin-bottom: 0;
}

.woocommerce-company-info .radio-option:hover {
	border-color: #208490;
	background-color: #f8fcfd;
}

.woocommerce-company-info .radio-option input[type="radio"] {
	margin-right: 14px;
	margin-top: 2px;
	flex-shrink: 0;
	width: 18px;
	height: 18px;
	cursor: pointer;
}

.woocommerce-company-info .radio-option input[type="radio"]:checked {
	accent-color: #208490;
}

.woocommerce-company-info .radio-option:has(input[type="radio"]:checked) {
	border-color: #208490;
	background-color: #e8f4f8;
	border-width: 2px;
}

/* Radio option content container */
.woocommerce-company-info .radio-option-content {
	display: flex;
	flex-direction: column;
	gap: 6px;
	flex: 1;
}

/* Radio option title (bold) */
.woocommerce-company-info .radio-option-title {
	display: block;
	font-weight: 700;
	font-size: 1em;
	color: #333;
	line-height: 1.4;
}

/* Radio option description (smaller text) */
.woocommerce-company-info .radio-option-description {
	display: block;
	font-weight: 400;
	font-size: 0.875em;
	color: #666;
	line-height: 1.5;
}

/* Operator type field specific styling */
#rcp_company_op_type_field .woocommerce-input-wrapper {
	display: block;
}

#rcp_company_op_type_field label:not([class*="required"]) {
	font-weight: 400;
	margin-bottom: 0;
}

/* Ensure proper sizing for all elements */
.woocommerce-company-info * {
	box-sizing: border-box;
}

/* ========================================
   All Checkout Sections Consistent Styling
   ======================================== */

/* Style all field wrapper sections consistently */
.woocommerce-billing-fields__field-wrapper,
.woocommerce-shipping-fields__field-wrapper,
.woocommerce-additional-fields__field-wrapper {
	background-color: #ffffff;
	padding: 30px;
	border-radius: 8px;
	border: 1px solid #e2e8f0;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
	box-sizing: border-box;
	margin-bottom: 0;
}

/* ========================================
   Right Side Sections (Order Summary & Payment)
   ======================================== */

/* Order Review Heading */
#order_review_heading {
	color: #2d3748 !important;
	font-size: 1.3em !important;
	font-weight: 600 !important;
	border-bottom: none !important;
	padding-bottom: 0 !important;
	margin-bottom: 20px !important;
	margin-top: 0 !important;
	text-transform: none !important;
	letter-spacing: normal !important;
}

/* Order Review Table Container */
#order_review,
.woocommerce-checkout-review-order {
	background-color: #ffffff;
	padding: 30px;
	border-radius: 8px;
	border: 1px solid #e2e8f0;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
	box-sizing: border-box;
}

/* Order table styling */
.woocommerce-checkout-review-order-table {
	background-color: #fff;
	border-radius: 4px;
	margin-bottom: 20px;
}

/* Payment Section */
#payment {
	background-color: #ffffff;
	padding: 30px;
	border-radius: 8px;
	border: 1px solid #e2e8f0;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
	box-sizing: border-box;
	margin-top: 30px;
}

/* Payment Section Heading - make it bolder and bigger */
#payment .wc_payment_methods {
	margin-top: 0;
}

#payment::before {
	content: "Payment method";
	display: block;
	font-size: 1.15em;
	font-weight: 600;
	color: #2d3748;
	margin-bottom: 20px;
	padding-bottom: 0;
	border-bottom: none;
}

/* Payment method labels */
#payment .wc_payment_method label {
	font-weight: 600;
	color: #4a5568;
}

/* Place order button styling */
#payment #place_order {
	background-color: #208490 !important;
	color: #fff !important;
	border: none !important;
	padding: 14px 30px !important;
	font-size: 1em !important;
	font-weight: 600 !important;
	border-radius: 32px !important;
	width: 100%;
	transition: all 0.2s ease !important;
	cursor: pointer;
}

#payment #place_order:hover {
	background-color: #1a6f7a !important;
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(32, 132, 144, 0.2);
}

/* Consistent input field styling across all sections - consolidated for efficiency */
form.checkout input[type="text"],
form.checkout input[type="email"],
form.checkout input[type="tel"],
form.checkout input.input-text,
form.checkout select,
form.checkout textarea {
	padding: 10px 12px !important;
	border: 1px solid #e2e8f0 !important;
	border-radius: 6px !important;
	font-size: 1em !important;
	transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
	box-sizing: border-box !important;
	height: auto !important;
	line-height: 1.5 !important;
	color: #4a5568 !important;
}

/* Consistent focus states across all sections - consolidated for efficiency */
form.checkout input[type="text"]:focus,
form.checkout input[type="email"]:focus,
form.checkout input[type="tel"]:focus,
form.checkout input.input-text:focus,
form.checkout select:focus,
form.checkout textarea:focus,
.woocommerce-company-info input[type="text"]:focus,
.woocommerce-company-info input.input-text:focus,
.woocommerce-company-info select:focus {
	border-color: #208490 !important;
	outline: none !important;
	box-shadow: 0 0 0 3px rgba(32, 132, 144, 0.15) !important;
}

/* Consistent label styling - consolidated */
form.checkout label,
.woocommerce-company-info label {
	font-weight: 600 !important;
	color: #4a5568 !important;
	margin-bottom: 8px !important;
	display: block !important;
}

/* Ensure two-column checkout layout */
.woocommerce-checkout .col2-set {
	width: 100%;
	display: block;
	clear: both;
}

.woocommerce-checkout .col2-set::after {
	content: "";
	display: table;
	clear: both;
}

/* Ensure fields and sections spacing */
.woocommerce-billing-fields,
.woocommerce-shipping-fields,
.woocommerce-additional-fields {
	margin-bottom: 30px;
}

.woocommerce-company-info {
	display: block;
	width: 100%;
	margin-bottom: 30px;
}

/* Payment methods display */
.woocommerce form.checkout #payment .payment_methods {
	display: block !important;
}

.woocommerce-checkout .col2-set {
	display: block;
	width: 100%;
}

.woocommerce-checkout .col2-set::after {
	content: "";
	display: table;
	clear: both;
}

/* Responsive adjustments */
@media (max-width: 768px) {
	.woocommerce-company-info,
	.woocommerce-billing-fields__field-wrapper,
	.woocommerce-shipping-fields__field-wrapper,
	.woocommerce-additional-fields__field-wrapper,
	#order_review,
	.woocommerce-checkout-review-order,
	#payment {
		padding: 20px 15px;
	}
	
	.woocommerce-company-info .form-row.form-row-first,
	.woocommerce-company-info .form-row.form-row-last {
		flex: 1 1 100%;
		min-width: 0;
	}
	
	.woocommerce-section-heading,
	.woocommerce-billing-fields > h3,
	.woocommerce-shipping-fields > h3,
	.woocommerce-additional-fields > h3,
	#order_review_heading {
		font-size: 1.3em !important;
		margin-top: 30px !important;
	}
	
	.woocommerce-section-heading {
		margin-top: 30px !important;
	}
	
	.woocommerce-company-info .radio-option {
		padding: 10px;
	}
	
	.woocommerce-billing-fields,
	.woocommerce-shipping-fields,
	.woocommerce-additional-fields {
		margin-bottom: 20px;
	}
	
	#payment {
		margin-top: 20px;
	}
}

/* Select2 styling to match WooCommerce theme */
.select2-container--default .select2-selection--single,
.select2-container--default .select2-selection--multiple {
	border: 1px solid #ddd;
	border-radius: 4px;
	min-height: 40px;
	padding: 0 8px;
}

.select2-container--default .select2-selection--single {
	height: 40px;
	line-height: 40px;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
	line-height: 40px;
	padding-left: 0;
	padding-right: 20px;
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
	height: 38px;
	right: 8px;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice {
	background-color: #f0f0f0;
	border: 1px solid #ddd;
	border-radius: 4px;
	margin: 4px 4px 4px 0;
	padding: 4px 8px;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
	margin-right: 6px;
	color: #999;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice__remove:hover {
	color: #333;
}

.select2-container--default .select2-results__option--highlighted[aria-selected] {
	background-color: #208490;
	color: #fff;
}

.select2-dropdown {
	border: 1px solid #ddd;
	border-radius: 4px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

/* Radio button styling for operator type */
.woocommerce-checkout #payment .form-row.rcp_company_op_type,
.woocommerce-account .woocommerce-EditAccountForm .form-row.rcp_company_op_type {
	margin-bottom: 20px;
}

.woocommerce-checkout #payment .form-row.rcp_company_op_type label,
.woocommerce-account .woocommerce-EditAccountForm .form-row.rcp_company_op_type label {
	display: block;
	margin-bottom: 12px;
	font-weight: 600;
}

.woocommerce-checkout #payment .form-row.rcp_company_op_type .woocommerce-input-wrapper,
.woocommerce-account .woocommerce-EditAccountForm .form-row.rcp_company_op_type .woocommerce-input-wrapper,
.woocommerce-account .woocommerce-form-row--wide .woocommerce-input-wrapper {
	display: block;
}

.woocommerce-checkout #payment .form-row.rcp_company_op_type input[type="radio"],
.woocommerce-account .woocommerce-EditAccountForm .form-row.rcp_company_op_type input[type="radio"],
.woocommerce-account .woocommerce-form-row--wide input[type="radio"] {
	margin-right: 8px;
	margin-top: 4px;
	vertical-align: top;
}

.woocommerce-checkout #payment .form-row.rcp_company_op_type label:not([for]),
.woocommerce-account .woocommerce-EditAccountForm .form-row.rcp_company_op_type label:not([for]),
.woocommerce-account .woocommerce-form-row--wide label:not([for]) {
	display: block;
	margin-bottom: 8px;
	font-weight: 400;
	font-size: 0.95em;
	line-height: 1.5;
	padding-left: 24px;
}

.woocommerce-checkout #payment .form-row.rcp_company_op_type label:not([for]):last-child,
.woocommerce-account .woocommerce-EditAccountForm .form-row.rcp_company_op_type label:not([for]):last-child,
.woocommerce-account .woocommerce-form-row--wide label:not([for]):last-child {
	margin-bottom: 0;
}

/* Registration form styling */
.woocommerce-account .woocommerce-form-row--wide {
	margin-bottom: 20px;
}

.woocommerce-account .woocommerce-form-row--wide > label:first-child {
	display: block;
	margin-bottom: 8px;
	font-weight: 600;
}

.woocommerce-account .woocommerce-form-row--wide .select2-container {
	width: 100% !important;
}

/* Registration form radio button styling */
.woocommerce-account .woocommerce-form-row--wide .radio-option {
	display: flex;
	align-items: flex-start;
	margin-bottom: 16px;
	padding: 16px;
	background-color: #fff;
	border: 2px solid #e0e0e0;
	border-radius: 6px;
	transition: all 0.2s ease;
	cursor: pointer;
}

.woocommerce-account .woocommerce-form-row--wide .radio-option:last-of-type {
	margin-bottom: 0;
}

.woocommerce-account .woocommerce-form-row--wide .radio-option:hover {
	border-color: #208490;
	background-color: #f8fcfd;
}

.woocommerce-account .woocommerce-form-row--wide .radio-option input[type="radio"] {
	margin-right: 14px;
	margin-top: 2px;
	flex-shrink: 0;
	width: 18px;
	height: 18px;
	cursor: pointer;
}

.woocommerce-account .woocommerce-form-row--wide .radio-option input[type="radio"]:checked {
	accent-color: #208490;
}

.woocommerce-account .woocommerce-form-row--wide .radio-option:has(input[type="radio"]:checked) {
	border-color: #208490;
	background-color: #e8f4f8;
	border-width: 2px;
}

/* Registration form radio option content container */
.woocommerce-account .woocommerce-form-row--wide .radio-option-content {
	display: flex;
	flex-direction: column;
	gap: 6px;
	flex: 1;
}

/* Registration form radio option title (bold) */
.woocommerce-account .woocommerce-form-row--wide .radio-option-title {
	display: block;
	font-weight: 700;
	font-size: 1em;
	color: #333;
	line-height: 1.4;
}

/* Registration form radio option description (smaller text) */
.woocommerce-account .woocommerce-form-row--wide .radio-option-description {
	display: block;
	font-weight: 400;
	font-size: 0.875em;
	color: #666;
	line-height: 1.5;
}

/* Ensure Select2 width matches form fields */
.select2-container {
	width: 100% !important;
}

/* Responsive adjustments */
@media (max-width: 768px) {
	.select2-container--default .select2-selection--single,
	.select2-container--default .select2-selection--multiple {
		min-height: 44px;
	}

	.select2-container--default .select2-selection--single {
		height: 44px;
		line-height: 44px;
	}

	.select2-container--default .select2-selection--single .select2-selection__rendered {
		line-height: 44px;
	}
}

/* ========================================
   Cart Page Styling
   ======================================== */

/* Cart Totals Section Heading */
.woocommerce-cart .cart_totals > h2 {
	color: #2d3748 !important;
	font-size: 1.3em !important;
	font-weight: 600 !important;
	border-bottom: none !important;
	padding-bottom: 0 !important;
	margin-bottom: 20px !important;
	text-transform: none !important;
	letter-spacing: normal !important;
}

/* Cart Totals Container */
.woocommerce-cart .cart_totals {
	background-color: #ffffff;
	padding: 30px;
	border-radius: 8px;
	border: 1px solid #e2e8f0;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
	box-sizing: border-box;
}

/* Cart Totals Table */
.woocommerce-cart .cart_totals table {
	background-color: #fafbfc;
	border-radius: 6px;
	margin-bottom: 20px;
}

.woocommerce-cart .cart_totals table th {
	font-weight: 600;
	color: #4a5568;
	padding: 12px;
}

.woocommerce-cart .cart_totals table td {
	padding: 12px;
	text-align: right;
	color: #2d3748;
}

.woocommerce-cart .cart_totals table .order-total th,
.woocommerce-cart .cart_totals table .order-total td {
	font-weight: 700;
	font-size: 1.1em;
	border-top: 2px solid #e2e8f0;
	padding-top: 15px;
	color: #2d3748;
}

/* Cart Form Table */
.woocommerce-cart-form .shop_table {
	background-color: #fff;
	border-radius: 8px;
	margin-bottom: 30px;
	border: 1px solid #e2e8f0;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}

.woocommerce-cart-form .shop_table thead th {
	font-weight: 600;
	color: #4a5568;
	padding: 15px;
	border-bottom: 2px solid #e2e8f0;
	text-transform: none;
	font-size: 0.9em;
	letter-spacing: normal;
}

.woocommerce-cart-form .shop_table tbody td {
	padding: 15px;
	border-bottom: 1px solid #e0e0e0;
}

.woocommerce-cart-form .shop_table tbody tr:last-child td {
	border-bottom: none;
}

/* Cart Page Buttons */
.woocommerce-cart .button,
.woocommerce-cart input.button {
	padding: 12px 28px !important;
	font-size: 1em !important;
	font-weight: 600 !important;
	border-radius: 32px !important;
	transition: all 0.2s ease !important;
	border: none !important;
	cursor: pointer;
}

/* Update Cart Button (Secondary) */
.woocommerce-cart-form .button[name="update_cart"] {
	background-color: #718096 !important;
	color: #fff !important;
}

.woocommerce-cart-form .button[name="update_cart"]:hover {
	background-color: #4a5568 !important;
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(74, 85, 104, 0.2);
}

/* Proceed to Checkout Button (Primary) */
.woocommerce-cart .wc-proceed-to-checkout .checkout-button,
.woocommerce-cart .cart_totals .checkout-button {
	background-color: #208490 !important;
	color: #fff !important;
	width: 100%;
	display: block;
	text-align: center;
	text-decoration: none;
}

.woocommerce-cart .wc-proceed-to-checkout .checkout-button:hover,
.woocommerce-cart .cart_totals .checkout-button:hover {
	background-color: #1a6f7a !important;
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(32, 132, 144, 0.2);
}

/* Coupon Code Input */
.woocommerce-cart .coupon input.input-text {
	padding: 10px 12px !important;
	border: 1px solid #e2e8f0 !important;
	border-radius: 6px !important;
	font-size: 1em !important;
	transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
	box-sizing: border-box !important;
	color: #4a5568 !important;
}

.woocommerce-cart .coupon input.input-text:focus {
	border-color: #208490 !important;
	outline: none !important;
	box-shadow: 0 0 0 3px rgba(32, 132, 144, 0.15) !important;
}

/* Apply Coupon Button */
.woocommerce-cart .coupon .button {
	background-color: #718096 !important;
	color: #fff !important;
	padding: 10px 24px !important;
	border-radius: 32px !important;
}

.woocommerce-cart .coupon .button:hover {
	background-color: #4a5568 !important;
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(74, 85, 104, 0.2);
}

/* Quantity Input */
.woocommerce-cart .quantity input.qty {
	padding: 10px 12px !important;
	border: 1px solid #e2e8f0 !important;
	border-radius: 6px !important;
	font-size: 1em !important;
	width: 80px;
	text-align: center;
	transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
	color: #4a5568 !important;
}

.woocommerce-cart .quantity input.qty:focus {
	border-color: #208490 !important;
	outline: none !important;
	box-shadow: 0 0 0 3px rgba(32, 132, 144, 0.15) !important;
}

/* Cart Empty State */
.woocommerce-cart .cart-empty {
	text-align: center;
	padding: 40px 20px;
	color: #718096;
}

.woocommerce-cart .return-to-shop .button {
	background-color: #208490 !important;
	color: #fff !important;
	padding: 12px 28px !important;
	border-radius: 32px !important;
}

.woocommerce-cart .return-to-shop .button:hover {
	background-color: #1a6f7a !important;
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(32, 132, 144, 0.2);
}

/* Cart Responsive */
@media (max-width: 768px) {
	.woocommerce-cart .cart_totals {
		padding: 20px 15px;
		margin-top: 30px;
	}
	
	.woocommerce-cart .cart_totals > h2 {
		font-size: 1.3em !important;
	}
	
	.woocommerce-cart-form .shop_table thead {
		display: none;
	}
	
	.woocommerce-cart-form .shop_table tbody td {
		display: block;
		padding: 10px;
		text-align: left !important;
	}
	
	.woocommerce-cart-form .shop_table tbody td::before {
		content: attr(data-title);
		font-weight: 600;
		display: block;
		margin-bottom: 5px;
		color: #333;
	}
}

/* ========================================
   Order Confirmation Page Styling
   ======================================== */

/* Success Notice Banner */
.woocommerce-order-received .woocommerce-notice--success {
	background-color: #f0fdf4;
	border: 1px solid #bbf7d0;
	border-left: 4px solid #48bb78;
	color: #166534;
	padding: 15px 20px;
	margin-bottom: 30px;
	border-radius: 8px;
	font-weight: 500;
}

/* Override Bricks flex styling that breaks multi-line notices */
.woocommerce-notices-wrapper .woocommerce-message {
	display: block !important;
	flex-flow: unset;
}

/* Seat Change Success Notice - styled consistently */
.woocommerce-order-received .woocommerce-message,
.woocommerce-thankyou .woocommerce-message,
.teams-area .woocommerce-notices-wrapper .woocommerce-message {
	background-color: #f0fdf4;
	border: 1px solid #bbf7d0;
	border-left: 4px solid #48bb78;
	color: #166534;
	padding: 20px 25px;
	margin-bottom: 20px;
	border-radius: 8px;
	font-weight: 500;
	line-height: 1.6;
	display: block !important;
}

/* Style the recurring total highlight in seat change notices */
.woocommerce-order-received .woocommerce-message br + br + *,
.woocommerce-thankyou .woocommerce-message br + br + * {
	display: inline;
}

/* Teams area success messages */
.teams-area .woocommerce-message {
	background-color: #f0fdf4;
	border: 1px solid #bbf7d0;
	border-left: 4px solid #48bb78;
	color: #166534;
	padding: 20px 25px;
	margin-bottom: 20px;
	border-radius: 8px;
	font-weight: 500;
	line-height: 1.6;
}

/* Order Overview Section */
.woocommerce-order-overview {
	background-color: #ffffff;
	padding: 30px;
	border-radius: 8px;
	border: 1px solid #e2e8f0;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
	box-sizing: border-box;
	margin-bottom: 30px;
	list-style: none;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 20px;
}

.woocommerce-order-overview li {
	display: flex;
	flex-direction: column;
	gap: 5px;
	color: #718096;
	font-size: 0.95em;
}

.woocommerce-order-overview li strong {
	color: #2d3748;
	font-size: 1.15em;
	font-weight: 600;
	margin-top: 2px;
}

/* Make the Total stand out more */
.woocommerce-order-overview__total {
	padding: 15px 20px;
	background-color: #f7fafc;
	border-radius: 8px;
	border: 2px solid #e2e8f0;
	text-align: center;
}

.woocommerce-order-overview__total strong {
	font-size: 1.8em;
	color: #2d3748;
}

/* Order Details Section Heading */
.woocommerce-order-details__title,
.woocommerce-order-downloads__title,
.woocommerce-customer-details__title {
	color: #2d3748 !important;
	font-size: 1.3em !important;
	font-weight: 600 !important;
	border-bottom: none !important;
	padding-bottom: 0 !important;
	margin-bottom: 20px !important;
	margin-top: 40px !important;
	text-transform: none !important;
	letter-spacing: normal !important;
}

.woocommerce-order-details__title:first-child {
	margin-top: 0 !important;
}

/* Order Details Container */
.woocommerce-order-details {
	background-color: #ffffff;
	padding: 30px;
	border-radius: 8px;
	border: 1px solid #e2e8f0;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
	box-sizing: border-box;
	margin-bottom: 30px;
}

/* Order Downloads Container */
.woocommerce-order-downloads {
	background-color: #ffffff;
	padding: 30px;
	border-radius: 8px;
	border: 1px solid #e2e8f0;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
	box-sizing: border-box;
	margin-bottom: 30px;
}

/* Customer Details Container */
.woocommerce-customer-details {
	background-color: #ffffff;
	padding: 30px;
	border-radius: 8px;
	border: 1px solid #e2e8f0;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
	box-sizing: border-box;
	margin-bottom: 30px;
}

/* Order Details Table */
.woocommerce-table--order-details {
	background-color: #fafbfc;
	border-radius: 6px;
	margin-bottom: 20px;
	width: 100%;
}

.woocommerce-table--order-details thead th {
	font-weight: 600;
	color: #4a5568;
	padding: 15px;
	border-bottom: 2px solid #e2e8f0;
	text-transform: none;
	font-size: 0.9em;
	letter-spacing: normal;
}

.woocommerce-table--order-details tbody td {
	padding: 15px;
	border-bottom: 1px solid #e0e0e0;
}

.woocommerce-table--order-details tbody tr:last-child td {
	border-bottom: none;
}

.woocommerce-table--order-details tfoot th {
	font-weight: 600;
	color: #4a5568;
	padding: 12px 15px;
	border-top: 1px solid #e2e8f0;
}

.woocommerce-table--order-details tfoot td {
	padding: 12px 15px;
	text-align: right;
	border-top: 1px solid #e2e8f0;
	color: #2d3748;
}

.woocommerce-table--order-details tfoot .order-total th,
.woocommerce-table--order-details tfoot .order-total td {
	font-weight: 700;
	font-size: 1.1em;
	border-top: 2px solid #e2e8f0;
	padding-top: 15px;
	color: #2d3748;
}

/* Order Downloads Table */
.woocommerce-order-downloads__files {
	background-color: #fafbfc;
	border-radius: 6px;
	margin-bottom: 20px;
	width: 100%;
}

.woocommerce-order-downloads__files thead th {
	font-weight: 600;
	color: #4a5568;
	padding: 15px;
	border-bottom: 2px solid #e2e8f0;
	text-transform: none;
	font-size: 0.9em;
	letter-spacing: normal;
}

.woocommerce-order-downloads__files tbody td {
	padding: 15px;
	border-bottom: 1px solid #e0e0e0;
}

.woocommerce-order-downloads__files tbody tr:last-child td {
	border-bottom: none;
}

.woocommerce-order-downloads__files a {
	color: #208490;
	text-decoration: none;
	font-weight: 600;
}

.woocommerce-order-downloads__files a:hover {
	text-decoration: underline;
}

/* Customer Details Address */
.woocommerce-customer-details address {
	background-color: #fff;
	padding: 20px;
	border-radius: 4px;
	margin-top: 10px;
	font-style: normal;
	line-height: 1.8;
}

.woocommerce-customer-details address p {
	margin-bottom: 8px;
}

.woocommerce-customer-details address p:last-child {
	margin-bottom: 0;
}

/* Order Again Button */
.woocommerce-order-again .button {
	background-color: #208490 !important;
	color: #fff !important;
	padding: 12px 28px !important;
	font-size: 1em !important;
	font-weight: 600 !important;
	border-radius: 32px !important;
	border: none !important;
	transition: all 0.2s ease !important;
}

.woocommerce-order-again .button:hover {
	background-color: #1a6f7a !important;
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(32, 132, 144, 0.2);
}

/* ========================================
   My Account Page Styling
   ======================================== */

/* My Account Layout */
.woocommerce-account .woocommerce-MyAccount-navigation {
	background-color: #f7fafc;
	border-radius: 8px;
	padding: 0;
	margin-bottom: 30px;
	border: 1px solid #e2e8f0;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.woocommerce-account .woocommerce-MyAccount-navigation li {
	margin: 0;
	border-bottom: 1px solid #e2e8f0;
}

.woocommerce-account .woocommerce-MyAccount-navigation li:last-child {
	border-bottom: none;
}

.woocommerce-account .woocommerce-MyAccount-navigation a {
	display: block;
	padding: 12px 24px;
	color: #4a5568;
	text-decoration: none;
	font-weight: 500;
	transition: all 0.2s ease;
	position: relative;
	line-height: 1.6em;
}

.woocommerce-account .woocommerce-MyAccount-navigation a:hover {
	background-color: rgba(32, 132, 144, 0.08);
	color: #208490;
	padding-left: 28px;
}

.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a {
	background-color: #ffffff;
	color: #208490;
	font-weight: 600;
	border-left: 3px solid #208490;
	padding-left: 21px;
}

/* Logout button accent */
.woocommerce-account .woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--customer-logout a {
	color: #ef4444;
	font-weight: 600;
}

.woocommerce-account .woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--customer-logout a:hover {
	background-color: rgba(239, 68, 68, 0.08);
	color: #dc2626;
}

/* My Account Content Area */
.woocommerce-account .woocommerce-MyAccount-content {
	background-color: #ffffff;
	border-radius: 8px;
	padding: 30px;
	border: 1px solid #e2e8f0;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}

/* Improved spacing for content headings and sections */
.woocommerce-account .woocommerce-MyAccount-content h2,
.woocommerce-account .woocommerce-MyAccount-content h3 {
	color: #2d3748;
	font-weight: 600;
	margin-top: 0;
	margin-bottom: 20px;
	line-height: 1.4;
}

.woocommerce-account .woocommerce-MyAccount-content h2:not(:first-child),
.woocommerce-account .woocommerce-MyAccount-content h3:not(:first-child) {
	margin-top: 40px;
}

.woocommerce-account .woocommerce-MyAccount-content p {
	margin-bottom: 16px;
	line-height: 1.6;
	color: #4a5568;
}

.woocommerce-account .woocommerce-MyAccount-content fieldset {
	margin-bottom: 24px;
	padding: 0;
	border: none;
}

.woocommerce-account .woocommerce-MyAccount-content legend {
	font-size: 1.1em;
	font-weight: 600;
	color: #2d3748;
	margin-bottom: 16px;
	padding: 0;
}

/* My Account Orders Table */
.woocommerce-account .woocommerce-orders-table {
	background-color: #fafbfc;
	border-radius: 8px;
	border: 1px solid #e2e8f0;
	overflow: hidden;
}

.woocommerce-account .woocommerce-orders-table thead th {
	background-color: #f7fafc;
	color: #4a5568;
	font-weight: 600;
	padding: 15px;
	text-align: left;
	border-bottom: 2px solid #e2e8f0;
	font-size: 0.9em;
	text-transform: none;
	letter-spacing: normal;
}

.woocommerce-account .woocommerce-orders-table tbody td {
	padding: 15px;
	border-bottom: 1px solid #e2e8f0;
	color: #4a5568;
}

.woocommerce-account .woocommerce-orders-table tbody tr {
	background-color: #ffffff;
	transition: background-color 0.2s ease;
}

.woocommerce-account .woocommerce-orders-table tbody tr:hover {
	background-color: #fafbfc;
}

.woocommerce-account .woocommerce-orders-table tbody tr:last-child td {
	border-bottom: none;
}

/* Order Number Links */
.woocommerce-account .woocommerce-orders-table a {
	color: #208490;
	text-decoration: none;
	font-weight: 500;
	transition: color 0.2s ease;
}

.woocommerce-account .woocommerce-orders-table a:hover {
	color: #1a6f7a;
	text-decoration: underline;
}

/* Order Status Badge */
.woocommerce-account .woocommerce-orders-table .woocommerce-orders-table__cell-order-status {
	font-weight: 500;
}

/* View Button in Orders Table */
.woocommerce-account .woocommerce-button.view,
.woocommerce-account .woocommerce-orders-table .button {
	background-color: #ffffff;
	color: #208490;
	border: 2px solid #208490;
	padding: 8px 20px;
	border-radius: 32px;
	font-size: 0.9em;
	font-weight: 600;
	text-decoration: none;
	display: inline-block;
	transition: all 0.2s ease;
	margin-top: 10px;
}

.woocommerce-account .woocommerce-button.view:hover,
.woocommerce-account .woocommerce-orders-table .button:hover {
	background-color: #208490;
	color: #ffffff;
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(32, 132, 144, 0.2);
}

/* Orders page - Add spacing for action buttons */
.woocommerce-account .woocommerce-orders-table__cell-order-actions {
	padding-top: 15px !important;
}

/* My Account Forms */
.woocommerce-account .woocommerce-EditAccountForm label,
.woocommerce-account .woocommerce-address-fields label {
	color: #4a5568;
	font-weight: 600;
	margin-bottom: 8px;
	display: block;
}

.woocommerce-account .woocommerce-EditAccountForm .form-row,
.woocommerce-account .woocommerce-address-fields .form-row {
	margin-bottom: 20px;
}

.woocommerce-account .woocommerce-EditAccountForm input[type="text"],
.woocommerce-account .woocommerce-EditAccountForm input[type="email"],
.woocommerce-account .woocommerce-EditAccountForm input[type="password"],
.woocommerce-account .woocommerce-address-fields input[type="text"],
.woocommerce-account .woocommerce-address-fields input[type="email"],
.woocommerce-account .woocommerce-address-fields select {
	padding: 10px 12px;
	border: 1px solid #e2e8f0;
	border-radius: 6px;
	font-size: 1em;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	box-sizing: border-box;
	width: 100%;
	color: #4a5568;
}

.woocommerce-account .woocommerce-EditAccountForm input[type="text"]:focus,
.woocommerce-account .woocommerce-EditAccountForm input[type="email"]:focus,
.woocommerce-account .woocommerce-EditAccountForm input[type="password"]:focus,
.woocommerce-account .woocommerce-address-fields input[type="text"]:focus,
.woocommerce-account .woocommerce-address-fields input[type="email"]:focus,
.woocommerce-account .woocommerce-address-fields select:focus {
	border-color: #208490;
	outline: none;
	box-shadow: 0 0 0 3px rgba(32, 132, 144, 0.15);
}

/* Password toggle button fix */
.woocommerce-account .show-password-input,
.woocommerce .show-password-input,
.show-password-input {
	position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-50%);
	background: none;
	border: none;
	cursor: pointer;
	padding: 8px;
	z-index: 10;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #718096;
	font-size: 1.2em;
}

.woocommerce-account .show-password-input:hover,
.woocommerce .show-password-input:hover,
.show-password-input:hover {
	color: #4a5568;
}

/* Ensure password field wrapper has position relative */
.woocommerce-account .woocommerce-form-row,
.woocommerce-form-row {
	position: relative;
}

.woocommerce-account .password-input,
.woocommerce .password-input,
.password-input {
	padding-right: 45px !important;
}

/* My Account Buttons */
.woocommerce-account .woocommerce-Button,
.woocommerce-account button[type="submit"],
.woocommerce-account .button {
	background-color: #208490;
	color: #ffffff;
	border: none;
	padding: 12px 28px;
	border-radius: 32px;
	font-size: 1em;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.2s ease;
	text-decoration: none;
	display: inline-block;
}

.woocommerce-account .woocommerce-Button:hover,
.woocommerce-account button[type="submit"]:hover,
.woocommerce-account .button:hover {
	background-color: #1a6f7a;
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(32, 132, 144, 0.2);
}

/* My Account Addresses */
.woocommerce-account .woocommerce-Addresses {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 20px;
}

.woocommerce-account .woocommerce-Address {
	background-color: #fafbfc;
	padding: 20px;
	border-radius: 8px;
	border: 1px solid #e2e8f0;
}

.woocommerce-account .woocommerce-Address-title h3 {
	color: #2d3748;
	font-size: 1.1em;
	font-weight: 600;
	margin-bottom: 15px;
}

.woocommerce-account .woocommerce-Address address {
	font-style: normal;
	line-height: 1.8;
	color: #4a5568;
}

/* Downloads Section */
.woocommerce-account .woocommerce-Message {
	background-color: #f7fafc;
	border-left: 4px solid #208490;
	padding: 15px 20px;
	margin-bottom: 20px;
	border-radius: 6px;
	color: #4a5568;
}

/* Downloads Table Improvements */
.woocommerce-account .woocommerce-order-downloads {
	background: none;
	border: none;
	box-shadow: none;
	padding: 0;
}

.woocommerce-account .woocommerce-table--order-downloads {
	background-color: #fafbfc;
	border: 1px solid #e2e8f0;
	border-radius: 8px;
}

/* Table header styling - better spacing and alignment */
.woocommerce-account .woocommerce-table--order-downloads thead th {
	padding: 16px 20px;
	font-weight: 600;
	color: #2d3748;
	font-size: 0.95em;
	border-bottom: 2px solid #e2e8f0;
	text-align: center;
}

/* Keep Product header left-aligned */
.woocommerce-account .woocommerce-table--order-downloads thead th.download-product {
	text-align: left;
}

/* Table body cells */
.woocommerce-account .woocommerce-table--order-downloads tbody td {
	padding: 16px 20px;
	text-align: center;
	vertical-align: middle;
	font-size: 0.95em;
}

/* Keep Product column left-aligned */
.woocommerce-account .woocommerce-table--order-downloads tbody td.download-product {
	text-align: left;
}

/* Product column width */
.woocommerce-account .woocommerce-table--order-downloads th.download-product,
.woocommerce-account .woocommerce-table--order-downloads td.download-product {
	width: 40%;
}

/* Download Report button styling */
.woocommerce-account .woocommerce-table--order-downloads .woocommerce-MyAccount-downloads-file {
	white-space: nowrap;
	display: inline-block;
	padding: 8px 20px;
	font-size: 0.9em;
}

/* ========================================
   Memberships Page - Card Layout
   ======================================== */

.woocommerce-account .my_account_memberships {
	background: none;
	border: none;
	box-shadow: none;
	border-radius: 0;
}

.woocommerce-account .my_account_memberships thead {
	display: none;
}

.woocommerce-account .my_account_memberships tbody {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: 20px;
}

.woocommerce-account .my_account_memberships tbody tr.membership {
	display: flex;
	flex-direction: column;
	background-color: #ffffff;
	border: 1px solid #e2e8f0;
	border-radius: 8px;
	padding: 24px;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
	transition: box-shadow 0.2s ease, transform 0.2s ease;
	margin-bottom: 0;
}

.woocommerce-account .my_account_memberships tbody tr.membership:hover {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
	transform: translateY(-2px);
}

.woocommerce-account .my_account_memberships tbody td {
	display: block;
	padding: 0;
	margin-bottom: 12px;
	border: none;
	text-align: left !important;
}

.woocommerce-account .my_account_memberships tbody td:last-child {
	margin-bottom: 0;
	margin-top: 8px;
}

/* Membership Plan - Make it prominent */
.woocommerce-account .my_account_memberships tbody td.membership-plan {
	font-size: 1.2em;
	font-weight: 600;
	color: #2d3748;
	margin-bottom: 16px;
	padding-bottom: 12px;
	border-bottom: 2px solid #e2e8f0;
}

.woocommerce-account .my_account_memberships tbody td.membership-plan a {
	color: #2d3748;
	text-decoration: none;
}

.woocommerce-account .my_account_memberships tbody td.membership-plan a:hover {
	color: #208490;
}

/* Add labels to data */
.woocommerce-account .my_account_memberships tbody td::before {
	content: attr(data-title) ": ";
	font-weight: 600;
	color: #4a5568;
	display: inline;
	margin-right: 6px;
	font-size: 0.9em;
}

.woocommerce-account .my_account_memberships tbody td.membership-plan::before,
.woocommerce-account .my_account_memberships tbody td.membership-actions::before {
	content: none;
}

/* Membership status badge */
.woocommerce-account .my_account_memberships tbody td.membership-status {
	font-weight: 600;
	color: #48bb78;
}

/* Membership dates */
.woocommerce-account .my_account_memberships tbody td.membership-start-date,
.woocommerce-account .my_account_memberships tbody td.membership-end-date,
.woocommerce-account .my_account_memberships tbody td.membership-next-bill-on {
	font-size: 0.95em;
	color: #4a5568;
}

/* Actions buttons in cards */
.woocommerce-account .my_account_memberships tbody td.membership-actions {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	padding-top: 12px;
	border-top: 1px solid #e2e8f0;
}

.woocommerce-account .my_account_memberships tbody td.membership-actions .button {
	flex: 1;
	min-width: 100px;
	text-align: center;
	margin: 0;
}

.woocommerce-account .my_account_memberships tbody td.membership-actions .button.cancel {
	background-color: #ffffff;
	color: #ef4444;
	border: 2px solid #ef4444;
}

.woocommerce-account .my_account_memberships tbody td.membership-actions .button.cancel:hover {
	background-color: #ef4444;
	color: #ffffff;
}

/* ========================================
   Teams Page - Card Layout
   ======================================== */

.woocommerce-account table.my_account_teams {
	background: none;
	border: none;
	box-shadow: none;
	border-radius: 0;
}

.woocommerce-account table.my_account_teams thead {
	display: none;
}

.woocommerce-account table.my_account_teams tbody {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: 20px;
}

.woocommerce-account table.my_account_teams tbody tr.team {
	display: flex;
	flex-direction: column;
	background-color: #ffffff;
	border: 1px solid #e2e8f0;
	border-radius: 8px;
	padding: 24px;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
	transition: box-shadow 0.2s ease, transform 0.2s ease;
	margin-bottom: 0;
}

.woocommerce-account table.my_account_teams tbody tr.team:hover {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
	transform: translateY(-2px);
}

.woocommerce-account table.my_account_teams tbody td {
	display: block;
	padding: 0;
	margin-bottom: 12px;
	border: none;
	text-align: left !important;
}

.woocommerce-account table.my_account_teams tbody td:last-child {
	margin-bottom: 0;
	margin-top: 8px;
}

/* Team Name - Make it prominent */
.woocommerce-account table.my_account_teams tbody td.team-name {
	font-size: 1.2em;
	font-weight: 600;
	color: #2d3748;
	margin-bottom: 16px;
	padding-bottom: 12px;
	border-bottom: 2px solid #e2e8f0;
}

.woocommerce-account table.my_account_teams tbody td.team-name a {
	color: #2d3748;
	text-decoration: none;
}

.woocommerce-account table.my_account_teams tbody td.team-name a:hover {
	color: #208490;
}

/* Add labels to team data */
.woocommerce-account table.my_account_teams tbody td::before {
	content: attr(data-title) ": ";
	font-weight: 600;
	color: #4a5568;
	display: inline;
	margin-right: 6px;
	font-size: 0.9em;
}

.woocommerce-account table.my_account_teams tbody td.team-name::before,
.woocommerce-account table.my_account_teams tbody td.team-actions::before {
	content: none;
}

/* Team dates and info */
.woocommerce-account table.my_account_teams tbody td.team-created-date,
.woocommerce-account table.my_account_teams tbody td.team-next-bill-on,
.woocommerce-account table.my_account_teams tbody td.team-member-count {
	font-size: 0.95em;
	color: #4a5568;
}

/* Actions buttons in team cards */
.woocommerce-account table.my_account_teams tbody td.team-actions {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	padding-top: 12px;
	border-top: 1px solid #e2e8f0;
}

.woocommerce-account table.my_account_teams tbody td.team-actions .button {
	flex: 1;
	min-width: 100px;
	text-align: center;
	margin: 0;
}

.woocommerce-account table.my_account_teams tbody td.team-actions .button.billing {
	background-color: #718096;
	color: #ffffff;
	border: none;
}

.woocommerce-account table.my_account_teams tbody td.team-actions .button.billing:hover {
	background-color: #4a5568;
}

/* ========================================
   Global WooCommerce Link & Button Unification
   ======================================== */

/* Standard WooCommerce Links */
.woocommerce a:not(.button):not(.woocommerce-button) {
	color: #208490;
	text-decoration: none;
	transition: color 0.2s ease;
}

.woocommerce a:not(.button):not(.woocommerce-button):hover {
	color: #1a6f7a;
}

.woocommerce a.subscription-back-link:not(.button):not(.woocommerce-button):hover {
	color: #ffffff;
}

/* Ensure all primary action buttons are pill-shaped and consistent */
.woocommerce .button.alt,
.woocommerce-page .button.alt {
	background-color: #208490 !important;
	color: #ffffff !important;
	border: none !important;
	padding: 12px 28px !important;
	border-radius: 32px !important;
	font-size: 1em !important;
	font-weight: 600 !important;
	transition: all 0.2s ease !important;
	text-decoration: none !important;
}

.woocommerce .button.alt:hover,
.woocommerce-page .button.alt:hover {
	background-color: #1a6f7a !important;
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(32, 132, 144, 0.2);
}

/* Secondary buttons */
.woocommerce .button:not(.alt):not(.checkout-button),
.woocommerce-page .button:not(.alt):not(.checkout-button) {
	padding: 10px 24px !important;
	border-radius: 32px !important;
	font-weight: 600 !important;
	transition: all 0.2s ease !important;
}

/* Page headings consistency */
.woocommerce-page .entry-title,
.woocommerce .page-title {
	color: #2d3748;
	font-weight: 600;
	margin-bottom: 30px;
}

/* Notices & Messages */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	border-radius: 8px;
	padding: 15px 20px;
	margin-bottom: 20px;
	border-left-width: 4px;
}

.woocommerce-message {
	background-color: #f0fdf4;
	border-left-color: #48bb78;
	color: #166534;
}

.woocommerce-info {
	background-color: #f0f9ff;
	border-left-color: #208490;
	color: #0c4a6e;
}

.woocommerce-error {
	background-color: #fef2f2;
	border-left-color: #ef4444;
	color: #991b1b;
}

/* ========================================
   Login & Registration Page
   ======================================== */

.woocommerce-form-login,
.woocommerce-form-register {
	background-color: #ffffff;
	padding: 40px;
	border-radius: 8px;
	border: 1px solid #e2e8f0;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
	max-width: 500px;
	margin: 0 auto;
}

.woocommerce-form-login h2,
.woocommerce-form-register h2 {
	color: #2d3748;
	font-weight: 600;
	margin-bottom: 24px;
	text-align: center;
}

.woocommerce-form-login .form-row,
.woocommerce-form-register .form-row {
	margin-bottom: 20px;
}

.woocommerce-form-login label,
.woocommerce-form-register label {
	color: #4a5568;
	font-weight: 600;
	margin-bottom: 8px;
	display: block;
}

.woocommerce-form-login input[type="text"],
.woocommerce-form-login input[type="password"],
.woocommerce-form-login input[type="email"],
.woocommerce-form-register input[type="text"],
.woocommerce-form-register input[type="password"],
.woocommerce-form-register input[type="email"] {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid #e2e8f0;
	border-radius: 6px;
	font-size: 1em;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	color: #4a5568;
}

.woocommerce-form-login input:focus,
.woocommerce-form-register input:focus {
	border-color: #208490;
	outline: none;
	box-shadow: 0 0 0 3px rgba(32, 132, 144, 0.15);
}

.woocommerce-form-login button[type="submit"],
.woocommerce-form-register button[type="submit"] {
	background-color: #208490;
	color: #ffffff;
	border: none;
	padding: 12px 28px;
	border-radius: 32px;
	font-size: 1em;
	font-weight: 600;
	width: 100%;
	cursor: pointer;
	transition: all 0.2s ease;
}

.woocommerce-form-login button[type="submit"]:hover,
.woocommerce-form-register button[type="submit"]:hover {
	background-color: #1a6f7a;
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(32, 132, 144, 0.2);
}

.woocommerce-form-login .woocommerce-form-login__rememberme {
	margin-bottom: 20px;
}

.woocommerce-form-login .lost_password {
	text-align: center;
	margin-top: 16px;
}

.woocommerce-form-login .lost_password a {
	color: #208490;
	text-decoration: none;
}

.woocommerce-form-login .lost_password a:hover {
	color: #1a6f7a;
	text-decoration: underline;
}

/* Order Confirmation Responsive */
@media (max-width: 768px) {
	/* Order Overview - Stack on mobile */
	.woocommerce-order-overview {
		padding: 20px 15px;
		grid-template-columns: 1fr;
		gap: 15px;
	}
	
	.woocommerce-order-overview__total {
		grid-column: span 1;
		padding: 15px;
	}
	
	.woocommerce-order-overview__total strong {
		font-size: 1.5em;
	}
	
	.woocommerce-order-details,
	.woocommerce-order-downloads,
	.woocommerce-customer-details {
		padding: 20px 15px;
	}
	
	.woocommerce-order-details__title,
	.woocommerce-order-downloads__title,
	.woocommerce-customer-details__title {
		font-size: 1.3em !important;
		margin-top: 30px !important;
	}
	
	.woocommerce-order-details__title:first-child {
		margin-top: 0 !important;
	}
	
	.woocommerce-table--order-details,
	.woocommerce-order-downloads__files {
		font-size: 0.9em;
	}
	
	.woocommerce-table--order-details thead,
	.woocommerce-order-downloads__files thead {
		display: none;
	}
	
	.woocommerce-table--order-details tbody td,
	.woocommerce-order-downloads__files tbody td {
		display: block;
		padding: 10px;
		text-align: left !important;
		border-bottom: 1px solid #e0e0e0;
	}
	
	.woocommerce-table--order-details tbody td::before,
	.woocommerce-order-downloads__files tbody td::before {
		content: attr(data-title);
		font-weight: 600;
		display: block;
		margin-bottom: 5px;
		color: #333;
	}
	
	/* My Account Responsive */
	.woocommerce-account .woocommerce-MyAccount-navigation {
		margin-bottom: 20px;
	}
	
	.woocommerce-account .woocommerce-MyAccount-content {
		padding: 20px;
	}
	
	.woocommerce-account .woocommerce-orders-table {
		font-size: 0.9em;
	}
	
	.woocommerce-account .woocommerce-orders-table thead {
		display: none;
	}
	
	.woocommerce-account .woocommerce-orders-table tbody td {
		display: block;
		padding: 10px 15px;
		text-align: left !important;
		border-bottom: 1px solid #e2e8f0;
	}
	
	.woocommerce-account .woocommerce-orders-table tbody td::before {
		content: attr(data-title);
		font-weight: 600;
		display: block;
		margin-bottom: 5px;
		color: #2d3748;
		font-size: 0.85em;
		text-transform: uppercase;
		letter-spacing: 0.5px;
	}
	
	.woocommerce-account .woocommerce-orders-table tbody tr {
		display: block;
		margin-bottom: 15px;
		border: 1px solid #e2e8f0;
		border-radius: 8px;
		overflow: hidden;
	}
	
	.woocommerce-account .woocommerce-Addresses {
		grid-template-columns: 1fr;
	}
	
	/* Memberships cards on mobile */
	.woocommerce-account .my_account_memberships tbody {
		grid-template-columns: 1fr;
	}
	
	.woocommerce-account .my_account_memberships tbody tr.membership {
		padding: 20px;
	}
	
	.woocommerce-account .my_account_memberships tbody td.membership-actions {
		flex-direction: column;
	}
	
	.woocommerce-account .my_account_memberships tbody td.membership-actions .button {
		width: 100%;
	}
	
	/* Teams cards on mobile */
	.woocommerce-account table.my_account_teams tbody {
		grid-template-columns: 1fr;
	}
	
	.woocommerce-account table.my_account_teams tbody tr.team {
		padding: 20px;
	}
	
	.woocommerce-account table.my_account_teams tbody td.team-actions {
		flex-direction: column;
	}
	
	.woocommerce-account table.my_account_teams tbody td.team-actions .button {
		width: 100%;
	}
}

/* ========================================
   Subscription Membership Product Page
   Streamlined template matching membership overview
   ======================================== */

/* Main container - full width */
.single-product .subscription-membership-template {
	max-width: 100%;
	margin: 0;
	padding: 0;
}

/* Header Banner - Full viewport width */
.subscription-header-banner {
	background: linear-gradient(135deg, #0e3c52 0%, #208490 100%);
	padding: 60px 20px 80px;
	width: 100vw;
	position: relative;
	left: 50%;
	margin-left: -50vw;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* Header with background image */
.subscription-header-banner.has-bg-image {
	background: none;
}

.subscription-header-bg {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 0;
}

.subscription-header-bg-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
}

.subscription-header-overlay {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(135deg, rgba(14, 60, 82, 0.85) 0%, rgba(32, 132, 144, 0.75) 100%);
	mix-blend-mode: multiply;
}

.subscription-header-content {
	max-width: 800px;
	margin: 0 auto;
	text-align: center;
	position: relative;
	z-index: 1;
}

/* Back Link - Button Style */
.subscription-back-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background-color: #ffffff;
	color: #208490;
	text-decoration: none;
	font-size: 0.9rem;
	font-weight: 600;
	padding: 5px 20px;
	border-radius: 24px;
	margin-bottom: 24px;
	transition: all 0.2s ease;
	border: 2px solid #ffffff;
}

.subscription-back-link:hover {
	background-color: transparent;
	color: #ffffff;
	border-color: #ffffff;
}

.subscription-back-link svg {
	width: 16px;
	height: 16px;
	stroke: currentColor;
	transition: transform 0.2s ease;
}

.subscription-back-link:hover svg {
	transform: translateX(-2px);
}

/* Product Title in Header - High specificity to override theme defaults */
.subscription-membership-template .subscription-header-content h1.subscription-product-title,
h1.subscription-product-title {
	color: #ffffff !important;
	margin: 0 0 16px 0 !important;
	text-transform: none !important;
}

/* Price Display in Header - Hidden by default as price shown in form */
.subscription-price-display {
	display: none;
}

/* Main Content Section */
.subscription-main-content {
	padding: 0 20px;
	margin-top: -40px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
	z-index: 10;
}

.subscription-content-container {
	width: 768px;
	max-width: 100%;
	margin-left: auto;
	margin-right: auto;
}

/* Team size input - larger text for better visibility */
.subscription-membership-template .team-size-input,
.subscription-membership-template input#team-size-input {
	font-size: 1.5rem !important;
	font-weight: 600 !important;
	padding: 12px 16px !important;
	text-align: center;
	width: 100px !important;
}

/* Form Wrapper - Card Style */
.subscription-form-wrapper {
	background: #ffffff;
	border-radius: 12px;
	padding: 40px;
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.12);
	margin-bottom: 30px;
}

/* Override team pricing container within subscription template */
.subscription-membership-template .team-pricing-container {
	margin: 0;
	padding: 0;
	border: none;
	box-shadow: none;
	background: transparent;
}

/* Prevent slider animation on page load */
.subscription-membership-template .noUi-target {
	transition: none !important;
}

.subscription-membership-template .noUi-handle {
	transition: none !important;
}

.subscription-membership-template .noUi-connect {
	transition: none !important;
}

/* Ensure form container is static positioned */
.subscription-membership-template .variations_form,
.subscription-membership-template .team-size-selector-section {
	position: static;
	transform: none;
}

.subscription-membership-template .team-pricing-title {
	font-weight: 700;
	color: #2d3748;
	margin-bottom: 1.5rem;
}

/* Pricing display within form */
.subscription-membership-template .team-pricing-display {
	background: #f8fafc;
	border: 1px solid #e2e8f0;
	border-radius: 8px;
	padding: 1.5rem;
}

.subscription-membership-template .total-price-section {
	color: #208490;
	border-top-color: #208490;
}

/* Add to cart button styling */
.subscription-membership-template .single_add_to_cart_button {
	background-color: #208490 !important;
	color: #ffffff !important;
	border: none !important;
	padding: 14px 32px !important;
	font-size: 1.1rem !important;
	font-weight: 600 !important;
	border-radius: 32px !important;
	width: 100%;
	margin-top: 20px;
	transition: all 0.2s ease !important;
	cursor: pointer;
}

.subscription-membership-template .single_add_to_cart_button:hover {
	background-color: #1a6f7a !important;
	transform: translateY(-2px);
	box-shadow: 0 4px 16px rgba(32, 132, 144, 0.25);
}

.subscription-membership-template .single_add_to_cart_button:disabled,
.subscription-membership-template .single_add_to_cart_button.disabled {
	background-color: #a0aec0 !important;
	cursor: not-allowed;
	transform: none;
	box-shadow: none;
}

/* WooCommerce Variation form adjustments */
.subscription-membership-template .variations_form {
	margin: 0;
}

.subscription-membership-template .single_variation_wrap {
	margin-top: 20px;
}

.subscription-membership-template .woocommerce-variation {
	margin-bottom: 15px;
}

.subscription-membership-template .woocommerce-variation-price {
	display: none; /* Price shown in header */
}

/* Hide quantity input for subscriptions (handled by team size) */
.subscription-membership-template .quantity {
	display: none;
}


/* Hide WooCommerce elements not needed */
.subscription-membership-template .woocommerce-product-gallery,
.subscription-membership-template .product_meta,
.subscription-membership-template .woocommerce-tabs,
.subscription-membership-template .related.products,
.subscription-membership-template .up-sells,
.subscription-membership-template .entry-summary > .price,
.subscription-membership-template .woocommerce-product-details__short-description {
	display: none !important;
}

/* Notices styling within subscription template */
.subscription-membership-template .woocommerce-message,
.subscription-membership-template .woocommerce-error,
.subscription-membership-template .woocommerce-info {
	margin-bottom: 20px;
	border-radius: 8px;
}

/* noUiSlider color overrides to match Arival brand */
.subscription-membership-template .noUi-connect {
	background: linear-gradient(90deg, #208490, #1a6f7a);
}

.subscription-membership-template .noUi-handle {
	background: #208490;
	box-shadow: 0 3px 8px rgba(32, 132, 144, 0.4);
}

.subscription-membership-template .noUi-handle:hover {
	background: #1a6f7a;
	box-shadow: 0 4px 12px rgba(32, 132, 144, 0.5);
}

.subscription-membership-template .noUi-handle.noUi-active {
	background: #0e3c52;
	box-shadow: 0 6px 16px rgba(32, 132, 144, 0.6);
}

.subscription-membership-template .noUi-tooltip {
	background: #208490;
}

.subscription-membership-template .noUi-tooltip::after {
	border-top-color: #208490;
}

/* Responsive Design for Subscription Template */
@media (max-width: 768px) {
	.subscription-header-banner {
		padding: 40px 15px 60px;
	}
	
	.subscription-main-content {
		padding: 0 15px;
		margin-top: -30px;
	}
	
	.subscription-form-wrapper {
		padding: 25px 20px;
		border-radius: 10px;
	}
	
	.subscription-upsell-section {
		padding: 20px;
	}
}

@media (max-width: 480px) {
	.subscription-header-banner {
		padding: 30px 15px 50px;
	}
	
	.subscription-back-link {
		margin-bottom: 16px;
	}
	
	.subscription-form-wrapper {
		padding: 20px 15px;
	}
	
	.subscription-membership-template .single_add_to_cart_button {
		padding: 12px 24px !important;
	}
}

/* ========================================
   Subscription Product Page - Enhanced Sections
   ======================================== */

/* Header Description - White text below title */
.subscription-product-description {
	color: #ffffff;
	margin: 0 0 20px 0;
	max-width: 600px;
	margin-left: auto;
	margin-right: auto;
}

/* Volume Discount Message */
.subscription-volume-discount-message {
	display: flex;
	align-items: center;
	gap: 12px;
	background: linear-gradient(135deg, #e8f7f9 0%, #d4f0f3 100%);
	border: 1px solid #208490;
	border-radius: 8px;
	padding: 16px 20px;
	margin-bottom: 24px;
	color: #0e3c52;
	font-size: 12px;
	line-height: 1.5;
}

.subscription-volume-discount-message i {
	color: #208490;
	font-size: 1.25rem;
	flex-shrink: 0;
}

/* Plan Details Accordion */
.subscription-plan-details-accordion {
	background: #ffffff;
	border-radius: 12px;
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.12);
	margin-bottom: 30px;
	overflow: hidden;
}

.plan-details-toggle {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	padding: 20px 24px;
	background: transparent;
	border: none;
	cursor: pointer;
	text-align: left;
	transition: background-color 0.2s ease;
}

.plan-details-toggle:hover {
	background: #f8fafc;
}

.plan-details-heading {
	font-weight: 600;
	color: #2d3748;
}

.plan-details-icon {
	color: #208490;
	font-size: 1rem;
	transition: transform 0.3s ease;
}

.plan-details-toggle[aria-expanded="true"] .plan-details-icon {
	transform: rotate(180deg);
}

.plan-details-content {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.4s ease;
	padding: 0 24px;
}

.plan-details-content[aria-hidden="false"] {
	padding: 24px;
}

/* Plan Details Checkmark Lists */
.plan-details-content ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
}

.plan-details-content ul li {
	position: relative;
	padding-left: 32px;
	margin-bottom: 12px;
	line-height: 1.5;
	color: #4a5568;
	display: block;
}

.plan-details-content ul li::before {
	font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f00c";
    color: #ff9d19;
    position: absolute;
    left: 0;
    top: 2px;
    font-size: 1em;
    line-height: 1.5;
}

/* Remove default WordPress list styling that may add bullets */
.plan-details-content ul li::marker {
	content: none;
	display: none;
}

.plan-details-content ul li:last-child {
	margin-bottom: 0;
}

/* Nested lists in plan details */
.plan-details-content ul ul {
	margin-top: 10px;
	margin-left: 16px;
}

.plan-details-content ul ul li::before {
	font-size: 0.85rem;
}

/* Upsell Section Enhanced */
.subscription-upsells-container {
	margin-top: 30px;
}

.subscription-upsell-section {
	background: #ffffff;
	border-radius: 12px;
	padding: 30px;
	margin-bottom: 20px;
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.12);
}

.subscription-upsell-section:last-child {
	margin-bottom: 0;
}

.upsell-content h3 {
	color: #2d3748;
	font-weight: 600;
	margin: 0 0 12px 0;
}

.upsell-content .upsell-description {
	color: #4a5568;
	margin-bottom: 20px;
}

.upsell-content .upsell-description p:last-child {
	margin-bottom: 0;
}

/* Upsell Button - Orange style */
.upsell-content .upsell-button {
	display: inline-block;
	margin-top: 16px;
	background-color: #ff9d19 !important;
	border-color: #ff9d19 !important;
	color: #ffffff !important;
	padding: 5px 20px !important;
	font-size: 0.9rem !important;
	min-width: auto !important;
}

.upsell-content .upsell-button:hover {
	background-color: #e88a0f !important;
	border-color: #e88a0f !important;
	color: #ffffff !important;
}

/* Ensure hidden upsells are not displayed initially */
.subscription-upsell-section[data-operator-type] {
	display: none;
}

.subscription-upsell-section.upsell-visible {
	display: block;
}

/* Show all upsells when JS hasn't initialized yet (fallback) */
.subscription-upsells-container[data-upsells-initialized="false"] .subscription-upsell-section[data-operator-type="all"] {
	display: block;
}

/* Responsive adjustments for new sections */
@media (max-width: 768px) {
	.subscription-volume-discount-message {
		flex-direction: column;
		text-align: center;
		gap: 8px;
	}
	
	.plan-details-toggle {
		padding: 16px 20px;
	}
	
	.plan-details-content[aria-hidden="false"] {
		padding: 20px;
	}
	
	.plan-details-content ul li {
		padding-left: 28px;
	}
	
	.subscription-upsell-section {
		padding: 24px 20px;
	}
}

@media (max-width: 480px) {
	.subscription-volume-discount-message {
		padding: 14px 16px;
	}
	
	.plan-details-toggle {
		padding: 14px 16px;
	}
	
	.plan-details-content[aria-hidden="false"] {
		padding: 16px;
	}
	
	.upsell-content .upsell-button {
		width: 100%;
		text-align: center;
	}
}

/* ==========================================================================
   GROUPED MEMBERSHIP TEMPLATE (Upgrade/Downgrade Path)
   ========================================================================== */

.grouped-membership-template {
	background-color: #f5f5f5;
	min-height: 100vh;
}

/* Override content container width for grouped template */
.grouped-membership-template .subscription-content-container {
	width: 100%;
	max-width: 1280px;
}

/* Membership Cards Container */
.membership-cards-container {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	margin-top: 0;
	align-items: start; /* Prevent cards from stretching to match height */
}

/* Before initialization - show all cards, hide after JS filters */
.membership-cards-container[data-initialized="false"] .membership-card {
	display: flex;
}

.membership-cards-container[data-initialized="true"] .membership-card[data-hidden="true"] {
	display: none;
}

/* Individual Membership Card */
.membership-card {
	display: flex;
	flex-direction: column;
	background: #ffffff;
	border-radius: 12px;
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.12);
	overflow: hidden;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.membership-card:not(.current-plan) {
    margin-top: 48px;
}

.membership-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.16);
}

/* Current Plan Highlight */
.membership-card.current-plan {
	border: 2px solid #208490;
	position: relative;
}

/* Current Plan Badge - Full width at top */
.current-plan-badge {
	display: block;
	width: 100%;
	background: #208490;
	color: #ffffff;
	padding: 12px 20px;
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1px;
	text-align: center;
	margin: 0;
	border-radius: 0;
}

/* Card Content */
.membership-card-content {
	padding: 28px;
	flex-grow: 1;
	display: flex;
	flex-direction: column;
}

.membership-card-title {
	font-size: 1.5rem !important;
	font-weight: 700 !important;
	color: #0e3c52 !important;
	margin: 0 0 16px 0 !important;
	text-transform: none !important;
}

.membership-card-price {
	margin-bottom: 24px;
}

.membership-card-price .woocommerce-Price-amount {
	font-size: 1.75rem;
	font-weight: 700;
	color: #208490;
}

.membership-card-price .subscription-details {
	font-size: 0.875rem;
	color: #666666;
}

.membership-card-actions {
	margin-top: auto;
}

.membership-card-btn {
	display: block;
	width: 100%;
	text-align: center;
	padding: 16px 24px;
	font-size: 1.125rem;
	font-weight: 600;
	border-radius: 8px;
	text-decoration: none;
	transition: all 0.2s ease;
}

a.arival-btn.membership-card-btn {
    color: #ffffff !important;
    border-color: #208490;
}

a.arival-btn.membership-card-btn:hover {
    color: #208490 !important;
}

.membership-card-btn:not(.current-plan-btn) {
	background-color: #208490;
	color: #ffffff;
}

.membership-card-btn:not(.current-plan-btn):hover {
	background-color: #1a6b75;
	color: #ffffff;
}

.membership-card-btn.current-plan-btn {
	background-color: #e8f4f5;
	color: #208490;
	cursor: default;
	border: 2px solid #208490;
}

/* Plan Details Accordion in Card */
.membership-card-accordion {
	border-top: 1px solid #e5e5e5;
	margin: 0;
	border-radius: 0 0 12px 12px;
}

.membership-card-accordion .plan-details-toggle {
	border-radius: 0 0 12px 12px;
}

.membership-card-accordion .plan-details-content[aria-hidden="false"] {
	border-radius: 0 0 12px 12px;
}

/* Back Link as Button */
.subscription-back-link,
button.subscription-back-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background-color: #ffffff;
	color: #208490;
	padding: 8px 20px;
	border-radius: 24px;
	font-size: 0.875rem;
	font-weight: 500;
	text-decoration: none;
	border: none;
	cursor: pointer;
	transition: all 0.2s ease;
	margin-bottom: 16px;
}

.subscription-back-link:hover,
button.subscription-back-link:hover {
	background-color: #f0f9fa;
	color: #1a6b75;
}

/* Responsive - Tablet */
@media (max-width: 1024px) {
	.membership-cards-container {
		grid-template-columns: repeat(2, 1fr);
		gap: 20px;
	}
	
	.grouped-membership-template .subscription-content-container {
		max-width: 100%;
	}
}

/* Responsive - Mobile */
@media (max-width: 768px) {
	.membership-cards-container {
		grid-template-columns: 1fr;
		gap: 16px;
	}
	
	.membership-card-content {
		padding: 20px;
	}
	
	.membership-card-title {
		font-size: 1.25rem;
	}
	
	.membership-card-price .woocommerce-Price-amount {
		font-size: 1.5rem;
	}
	
	.membership-card-btn {
		padding: 14px 20px;
		font-size: 1rem;
	}
	
	.current-plan-badge {
		padding: 10px 16px;
		font-size: 0.8125rem;
	}
}

/* ========================================
   Download Alert Bar
   Post-download notification
   ======================================== */

.arival-download-alert {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 99999;
	background: linear-gradient(135deg, #208490 0%, #1a6f7a 100%);
	color: #ffffff;
	padding: 0;
	transform: translateY(-100%);
	opacity: 0;
	transition: transform 0.3s ease, opacity 0.3s ease;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.arival-download-alert.is-visible {
	transform: translateY(0);
	opacity: 1;
}

.arival-download-alert.is-dismissing {
	transform: translateY(-100%);
	opacity: 0;
}

.arival-download-alert .download-alert-content {
	max-width: 1400px;
	margin: 0 auto;
	padding: 10px 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 14px;
	flex-wrap: wrap;
}

.arival-download-alert .download-alert-icon {
	font-size: 1.5rem;
	flex-shrink: 0;
}

.arival-download-alert .download-alert-icon i {
	color: #ffffff;
}

.arival-download-alert .download-alert-message {
	font-size: 1.125rem;
	font-weight: 500;
	line-height: 1.4;
	text-align: center;
}

.arival-download-alert .download-alert-link {
	color: #ffffff;
	text-decoration: underline;
	font-weight: 600;
	margin-left: 4px;
	font-size: 1.125rem;
	transition: opacity 0.2s ease;
}

.arival-download-alert .download-alert-link:hover {
	opacity: 0.85;
	color: #ffffff;
}

.arival-download-alert .download-alert-dismiss {
	background: transparent;
	border: none;
	color: #ffffff;
	cursor: pointer;
	padding: 6px 10px;
	margin-left: auto;
	opacity: 0.8;
	transition: opacity 0.2s ease;
	flex-shrink: 0;
}

.arival-download-alert .download-alert-dismiss:hover {
	opacity: 1;
}

.arival-download-alert .download-alert-dismiss i {
	font-size: 1.25rem;
}

/* Responsive - Download Alert */
@media (max-width: 768px) {
	.arival-download-alert .download-alert-content {
		padding: 10px 14px;
		gap: 10px;
	}
	
	.arival-download-alert .download-alert-message {
		font-size: 1rem;
	}
	
	.arival-download-alert .download-alert-link {
		display: block;
		margin-left: 0;
		margin-top: 4px;
		font-size: 1rem;
	}
}

/* ========================================
   Already Downloaded Notice
   Shows when user has previously purchased
   ======================================== */

.already-downloaded-notice {
	display: flex;
	align-items: center;
	gap: 14px;
	background: linear-gradient(135deg, #e8f7f9 0%, #d4f0f3 100%);
	border: 1px solid #208490;
	border-left: 4px solid #208490;
	border-radius: 6px;
	padding: 16px 20px;
	margin-bottom: 24px;
	font-size: 1rem;
	line-height: 1.5;
	color: #0e3c52;
}

.already-downloaded-notice .notice-icon {
	color: #208490;
	font-size: 1.35rem;
	flex-shrink: 0;
}

.already-downloaded-notice .notice-text {
	flex: 1;
	font-size: 1rem;
}

.already-downloaded-notice .notice-text a {
	color: #208490;
	font-weight: 600;
	text-decoration: none;
	white-space: nowrap;
	font-size: 1rem;
}

.already-downloaded-notice .notice-text a:hover {
	text-decoration: underline;
}

/* Responsive - Already Downloaded Notice */
@media (max-width: 768px) {
	.already-downloaded-notice {
		padding: 14px 16px;
		font-size: 0.95rem;
	}
	
	.already-downloaded-notice .notice-text {
		font-size: 0.95rem;
	}
	
	.already-downloaded-notice .notice-text a {
		display: block;
		margin-top: 4px;
		font-size: 0.95rem;
	}
}

/* ========================================
   Free Download Button & Pricing
   ======================================== */

.single-product .custom-download-template .product-price--free .free-price {
	color: #208490;
	font-weight: 600;
	font-size: 1.1rem;
}

.free-download-button-wrapper {
	margin-top: 16px;
}

.product-price.product-price--free, #download-main .download-top .page-subtitle {
    margin-bottom: 16px !important;
}

#download-main .download-top {
    padding-bottom: 32px;
}

.single-product .custom-download-template .arival-free-download-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 12px 28px;
	border-radius: 32px;
	font-size: 1rem;
	font-weight: 600;
	background-color: #208490 !important;
	border: 2px solid #208490;
	color: #ffffff;
	text-align: center;
	min-width: 180px;
	text-decoration: none;
	transition: all 0.3s ease;
	cursor: pointer;
}

.single-product .custom-download-template .arival-free-download-btn:hover {
	background-color: #1a6f7a !important;
	border-color: #1a6f7a;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(32, 132, 144, 0.25);
}

.single-product .custom-download-template .arival-free-download-btn:disabled,
.single-product .custom-download-template .arival-free-download-btn.is-loading {
	background-color: #a0aec0 !important;
	border-color: #a0aec0;
	cursor: not-allowed;
	transform: none;
	box-shadow: none;
}

.single-product .custom-download-template .arival-free-download-btn .btn-loading {
	display: none;
}

.single-product .custom-download-template .arival-free-download-btn.is-loading .btn-text {
	display: none;
}

.single-product .custom-download-template .arival-free-download-btn.is-loading .btn-loading {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.single-product .custom-download-template .arival-free-download-btn .fa-spinner {
	animation: fa-spin 1s linear infinite;
}

@keyframes fa-spin {
	0% {
		transform: rotate(0deg);
	}
	100% {
		transform: rotate(360deg);
	}
}

/* Responsive - Free Download Button */
@media (max-width: 768px) {
	.single-product .custom-download-template .arival-free-download-btn {
		width: 100%;
		padding: 14px 24px;
	}
}

/* ========================================
   Checkout - Subscription Switch Clarity
   ======================================== */

/* Today's Payment Section */
.arival-checkout-today-payment {
	background: #f0fdf4;
	border: 2px solid #22c55e;
	border-radius: 12px;
	padding: 20px;
	margin-bottom: 24px;
}

.arival-checkout-today-payment .section-label {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 0.85em;
	font-weight: 600;
	color: #166534;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	margin-bottom: 12px;
}

.arival-checkout-today-payment .section-label::before {
	content: "✓";
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 20px;
	height: 20px;
	background: #22c55e;
	color: white;
	border-radius: 50%;
	font-size: 12px;
}

.arival-checkout-today-payment .amount {
	font-size: 2em;
	font-weight: 700;
	color: #166534;
}

.arival-checkout-today-payment .description {
	font-size: 0.9em;
	color: #4a5568;
	margin-top: 8px;
}

/* Credit Section (for downgrades) */
.arival-checkout-credit {
	background: #fefce8;
	border: 2px solid #eab308;
	border-radius: 12px;
	padding: 20px;
	margin-bottom: 16px;
}

.arival-checkout-credit .section-label {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 0.85em;
	font-weight: 600;
	color: #854d0e;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	margin-bottom: 12px;
}

.arival-checkout-credit .section-label::before {
	content: "💰";
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 20px;
	height: 20px;
	font-size: 14px;
}

.arival-checkout-credit .amount {
	font-size: 2em;
	font-weight: 700;
	color: #854d0e;
}

.arival-checkout-credit .description {
	font-size: 0.9em;
	color: #713f12;
	margin-top: 8px;
	line-height: 1.5;
}

/* No Payment Section (for $0 checkout) */
.arival-checkout-no-payment {
	background: #f8fafc;
	border: 2px solid #e2e8f0;
	border-radius: 12px;
	padding: 20px;
	margin-bottom: 24px;
}

.arival-checkout-no-payment .section-label {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 0.85em;
	font-weight: 600;
	color: #64748b;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	margin-bottom: 12px;
}

.arival-checkout-no-payment .section-label::before {
	content: "✓";
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 20px;
	height: 20px;
	background: #94a3b8;
	color: white;
	border-radius: 50%;
	font-size: 12px;
}

.arival-checkout-no-payment .amount {
	font-size: 2em;
	font-weight: 700;
	color: #64748b;
}

.arival-checkout-no-payment .description {
	font-size: 0.9em;
	color: #64748b;
	margin-top: 8px;
	line-height: 1.5;
}

/* Future Recurring Section */
.arival-checkout-recurring {
	background: #f8fafc;
	border: 1px solid #e2e8f0;
	border-radius: 12px;
	padding: 20px;
	margin-top: 20px;
}

.arival-checkout-recurring .section-label {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 0.85em;
	font-weight: 600;
	color: #64748b;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	margin-bottom: 12px;
}

.arival-checkout-recurring .section-label::before {
	content: "↻";
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 20px;
	height: 20px;
	background: #94a3b8;
	color: white;
	border-radius: 50%;
	font-size: 12px;
}

.arival-checkout-recurring .amount {
	font-size: 1.5em;
	font-weight: 600;
	color: #334155;
}

.arival-checkout-recurring .renewal-date {
	font-size: 0.9em;
	color: #64748b;
	margin-top: 8px;
}

/* Hide default recurring totals header when our custom one is present */
.arival-checkout-recurring-wrapper .recurring-totals-header,
.arival-checkout-recurring-wrapper .shop_table.recurring-totals thead {
	display: none;
}

/* Style the recurring totals table inside our wrapper */
.arival-checkout-recurring .shop_table.recurring-totals {
	background: transparent;
	border: none;
	margin: 0;
}

.arival-checkout-recurring .shop_table.recurring-totals td,
.arival-checkout-recurring .shop_table.recurring-totals th {
	padding: 8px 0;
	border: none;
	background: transparent;
}

/* Order review table styling for subscription switches */
.woocommerce-checkout-review-order-table .subscription-switch-info {
	font-size: 0.9em;
	color: #64748b;
	padding: 8px 0;
}

.woocommerce-checkout-review-order-table .subscription-switch-info strong {
	color: #334155;
}

/* Seat change details styling in checkout */
.woocommerce-checkout-review-order-table .seat-change-details {
	background: #f1f5f9;
	border-radius: 8px;
	padding: 12px;
	margin: 8px 0;
	font-size: 0.9em;
}

.woocommerce-checkout-review-order-table .seat-change-details .change-arrow {
	color: #22c55e;
	font-weight: 600;
}

/* Proration explanation text */
.arival-proration-explanation {
	background: #eff6ff;
	border-left: 4px solid #3b82f6;
	padding: 12px 16px;
	margin: 16px 0;
	font-size: 0.9em;
	color: #1e40af;
	border-radius: 0 8px 8px 0;
}

.arival-proration-explanation strong {
	display: block;
	margin-bottom: 4px;
}

/* Proration Calculation Breakdown */
.arival-proration-breakdown {
	background: #ffffff;
	border: 1px solid #e2e8f0;
	border-radius: 12px;
	padding: 20px;
	margin-bottom: 16px;
}

.arival-proration-breakdown .breakdown-header {
	font-size: 0.9em;
	font-weight: 600;
	color: #64748b;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	margin-bottom: 16px;
	padding-bottom: 12px;
	border-bottom: 1px solid #e2e8f0;
}

.arival-proration-breakdown .breakdown-section {
	margin-bottom: 16px;
	padding-bottom: 16px;
	border-bottom: 1px dashed #e2e8f0;
}

.arival-proration-breakdown .breakdown-section:last-child {
	margin-bottom: 0;
	padding-bottom: 0;
	border-bottom: none;
}

.arival-proration-breakdown .breakdown-label {
	font-size: 0.8em;
	font-weight: 600;
	color: #94a3b8;
	text-transform: uppercase;
	letter-spacing: 0.3px;
	margin-bottom: 8px;
}

.arival-proration-breakdown .breakdown-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 6px 0;
	font-size: 0.95em;
	color: #334155;
}

.arival-proration-breakdown .breakdown-row .value {
	font-weight: 600;
	color: #1e293b;
}

.arival-proration-breakdown .breakdown-row.credit .value.negative {
	color: #16a34a;
}

.arival-proration-breakdown .breakdown-row.charge .value {
	color: #334155;
}

.arival-proration-breakdown .breakdown-row.time-remaining {
	background: #f8fafc;
	padding: 10px 12px;
	border-radius: 8px;
	margin-bottom: 8px;
}

.arival-proration-breakdown .breakdown-row.time-remaining .value {
	font-size: 0.9em;
	color: #64748b;
}

.arival-proration-breakdown .proration-calc {
	background: #fafbfc;
	margin-left: -20px;
	margin-right: -20px;
	padding-left: 20px;
	padding-right: 20px;
	padding-top: 16px;
	border-radius: 0 0 12px 12px;
}

/* Visual separator between calculation and result */
.arival-proration-breakdown + .arival-checkout-today-payment {
	position: relative;
}

.arival-proration-breakdown + .arival-checkout-today-payment::before {
	content: "=";
	position: absolute;
	top: -24px;
	left: 50%;
	transform: translateX(-50%);
	width: 32px;
	height: 32px;
	background: #208490;
	color: white;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	font-size: 1.2em;
}
