/* UTJD Book Download - Frontend Styles */

.utjd-download-form-wrapper,
.utjd-unsubscribe-form-wrapper {
	max-width: 500px;
	margin: 30px auto;
	padding: 25px;
	background-color: #f9f9f9;
	border: 1px solid #ddd;
	border-radius: 4px;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.utjd-download-form-wrapper h3,
.utjd-unsubscribe-form-wrapper h3 {
	margin-top: 0;
	color: #333;
	font-size: 24px;
}

.utjd-download-form-wrapper p,
.utjd-unsubscribe-form-wrapper p {
	color: #666;
	font-size: 14px;
	line-height: 1.6;
}

/* Form Groups */
.utjd-form-group {
	margin-bottom: 20px;
}

.utjd-form-group label {
	display: block;
	margin-bottom: 8px;
	font-weight: 600;
	color: #333;
	font-size: 14px;
}

.utjd-form-group label .required {
	color: #d32f2f;
	margin-left: 4px;
}

.utjd-form-group input[type="text"],
.utjd-form-group input[type="email"],
.utjd-form-group select,
.utjd-form-group textarea {
	width: 100%;
	padding: 10px;
	border: 1px solid #ddd;
	border-radius: 4px;
	font-size: 14px;
	font-family: inherit;
	box-sizing: border-box;
	transition: border-color 0.3s;
}

.utjd-form-group input[type="text"]:focus,
.utjd-form-group input[type="email"]:focus,
.utjd-form-group select:focus,
.utjd-form-group textarea:focus {
	outline: none;
	border-color: #007cba;
	box-shadow: 0 0 0 3px rgba(0, 124, 186, 0.1);
}

.utjd-form-group input[type="checkbox"] {
	margin-right: 8px;
}

.utjd-form-group input[type="checkbox"] + label {
	display: inline;
	margin-bottom: 0;
	font-weight: 400;
}

/* Error messages */
.utjd-error-message {
	display: block;
	color: #d32f2f;
	font-size: 13px;
	margin-top: 5px;
}

.utjd-error-message.show {
	display: block;
}

/* Privacy Notice */
.utjd-privacy-notice {
	background-color: #fff9c4;
	border-left: 4px solid #fbc02d;
	padding: 15px;
	margin-bottom: 20px;
	border-radius: 2px;
}

.utjd-privacy-notice h4 {
	margin-top: 0;
	margin-bottom: 10px;
	color: #f57f17;
	font-size: 16px;
}

.utjd-privacy-notice p,
.utjd-privacy-notice ul {
	margin: 8px 0;
	font-size: 13px;
	color: #666;
	line-height: 1.5;
}

.utjd-privacy-notice ul {
	padding-left: 20px;
}

.utjd-privacy-notice li {
	margin-bottom: 5px;
}

/* Privacy section */
.utjd-privacy-section {
	margin: 20px 0;
}

/* Form actions */
.utjd-form-actions {
	margin: 25px 0;
	text-align: center;
}

.utjd-submit-button {
	background-color: #007cba;
	color: white;
	padding: 12px 30px;
	border: none;
	border-radius: 4px;
	font-size: 16px;
	font-weight: 600;
	cursor: pointer;
	transition: background-color 0.3s;
}

.utjd-submit-button:hover {
	background-color: #005a87;
}

.utjd-submit-button:active {
	transform: translateY(1px);
}

.utjd-submit-button:disabled {
	background-color: #ccc;
	cursor: not-allowed;
	opacity: 0.6;
}

/* Messages */
.utjd-message {
	padding: 15px;
	border-radius: 4px;
	margin-top: 15px;
	font-size: 14px;
	line-height: 1.6;
}

.utjd-message.success {
	background-color: #c8e6c9;
	color: #2e7d32;
	border: 1px solid #81c784;
}

.utjd-message.error {
	background-color: #ffcdd2;
	color: #c62828;
	border: 1px solid #ef9a9a;
}

.utjd-message.info {
	background-color: #bbdefb;
	color: #1565c0;
	border: 1px solid #64b5f6;
}

/* Loading state */
.utjd-loading {
	position: relative;
	opacity: 0.6;
	pointer-events: none;
}

.utjd-loading::after {
	content: "";
	position: absolute;
	width: 20px;
	height: 20px;
	top: 50%;
	left: 50%;
	margin-left: -10px;
	margin-top: -10px;
	border: 3px solid #f3f3f3;
	border-top: 3px solid #007cba;
	border-radius: 50%;
	animation: utjd-spin 1s linear infinite;
}

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

/* Honeypot */
.utjd-honeypot {
	display: none;
}

/* Responsive design */
@media (max-width: 600px) {
	.utjd-download-form-wrapper,
	.utjd-unsubscribe-form-wrapper {
		padding: 15px;
		margin: 20px 10px;
	}

	.utjd-submit-button {
		width: 100%;
	}
}

/* Accessibility improvements */
.utjd-form-group input:focus,
.utjd-form-group select:focus,
.utjd-form-group textarea:focus {
	outline: 2px solid #007cba;
	outline-offset: 2px;
}

/* Turnstile frame styling */
.cf-turnstile {
	margin: 15px 0;
	display: flex;
	justify-content: center;
}

/* reCAPTCHA styling */
.g-recaptcha {
	margin: 15px 0;
	display: flex;
	justify-content: center;
}
