/* WP Registration Suite — Front-end modern form styling (Tutor LMS inspired) */
.wprs-form-wrapper {
	--wprs-primary: #5b2eff;
	--wprs-primary-dark: #4521d6;
	--wprs-bg: #f7f7fb;
	--wprs-border: #e6e6ef;
	--wprs-text: #1d1d2b;
	--wprs-muted: #6f6f87;
	--wprs-danger: #e6483f;
	--wprs-success: #1ba672;
	display: flex;
	justify-content: center;
	padding: 32px 16px;
	box-sizing: border-box;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

.wprs-form-card {
	width: 100%;
	max-width: 620px;
	background: #fff;
	border-radius: 18px;
	box-shadow: 0 8px 30px rgba(20, 20, 43, 0.08);
	border: 1px solid var(--wprs-border);
	padding: 36px 32px;
}

.wprs-form-header { margin-bottom: 22px; text-align: center; }
.wprs-form-title {
	font-size: 26px;
	font-weight: 700;
	color: var(--wprs-text);
	margin: 0 0 6px;
}

.wprs-fields-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 18px;
}

.wprs-field-group { display: flex; flex-direction: column; gap: 6px; }
.wprs-width-full { flex: 1 1 100%; }
.wprs-width-half { flex: 1 1 calc(50% - 9px); }
@media (max-width: 520px) { .wprs-width-half { flex: 1 1 100%; } }

.wprs-field-group label {
	font-size: 13.5px;
	font-weight: 600;
	color: var(--wprs-text);
}
.wprs-required { color: var(--wprs-danger); }

.wprs-input,
.wprs-form select.wprs-input {
	width: 100%;
	padding: 12px 14px;
	border-radius: 10px;
	border: 1.5px solid var(--wprs-border);
	background: var(--wprs-bg);
	font-size: 14.5px;
	color: var(--wprs-text);
	transition: border-color .15s ease, box-shadow .15s ease;
	box-sizing: border-box;
}
.wprs-input:focus {
	outline: none;
	border-color: var(--wprs-primary);
	box-shadow: 0 0 0 3px rgba(91,46,255,0.12);
	background: #fff;
}
textarea.wprs-input { resize: vertical; min-height: 90px; }

.wprs-heading-block h3 {
	margin: 6px 0 0;
	font-size: 17px;
	font-weight: 700;
	border-bottom: 1px solid var(--wprs-border);
	padding-bottom: 8px;
}

/* Radio / Checkbox */
.wprs-radio-group { display: flex; gap: 16px; flex-wrap: wrap; }
.wprs-radio-label, .wprs-checkbox-label {
	display: flex; align-items: center; gap: 6px;
	font-size: 14px; font-weight: 500; color: var(--wprs-text);
	cursor: pointer;
}

/* Phone / WhatsApp */
.wprs-phone-wrap { position: relative; display: flex; align-items: center; }
.wprs-phone-icon {
	position: absolute; left: 12px; font-size: 16px; pointer-events: none;
}
.wprs-phone-wrap .wprs-whatsapp { padding-left: 38px; }

/* File upload */
.wprs-upload-wrap { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.wprs-upload-btn {
	display: inline-flex; align-items: center; gap: 8px;
	padding: 11px 16px; border-radius: 10px;
	background: var(--wprs-bg); border: 1.5px dashed var(--wprs-primary);
	color: var(--wprs-primary); font-weight: 600; font-size: 13.5px;
	cursor: pointer; transition: background .15s ease;
}
.wprs-upload-btn:hover { background: #efeaff; }
.wprs-upload-icon { font-size: 15px; }
.wprs-file-input { display: none; }
.wprs-file-name { font-size: 12.5px; color: var(--wprs-muted); }

/* Submit button */
.wprs-submit-btn {
	margin-top: 26px;
	width: 100%;
	padding: 14px 18px;
	border: none;
	border-radius: 12px;
	background: linear-gradient(135deg, var(--wprs-primary), #8a5cff);
	color: #fff;
	font-size: 15.5px;
	font-weight: 700;
	letter-spacing: .2px;
	cursor: pointer;
	display: flex; align-items: center; justify-content: center; gap: 10px;
	transition: transform .12s ease, box-shadow .12s ease;
	box-shadow: 0 8px 20px rgba(91,46,255,0.25);
}
.wprs-submit-btn:hover { transform: translateY(-1px); box-shadow: 0 12px 26px rgba(91,46,255,0.32); }
.wprs-submit-btn:disabled { opacity: .7; cursor: not-allowed; transform:none; }

.wprs-spinner {
	width: 16px; height: 16px; border-radius: 50%;
	border: 2.5px solid rgba(255,255,255,0.45);
	border-top-color: #fff;
	animation: wprs-spin 0.7s linear infinite;
}
@keyframes wprs-spin { to { transform: rotate(360deg); } }

.wprs-form-footer {
	text-align: center; margin-top: 18px; font-size: 13.5px; color: var(--wprs-muted);
}
.wprs-form-footer a { color: var(--wprs-primary); font-weight: 600; text-decoration: none; }

.wprs-alert {
	margin-bottom: 16px;
	padding: 12px 14px;
	border-radius: 10px;
	font-size: 13.5px;
	font-weight: 600;
}
.wprs-alert.wprs-alert-success { background: #e8faf2; color: var(--wprs-success); border: 1px solid #b9eed5; }
.wprs-alert.wprs-alert-error   { background: #fdecea; color: var(--wprs-danger); border: 1px solid #f7c6c2; }

.wprs-error { color: var(--wprs-danger); text-align: center; }

/* Type accents */
.wprs-type-login .wprs-form-card { max-width: 460px; }
