/* ==========================================================================
   Registration Form Styles - Overrides for Easy Plugin Demo
   ========================================================================== */

#epd_register_form {
	background: var(--qcd-bg);
	border: 1px solid var(--qcd-border);
	border-radius: var(--qcd-radius-lg);
	padding: 36px 32px;
	box-shadow: var(--qcd-shadow-lg);
}

#epd_register_form .epd_register_head {
	font-family: var(--qcd-font-heading);
	font-size: 22px;
	font-weight: 600;
	color: var(--qcd-text);
	text-align: center;
	margin-bottom: 28px;
	line-height: 1.3;
}

#epd_register_form fieldset {
	border: none;
	padding: 0;
	margin: 0;
}

#epd_register_form p {
	margin-bottom: 18px;
}

#epd_register_form label {
	display: block;
	font-size: 14px;
	font-weight: 600;
	color: var(--qcd-text);
	margin-bottom: 6px;
	letter-spacing: 0.01em;
}

#epd_register_form .epd-input,
#epd_register_form input[type="text"],
#epd_register_form input[type="email"] {
	width: 100%;
	padding: 12px 16px;
	font-family: var(--qcd-font-body);
	font-size: 15px;
	color: var(--qcd-text);
	background: var(--qcd-bg);
	border: 1.5px solid var(--qcd-border);
	border-radius: var(--qcd-radius);
	outline: none;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	-webkit-appearance: none;
}

#epd_register_form .epd-input:focus,
#epd_register_form input[type="text"]:focus,
#epd_register_form input[type="email"]:focus {
	border-color: var(--qcd-primary);
	box-shadow: 0 0 0 3px rgba(69, 141, 199, 0.15);
}

#epd_register_form .epd-input::placeholder,
#epd_register_form input::placeholder {
	color: #B0B0B0;
}

#epd_register_form #epd-register-submit,
#epd_register_form input[type="submit"],
#epd_register_form .button {
	width: 100%;
	padding: 14px 24px;
	font-family: var(--qcd-font-body);
	font-size: 16px;
	font-weight: 600;
	color: #fff;
	background: var(--qcd-navy);
	border: 2px solid var(--qcd-navy);
	border-radius: var(--qcd-radius);
	cursor: pointer;
	transition: all 0.3s ease;
	position: relative;
	overflow: hidden;
	z-index: 1;
	letter-spacing: 0.02em;
	margin-top: 8px;
	-webkit-appearance: none;
}

#epd_register_form #epd-register-submit::before,
#epd_register_form #epd-register-submit::after {
	content: '';
	position: absolute;
	top: 0;
	width: 0;
	height: 100%;
	background: var(--qcd-navy-hover);
	transition: width 0.3s ease-out;
	z-index: -1;
	transform: skewX(-50deg);
}

#epd_register_form #epd-register-submit::before {
	left: -10%;
}

#epd_register_form #epd-register-submit::after {
	right: -10%;
}

#epd_register_form #epd-register-submit:hover::before,
#epd_register_form #epd-register-submit:hover::after {
	width: 65%;
}

#epd_register_form #epd-register-submit:hover {
	color: #fff;
}

/* Alert styles */
.epd_alert {
	padding: 14px 18px;
	border-radius: var(--qcd-radius);
	font-size: 14px;
	font-weight: 500;
	margin-bottom: 20px;
	line-height: 1.5;
}

.epd_alert_error {
	background: #FEF2F2;
	color: #991B1B;
	border: 1px solid #FECACA;
}

.epd_alert_success {
	background: #F0FDF4;
	color: #166534;
	border: 1px solid #BBF7D0;
}

.epd_alert_warn {
	background: #FFFBEB;
	color: #92400E;
	border: 1px solid #FDE68A;
}

.epd_hidden {
	display: none;
}

/* reCAPTCHA alignment */
#epd-recaptcha {
	display: flex;
	justify-content: center;
	margin-bottom: 16px;
}

/* Site list (for returning users) */
.epd_site_list {
	background: var(--qcd-bg);
	border: 1px solid var(--qcd-border);
	border-radius: var(--qcd-radius-lg);
	padding: 24px;
	margin-bottom: 24px;
}

.epd_site_list h3 {
	font-family: var(--qcd-font-heading);
	font-size: 18px;
	font-weight: 600;
	margin-bottom: 16px;
}

.epd_site_list table {
	width: 100%;
	border-collapse: collapse;
}

.epd_site_list th,
.epd_site_list td {
	padding: 10px 12px;
	text-align: left;
	font-size: 14px;
	border-bottom: 1px solid var(--qcd-border);
}

.epd_site_list th {
	font-weight: 600;
	color: var(--qcd-text);
}

.epd_site_list td {
	color: var(--qcd-text-muted);
}

.epd_site_list a {
	color: var(--qcd-primary);
	font-weight: 500;
}

/* Loading state */
#epd_register_form.loading #epd-register-submit {
	opacity: 0.7;
	pointer-events: none;
}

@media (max-width: 480px) {
	#epd_register_form {
		padding: 24px 20px;
	}

	#epd_register_form .epd_register_head {
		font-size: 20px;
	}
}
