/**
 * OM Product Page Essentials - Wait List Module Styles
 */

.om-ppe-waitlist-container {
	position: relative;
	margin: 20px 0;
	padding: 20px;
	background-color: #f8f9fa;
	border: 1px solid #e9ecef;
	border-radius: 8px;
	opacity: 1 !important;
}

.om-ppe-waitlist-overlay {
	position: absolute !important;
	top: 0 !important;
	left: 0 !important;
	right: 0 !important;
	bottom: 0 !important;
	display: none !important; /* Hidden by default, shown via JS when loading */
	align-items: center;
	justify-content: center;
	background-color: rgba(255, 255, 255, 0.8);
	border-radius: 8px;
	z-index: 10;
}

.om-ppe-waitlist-overlay.is-loading {
	display: flex !important;
}

.om-ppe-waitlist-loader svg {
	width: 40px;
	height: 40px;
	color: #0073aa;
	animation: om-ppe-waitlist-spin 1s linear infinite;
}

@keyframes om-ppe-waitlist-spin {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(360deg);
	}
}

.om-ppe-waitlist-form {
	display: flex;
	flex-direction: column;
	gap: 15px;
	opacity: 1 !important;
}

.om-ppe-waitlist-title {
	margin: 0 0 5px 0 !important;
	font-size: 16px !important;
	font-weight: 600 !important;
	color: #333 !important;
	line-height: 1.4 !important;
	opacity: 1 !important;
}

.om-ppe-waitlist-field {
	display: flex;
	flex-direction: column;
	gap: 5px;
}

.om-ppe-waitlist-field label {
	font-size: 14px !important;
	font-weight: 500 !important;
	color: #555 !important;
	opacity: 1 !important;
}

.om-ppe-waitlist-field label .required {
	color: #e74c3c;
	font-weight: 700;
}

.om-ppe-waitlist-field input[type="email"] {
	width: 100%;
	padding: 12px 15px;
	font-size: 14px;
	border: 1px solid #ddd;
	border-radius: 4px;
	background-color: #fff;
	transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.om-ppe-waitlist-field input[type="email"]:focus {
	border-color: #0073aa;
	outline: none;
	box-shadow: 0 0 0 2px rgba(0, 115, 170, 0.2);
}

.om-ppe-waitlist-field input[type="email"]::placeholder {
	color: #999;
}

.om-ppe-waitlist-submit {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 12px 25px !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	color: #ffffff !important;
	background-color: #0073aa !important;
	border: none !important;
	border-radius: 4px !important;
	cursor: pointer !important;
	transition: background-color 0.3s ease, transform 0.2s ease;
	align-self: flex-start;
	opacity: 1 !important;
}

.om-ppe-waitlist-submit:hover {
	background-color: #005a87;
	transform: translateY(-1px);
}

.om-ppe-waitlist-submit:active {
	transform: translateY(0);
}

.om-ppe-waitlist-submit:disabled {
	opacity: 0.6;
	cursor: not-allowed;
	transform: none;
}

/* Message Styles */
.om-ppe-waitlist-message {
	display: none; /* Hidden by default, shown via JS */
	margin-top: 10px;
	padding: 12px 15px;
	border-radius: 4px;
	font-size: 14px;
	line-height: 1.5;
}

.om-ppe-waitlist-message.success {
	background-color: #d4edda;
	border: 1px solid #c3e6cb;
	color: #155724;
}

.om-ppe-waitlist-message.error {
	background-color: #f8d7da;
	border: 1px solid #f5c6cb;
	color: #721c24;
}

/* Variable Product - Hidden by default for variable products */
.product-type-variable .om-ppe-waitlist-container {
	display: none;
}

.product-type-variable .om-ppe-waitlist-container.show {
	display: block;
}

/* Responsive */
@media (max-width: 768px) {
	.om-ppe-waitlist-container {
		padding: 15px;
	}

	.om-ppe-waitlist-submit {
		width: 100%;
		justify-content: center;
	}
}

/* Theme Compatibility - Flatsome */
.single-product.flavor-flavor .om-ppe-waitlist-container {
	margin-top: 15px;
}

/* Theme Compatibility - Astra */
.ast-single-post .om-ppe-waitlist-container {
	margin-bottom: 20px;
}

/* Theme Compatibility - Storefront */
.storefront .om-ppe-waitlist-container {
	border-radius: 0;
}

/* Theme Compatibility - OceanWP */
.single-product.flavor-flavor .om-ppe-waitlist-submit {
	border-radius: 0;
}
