.form-item {
	position: relative;
	margin-bottom: 1.5rem;
}

.error-message {
	display: none;
	color: #ef4444;
	font-size: 0.875rem;
	margin-top: 0.5rem;
	animation: slideDown 0.3s ease-out;
}

.form-item.has-error .error-message {
	display: block;
}

.form-item.has-error .input,
.form-item.has-error .textarea {
	border-color: #ef4444;
	background-color: #fef2f2;
}

.form-general-error {
	background-color: #fef2f2;
	border: 1px solid #ef4444;
	color: #991b1b;
	padding: 1rem;
	border-radius: 0.5rem;
	margin-bottom: 1.5rem;
	animation: slideDown 0.3s ease-out;
}

.form-success-message {
	display: none;
	background: linear-gradient(135deg, #d1fae5 0%, #a7f3d0 100%);
	border: 2px solid #10b981;
	border-radius: 1rem;
	padding: 1.5rem 2rem;
	text-align: center;
	animation: scaleIn 0.5s ease-out;
	align-items: center;
	gap: 1rem;
	justify-content: center;
}

.form-success-message svg {
	flex-shrink: 0;
	animation: checkmark 0.6s ease-out 0.2s both;
}

.form-success-message .success-text {
	text-align: left;
}

.form-success-message h3 {
	color: #065f46;
	font-size: 1.25rem;
	margin: 0 0 0.25rem 0;
	font-weight: 600;
}

.form-success-message p {
	color: #047857;
	font-size: 0.9rem;
	margin: 0;
}

.btn-theatre.is-loading {
	pointer-events: none;
	opacity: 0.7;
}

.btn-theatre.is-loading .button-text::after {
	content: '';
	display: inline-block;
	width: 1rem;
	height: 1rem;
	margin-left: 0.5rem;
	border: 2px solid currentColor;
	border-top-color: transparent;
	border-radius: 50%;
	animation: spin 0.8s linear infinite;
}

.form-submitted .input-item {
	opacity: 0.6;
	pointer-events: none;
}

@media (max-width: 500px) {
	.form-success-message{-webkit-flex-wrap: wrap;flex-wrap: wrap;}
}

@keyframes slideDown {
	from { opacity: 0; transform: translateY(-10px); }
	to { opacity: 1; transform: translateY(0); }
}

@keyframes scaleIn {
	from { opacity: 0; transform: scale(0.9); }
	to { opacity: 1; transform: scale(1); }
}

@keyframes checkmark {
	0% { stroke-dasharray: 0 100; }
	100% { stroke-dasharray: 100 100; }
}

@keyframes spin {
	to { transform: rotate(360deg); }
}
