/* Unified Forms CSS - Bootstrap 5 Enhanced Forms */
/* This file complements Bootstrap 5 with custom styling for modern, attractive forms */

/* ============================================================
   CSS VARIABLES - Modern Design System (Bootstrap 5 Compatible)
   ============================================================ */
:root {
	/* Primary Colors - Matched to Theme Color Scheme */
	/* Using theme's green as primary color - these will use theme colors if defined in colors.css */
	--kp-primary: var(--color-km-green, #87b501);
	--kp-primary-dark: var(--color-km-dark-green, #789a0f);
	--kp-primary-light: var(--background-light-green, #ebf6c8);
	--kp-primary-hover: var(--color-km-dark-green, #789a0f);
	--bs-primary: var(--kp-primary); /* Bootstrap override */

	/* Semantic Colors - Matched to Theme */
	--kp-secondary: var(--color-medium-dark-gray, #7b7b7b);
	--kp-success: var(--color-km-green, #87b501);
	--kp-success-light: var(--background-light-green, #ebf6c8);
	--kp-success-dark: var(--color-km-dark-green, #789a0f);
	--kp-danger: var(--red, #b90000);
	--kp-warning: var(--color-km-orange, #f37b06);
	--kp-warning-light: var(--background-light-orange, #fbcd81);
	--kp-warning-dark: var(--color-km-orange, #f37b06);
	--kp-info: var(--light-blue, #5ba7dd);
	--kp-info-light: #d1ecf1;
	--kp-info-dark: #0c5460;

	/* Neutral Colors - Matched to Theme */
	--kp-light: var(--background-light-gray, #fafafa);
	--kp-dark: var(--color-dark-gray, #292b2c);
	--kp-border: var(--border-light-gray, #ededed);
	--kp-border-hover: var(--color-medium-light-gray, #a9a9a9);
	--kp-text-muted: var(--color-medium-dark-gray, #7b7b7b);

	/* Spacing & Layout */
	--kp-border-radius: 0.5rem;
	--kp-border-radius-lg: 0.75rem;
	--kp-spacing-xs: 0.25rem;
	--kp-spacing-sm: 0.5rem;
	--kp-spacing-md: 1rem;
	--kp-spacing-lg: 1.5rem;
	--kp-spacing-xl: 2rem;

	/* Shadows - Using theme's shadow variables */
	--kp-box-shadow: 0 0.125rem 0.25rem
		var(--boxshadow-dark-10, rgba(0, 0, 0, 0.1));
	--kp-box-shadow-lg: 0 0.5rem 1rem
		var(--boxshadow-dark-15, rgba(0, 0, 0, 0.15));
	--kp-box-shadow-focus: 0 0 0 0.25rem rgba(135, 181, 1, 0.25); /* Using green primary for focus */

	/* Transitions */
	--kp-transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ============================================================
   FORM CONTAINER - Bootstrap 5 Compatible
   ============================================================ */
.kp-form-container {
	max-width: 900px;
	margin: 2rem auto;
	padding: 1.5rem;
}

@media (min-width: 768px) {
	.kp-form-container {
		padding: 2.5rem;
	}
}

/* Form Header - Modern Typography */
.kp-form-header {
	margin-bottom: 2.5rem;
	text-align: center;
}

.kp-form-header h1 {
	color: var(--kp-dark);
	margin-bottom: 0.75rem;
	font-size: 2.5rem;
	font-weight: 700;
	letter-spacing: -0.5px;
}

.kp-form-header p {
	color: var(--kp-text-muted);
	font-size: 1.125rem;
	line-height: 1.6;
	margin: 0;
}

.kp-form-header .required {
	color: var(--kp-danger);
	font-weight: 600;
}

/* ============================================================
   SECTION TITLES AND DIVIDERS
   ============================================================ */
.kp-form-section-title {
	color: var(--kp-dark);
	margin: 2rem 0 1.5rem 0 !important;
	font-size: 1.5rem;
	font-weight: 600;
	display: flex;
	align-items: center;
	gap: 0.75rem;
	width: 100% !important;
	clear: both;
}

.kp-form-section-title:first-child {
	margin-top: 0 !important;
}

.kp-form-section-title::before {
	content: "";
	width: 4px;
	height: 24px;
	background: var(--kp-primary);
	border-radius: 2px;
	flex-shrink: 0;
}

.kp-form-section-divider {
	width: 100% !important;
	height: 1px;
	background: var(--kp-border);
	margin: 2rem 0 1rem 0;
	border: none;
	clear: both;
}

/* Section Header Wrappers - 100% Width */
.tml-section_header_about_you-wrap,
.tml-section_header_account_details-wrap {
	width: 100% !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
	display: block !important;
	clear: both;
	float: none !important;
}

/* ============================================================
   BOOTSTRAP 5 FORM ENHANCEMENTS
   ============================================================ */

/* Form Controls - Enhanced Bootstrap Styles */
.form-control,
.form-select {
	border: 2px solid var(--kp-border);
	border-radius: var(--kp-border-radius);
	padding: 0.75rem 1rem;
	font-size: 1rem;
	transition: var(--kp-transition);
}

.form-control:focus,
.form-select:focus {
	border-color: var(--kp-primary);
	box-shadow: var(--kp-box-shadow-focus);
}

.form-control:hover:not(:focus):not(:disabled) {
	border-color: var(--kp-border-hover);
}

.form-control[readonly] {
	background-color: var(--kp-light);
	cursor: not-allowed;
}

/* Do not style small checkboxes (e.g. Remember Me) as large text inputs */
.theme-my-login .tml-field-wrap input[type="checkbox"].form-control {
	border: none !important;
	border-radius: 0 !important;
	padding: 0 !important;
	width: auto !important;
	height: auto !important;
	box-shadow: none !important;
	background: transparent !important;
}

/* Form Labels - Bootstrap Enhanced */
.form-label {
	font-weight: 600;
	margin-bottom: 0.5rem;
	color: var(--kp-dark);
	font-size: 0.9375rem;
	letter-spacing: 0.2px;
}

/* Form Text - Description Text */
.form-text {
	font-size: 0.875rem;
	color: var(--kp-text-muted);
	margin-top: 0.25rem;
	line-height: 1.5;
}

/* Input Groups - Enhanced */
.input-group-text {
	border: 2px solid var(--kp-border);
	border-right: none;
	background-color: var(--kp-light);
}

.input-group .form-control {
	border-left: none;
}

.input-group .form-control:focus {
	border-left: 2px solid var(--kp-primary);
}

/* Form Check and Radio - Modern Styling */
.form-check-input {
	width: 1.25rem;
	height: 1.25rem;
	border: 2px solid var(--kp-border);
	cursor: pointer;
	transition: var(--kp-transition);
}

.form-check-input:checked {
	background-color: var(--kp-primary);
	border-color: var(--kp-primary);
}

.form-check-input:focus {
	box-shadow: var(--kp-box-shadow-focus);
}

.form-check-label {
	cursor: pointer;
	margin-left: 0.5rem;
	font-size: 0.9375rem;
	color: var(--kp-dark);
}

/* ============================================================
   RADIO BUTTON BOXES - Custom Styling for Radio Groups
   ============================================================ */

/* Account Type and Grade Radio Buttons - 50% Square Boxes */
/* Styles are handled by child elements, no direct styling needed here */

.tml-field-wrap input[type="radio"] {
	/* Remove form-control styling from radio inputs */
	width: auto !important;
	height: auto !important;
	padding: 0 !important;
	margin: 0 !important;
	border: none !important;
	background: none !important;
	appearance: none;
	-moz-appearance: none;
	-webkit-appearance: none;
}

/* Hide the main field label - we'll show it differently or it's already shown */
.tml-field-wrap label.tml-label:first-of-type {
	margin-bottom: 0.5rem;
	font-weight: 600;
	display: inline-block;
}

input#rememberme {
	border: none;
	appearance: auto;
	width: auto;
	display: inline-block;
	margin-right: 15px;
}

.tml-rememberme-wrap label.tml-label {
	width: auto;
}

/* Remove line breaks */
.tml-field-wrap.tml-account_type-wrap > br,
.tml-field-wrap.tml-grade_id-wrap > br {
	display: none;
}

/* Hide radio inputs visually */
.tml-field-wrap.tml-account_type-wrap input[type="radio"],
.tml-field-wrap.tml-grade_id-wrap input[type="radio"] {
	position: absolute;
	opacity: 0;
	pointer-events: none;
	width: 0;
	height: 0;
	margin: 0;
}

/* Style labels that are for radio buttons (not the first one which is the field label),
   and subject option boxes so they visually match grade boxes */

.tml-field-wrap.tml-grade_id-wrap label.tml-label[for^="grade_id_"],
.kp-subject-option {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: calc(15% - 0.5rem); /* 50% width minus half the gap */
	aspect-ratio: 1; /* Make it square */
	min-height: 100px;
	border: 2px solid var(--kp-border);
	border-radius: var(--kp-border-radius);
	padding: 1rem;
	cursor: pointer;
	transition: var(--kp-transition);
	background: white;
	text-align: center;
	color: var(--kp-dark);
	margin: 0;
	box-sizing: border-box;
}

.tml-field-wrap.tml-account_type-wrap
	label.tml-label[for^="account_type_"]:hover,
.tml-field-wrap.tml-grade_id-wrap label.tml-label[for^="grade_id_"]:hover,
.kp-subject-option:hover {
	border-color: var(--kp-primary);
	box-shadow: var(--kp-box-shadow);
	transform: translateY(-2px);
}

/* Selected state - when radio is checked, style its associated label */
/* Use :has() for modern browsers, fallback to class-based selection via JS */
.tml-field-wrap.tml-account_type-wrap:has(
		input[id="account_type_student"]:checked
	)
	label[for="account_type_student"],
.tml-field-wrap.tml-account_type-wrap:has(
		input[id="account_type_teacher"]:checked
	)
	label[for="account_type_teacher"],
.tml-field-wrap.tml-account_type-wrap
	input[type="radio"]:checked
	+ label.tml-label[for^="account_type_"],
.tml-field-wrap.tml-account_type-wrap
	label.tml-label[for^="account_type_"].selected {
	border-color: var(--kp-primary);
	background: var(--kp-primary-light);
	box-shadow: var(--kp-box-shadow-lg);
	font-weight: 600;
	color: var(--kp-primary);
}

/* Grade radio buttons - use .selected class added by JavaScript (most reliable) */
.tml-field-wrap.tml-grade_id-wrap label.tml-label[for^="grade_id_"].selected {
	border-color: var(--kp-primary);
	background: var(--kp-primary-light);
	box-shadow: var(--kp-box-shadow-lg);
	font-weight: 600;
	color: var(--kp-primary);
}

/* Fallback: adjacent sibling selector if radio and label are next to each other */
.tml-field-wrap.tml-grade_id-wrap
	input[type="radio"]:checked
	+ label.tml-label[for^="grade_id_"] {
	border-color: var(--kp-primary);
	background: var(--kp-primary-light);
	box-shadow: var(--kp-box-shadow-lg);
	font-weight: 600;
	color: var(--kp-primary);
}

/* Description styling */
.tml-field-wrap .tml-description {
	width: 100%;
	margin-top: 0.75rem;
	font-size: 0.875rem;
	color: var(--kp-text-muted);
}

/* ============================================
   SUBJECT CHECKBOXES - Match Grade Radio Style
   ============================================ */

.kp-subjects-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-top: 0.5rem;
}

/* Hide the actual checkbox, we only show the label box */
/* Checkboxes are siblings of labels, so we target them directly in the grid */
.kp-subjects-grid input[type="checkbox"].tml-checkbox.form-control {
	position: absolute;
	opacity: 0;
	pointer-events: none;
	width: 0;
	height: 0;
	margin: 0;
	border: none !important;
	padding: 0 !important;
	display: none !important;
}

/* Also hide when parent container is hidden */
.kp-subjects-field[style*="display: none"],
.kp-subjects-field[style*="display:none"] {
	display: none !important;
}

.kp-subjects-field[style*="display: none"] .kp-subjects-grid,
.kp-subjects-field[style*="display:none"] .kp-subjects-grid,
.kp-subjects-field[style*="display: none"] input[type="checkbox"],
.kp-subjects-field[style*="display:none"] input[type="checkbox"],
.kp-subjects-field[style*="display: none"] .kp-subject-option,
.kp-subjects-field[style*="display:none"] .kp-subject-option {
	display: none !important;
}

.kp-subject-option span {
	display: block;
	width: 100%;
	text-align: center;
}

/* Selected state - when checkbox is checked.
   With the current markup the checkbox is a sibling before the label,
   so we use the adjacent-sibling selector. */
.kp-subjects-grid
	input[type="checkbox"].tml-checkbox.form-control:checked
	+ label.kp-subject-option {
	border-color: var(--kp-primary);
	background: var(--kp-primary-light);
	box-shadow: var(--kp-box-shadow-lg);
	font-weight: 600;
	color: var(--kp-primary);
}

/* Radio button box container */
.kp-radio-box-group {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-top: 0.5rem;
}

.kp-radio-box {
	position: relative;
	flex: 1;
	min-width: 150px;
	border: 2px solid var(--kp-border);
	border-radius: var(--kp-border-radius);
	padding: 1rem 1.5rem;
	cursor: pointer;
	transition: var(--kp-transition);
	background: white;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
}

.kp-radio-box:hover {
	border-color: var(--kp-primary);
	box-shadow: var(--kp-box-shadow);
	transform: translateY(-1px);
}

.kp-radio-box input[type="radio"] {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.kp-radio-box input[type="radio"]:checked + label,
.kp-radio-box:has(input[type="radio"]:checked) {
	border-color: var(--kp-primary);
	background: var(--kp-primary-light);
	box-shadow: var(--kp-box-shadow-lg);
	font-weight: 600;
	color: var(--kp-primary);
}

.kp-radio-box label {
	cursor: pointer;
	margin: 0;
	font-size: 1rem;
	color: var(--kp-dark);
	width: 100%;
	text-align: center;
}

/* Fallback for browsers that don't support :has() */
.kp-radio-box.selected {
	border-color: var(--kp-primary);
	background: var(--kp-primary-light);
	box-shadow: var(--kp-box-shadow-lg);
	font-weight: 600;
}

.kp-radio-box.selected label {
	color: var(--kp-primary);
	font-weight: 600;
}

/* ============================================================
   ROLE SELECTION CARDS - Modern Card Design
   ============================================================ */
.kp-role-selection {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 1rem;
	margin-bottom: 1.5rem;
}

.kp-role-card {
	position: relative;
	border: 2px solid var(--kp-border);
	border-radius: var(--kp-border-radius-lg);
	padding: 1.5rem;
	cursor: pointer;
	transition: var(--kp-transition);
	background: white;
	text-align: center;
}

.kp-role-card:hover {
	border-color: var(--kp-primary);
	box-shadow: var(--kp-box-shadow-lg);
	transform: translateY(-2px);
}

.kp-role-card.selected {
	border-color: var(--kp-primary);
	background: var(--kp-primary-light);
	box-shadow: var(--kp-box-shadow-lg);
}

.kp-role-card input[type="radio"] {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.kp-role-icon {
	font-size: 3rem;
	margin-bottom: 0.75rem;
	display: block;
}

.kp-role-title {
	font-size: 1.25rem;
	font-weight: 600;
	color: var(--kp-dark);
	margin-bottom: 0.5rem;
}

.kp-role-description {
	font-size: 0.875rem;
	color: var(--kp-text-muted);
	margin: 0;
	line-height: 1.5;
}

/* ============================================================
   BUTTONS - Bootstrap 5 Enhanced
   ============================================================ */
.btn {
	border-radius: var(--kp-border-radius);
	padding: 0.75rem 1.5rem;
	font-weight: 600;
	transition: var(--kp-transition);
	min-height: 44px; /* Touch target */
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
}

.btn:hover:not(:disabled) {
	transform: translateY(-2px);
	box-shadow: var(--kp-box-shadow-lg);
}

.btn:focus {
	box-shadow: var(--kp-box-shadow-focus);
}

.btn-primary {
	background-color: var(--kp-primary);
	border-color: var(--kp-primary);
}

.btn-primary:hover:not(:disabled) {
	background-color: var(--kp-primary-hover);
	border-color: var(--kp-primary-hover);
}

.btn-lg {
	padding: 0.875rem 2rem;
	font-size: 1.125rem;
}

/* Loading State */
.btn-loading {
	position: relative;
	color: transparent !important;
	pointer-events: none;
}

.btn-loading::after {
	content: "";
	position: absolute;
	width: 1.25rem;
	height: 1.25rem;
	top: 50%;
	left: 50%;
	margin-left: -0.625rem;
	margin-top: -0.625rem;
	border: 2px solid rgba(255, 255, 255, 0.3);
	border-radius: 50%;
	border-top-color: white;
	animation: kp-spin 0.6s linear infinite;
}

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

/* ============================================================
   ALERTS AND MESSAGES - Bootstrap 5 Enhanced
   ============================================================ */
.alert {
	border-radius: var(--kp-border-radius);
	border-width: 2px;
	padding: 1rem 1.25rem;
}

.alert-danger {
	background-color: #f8d7da;
	border-color: var(--kp-danger);
	color: #721c24;
}

.alert-success {
	background-color: #d4edda;
	border-color: var(--kp-success);
	color: #155724;
}

/* ============================================================
   THEME MY LOGIN (TML) OVERRIDES - Bootstrap 5 Compatible
   ============================================================ */

/* Override TML Social Plugin max-width restriction */
.tml-register,
.tml-login {
	max-width: 100% !important;
	width: 100% !important;
}

/* TML Form Flexbox Layout */
.tml form {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	align-content: flex-start;
	justify-content: space-around;
	align-items: flex-start;
}

/* Use tml-register-form for better specificity */
.tml-register-form,
.theme-my-login .tml-form {
	background: white;
	padding: 2rem;
	border-radius: var(--kp-border-radius-lg);
	box-shadow: var(--kp-box-shadow-lg);
	max-width: 100% !important;
	width: 100% !important;
	display: flex;
	flex-wrap: wrap;
	gap: 1.5rem;
	align-items: flex-start;
	justify-content: flex-start;
}

/* Step container - ensure proper flex layout (removed duplicate) */

/* Clearfix for row breaks */
.kp-step-container::after {
	content: "";
	display: table;
	clear: both;
}

/* Section headers and dividers span full width */
.theme-my-login .tml-form .kp-form-section-title,
.theme-my-login .tml-form .kp-form-section-divider,
.theme-my-login .tml-form .tml-field-wrap.tml-section_header_about_you-wrap,
.theme-my-login
	.tml-form
	.tml-field-wrap.tml-section_header_account_details-wrap,
.tml-register-form .kp-form-section-title,
.tml-register-form .kp-form-section-divider,
.tml-register-form .tml-field-wrap.tml-section_header_about_you-wrap,
.tml-register-form .tml-field-wrap.tml-section_header_account_details-wrap {
	width: 100% !important;
	flex-basis: 100% !important;
}

/* Full-width fields (submit button, password indicator, subjects, etc.) */
.theme-my-login .tml-form .tml-submit-wrap,
.theme-my-login .tml-form .tml-field-wrap.tml-indicator-wrap,
.theme-my-login .tml-form .tml-field-wrap.tml-indicator_hint-wrap,
.theme-my-login .tml-form .tml-field-wrap:has(input[type="submit"]),
.theme-my-login .tml-form .tml-field-wrap:has(button[type="submit"]),
.theme-my-login .tml-form .tml-field-wrap.kp-subjects-field,
.tml-register-form .tml-submit-wrap,
.tml-register-form .tml-field-wrap.tml-indicator-wrap,
.tml-register-form .tml-field-wrap.tml-indicator_hint-wrap,
.tml-register-form .tml-field-wrap:has(input[type="submit"]),
.tml-register-form .tml-field-wrap:has(button[type="submit"]),
.tml-register-form .tml-field-wrap.kp-subjects-field {
	width: 100% !important;
	flex-basis: 100% !important;
}

/* Row 1: First Name and Last Name (50% each) */
.tml-field-wrap.tml-first_name-wrap,
.tml-field-wrap.tml-last_name-wrap,
.tml-field-wrap.tml-user_login-wrap,
.tml-field-wrap.tml-user_email-wrap,
.tml-field-wrap.tml-user_pass1-wrap,
.tml-field-wrap.tml-user_pass2-wrap {
	width: calc(50% - 0.75rem) !important;
	flex: 0 0 calc(50% - 0.75rem) !important;
	max-width: calc(50% - 0.75rem) !important;
}

/* Row 2: 33% width fields (I am, I want to, City) */
.tml-field-wrap.tml-gender-wrap,
.tml-field-wrap.tml-account_type-wrap,
.tml-field-wrap.tml-city-wrap {
	width: calc(33.333% - 1rem) !important;
	flex: 0 0 calc(33.333% - 1rem) !important;
	max-width: calc(33.333% - 1rem) !important;
}

/* Row 4: Grade (50%) */
.tml-field-wrap.tml-grade_id-wrap,
.tml-field-wrap.tml-kp_subject_ids-wrap {
	width: calc(100% - 0.75rem) !important;
	flex: 0 0 calc(100% - 0.75rem) !important;
	max-width: calc(100% - 0.75rem) !important;
}

/* Row 4: Subjects (100% when visible) */
.tml-field-wrap.tml-submit-wrap,
.tml-field-wrap.tml-indicator-wrap,
.tml-field-wrap.tml-indicator_hint-wrap,
.tml-field-wrap.tml-log-wrap,
.tml-field-wrap.tml-pwd-wrap,
.tml-field-wrap.tml-rememberme-wrap,
.tml-field-wrap.tml-submit-wrap {
	width: 100% !important;
	flex: 0 0 100% !important;
	max-width: 100% !important;
}

.theme-my-login .tml-field-wrap {
	margin-bottom: 0;
}

/* Grade Radio Buttons - 50% Square Boxes */

.tml-field-wrap.tml-grade_id-wrap {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-top: 0.5rem;
	width: 100% !important;
	flex-basis: 100% !important;
}

/* Apply Bootstrap classes to TML fields via CSS if classes aren't added via PHP */
.theme-my-login .tml-field-wrap label,
.tml-register-form .tml-field-wrap label,
.theme-my-login .tml-field-wrap .form-label,
.tml-register-form .tml-field-wrap .form-label {
	font-weight: 600;
	margin-bottom: 0.5rem;
	color: var(--kp-dark);
	font-size: 0.9375rem;
}

/* Ensure all inputs get Bootstrap styling */
.theme-my-login .tml-field-wrap input[type="text"],
.theme-my-login .tml-field-wrap input[type="email"],
.theme-my-login .tml-field-wrap input[type="password"],
.theme-my-login .tml-field-wrap input[type="tel"],
.theme-my-login .tml-field-wrap input[type="url"],
.theme-my-login .tml-field-wrap select,
.theme-my-login .tml-field-wrap textarea,
.tml-register-form .tml-field-wrap input[type="text"],
.tml-register-form .tml-field-wrap input[type="email"],
.tml-register-form .tml-field-wrap input[type="password"],
.tml-register-form .tml-field-wrap input[type="tel"],
.tml-register-form .tml-field-wrap input[type="url"],
.tml-register-form .tml-field-wrap select,
.tml-register-form .tml-field-wrap textarea,
.theme-my-login .tml-field-wrap .form-control,
.theme-my-login .tml-field-wrap .form-select,
.tml-register-form .tml-field-wrap .form-control,
.tml-register-form .tml-field-wrap .form-select {
	width: 100%;
	padding: 0.75rem 1rem;
	border: 2px solid var(--kp-border);
	border-radius: var(--kp-border-radius);
	font-size: 1rem;
	transition: var(--kp-transition);
}

.theme-my-login .tml-field-wrap input:focus,
.theme-my-login .tml-field-wrap select:focus,
.tml-register-form .tml-field-wrap input:focus,
.tml-register-form .tml-field-wrap select:focus {
	border-color: var(--kp-primary);
	outline: none;
	box-shadow: var(--kp-box-shadow-focus);
}

/* Password validation states */
.theme-my-login .tml-field-wrap input.is-invalid,
.tml-register-form .tml-field-wrap input.is-invalid {
	border-color: var(--kp-danger) !important;
}

.theme-my-login .tml-field-wrap input.is-valid,
.tml-register-form .tml-field-wrap input.is-valid {
	border-color: var(--kp-success) !important;
}

.theme-my-login .tml-field-wrap .invalid-feedback,
.tml-register-form .tml-field-wrap .invalid-feedback {
	display: block;
	color: var(--kp-danger);
	font-size: 0.875rem;
	margin-top: 0.25rem;
}

/* Password mismatch indicator */
#pass-strength-result.password-mismatch {
	background-color: var(--kp-danger-light);
	border: 2px solid var(--kp-danger);
	border-radius: var(--kp-border-radius);
	padding: 0.75rem 1rem;
	margin-top: 0.5rem;
}

#pass-strength-result.password-mismatch .password-mismatch-message {
	display: block;
	color: var(--kp-danger);
	font-weight: 600;
}

.theme-my-login .tml-field-wrap input[readonly] {
	background-color: var(--kp-light);
	cursor: not-allowed;
}

.theme-my-login .tml-field-wrap .description,
.tml-register-form .tml-field-wrap .description,
.theme-my-login .tml-field-wrap .form-text,
.tml-register-form .tml-field-wrap .form-text {
	font-size: 0.875rem;
	color: var(--kp-text-muted);
	margin-top: 0.25rem;
	line-height: 1.5;
	display: block;
}

/* Password Indicator - Full Width (span both columns) */
.theme-my-login .tml-field-wrap.tml-indicator-wrap,
.theme-my-login .tml-field-wrap.tml-indicator_hint-wrap,
.tml-register-form .tml-field-wrap.tml-indicator-wrap,
.tml-register-form .tml-field-wrap.tml-indicator_hint-wrap {
	width: 100% !important;
	display: none;
	grid-column: 1 / -1 !important;
}

.theme-my-login .tml-field-wrap.tml-indicator-wrap.has-password,
.theme-my-login .tml-field-wrap.tml-indicator_hint-wrap.has-password,
.tml-register-form .tml-field-wrap.tml-indicator-wrap.has-password,
.tml-register-form .tml-field-wrap.tml-indicator_hint-wrap.has-password {
	display: block;
	grid-column: 1 / -1 !important;
}

/* Radio Groups - Modern Styling */
.theme-my-login .tml-radio-group {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-top: 0.5rem;
}

.theme-my-login .tml-radio-group label {
	display: flex;
	align-items: center;
	cursor: pointer;
	font-weight: normal;
	margin-bottom: 0;
}

.theme-my-login .tml-radio-group input[type="radio"] {
	width: 1.25rem;
	height: 1.25rem;
	margin-right: 0.5rem;
	cursor: pointer;
}

/* Submit Buttons */
.theme-my-login .tml-submit-wrap {
	margin-top: 2rem;
	text-align: center;
}

.theme-my-login .tml-submit-wrap input[type="submit"],
.theme-my-login .tml-submit-wrap button {
	width: 100%;
	padding: 0.875rem 2rem;
	font-size: 1.125rem;
	font-weight: 600;
	border-radius: var(--kp-border-radius);
	background-color: var(--kp-primary);
	border-color: var(--kp-primary);
	color: white;
	transition: var(--kp-transition);
}

.theme-my-login .tml-submit-wrap input[type="submit"]:hover,
.theme-my-login .tml-submit-wrap button:hover {
	background-color: var(--kp-primary-hover);
	border-color: var(--kp-primary-hover);
	transform: translateY(-2px);
	box-shadow: var(--kp-box-shadow-lg);
}

/* Error Messages */
.theme-my-login .tml-errors {
	background-color: #f8d7da;
	border: 2px solid var(--kp-danger);
	border-radius: var(--kp-border-radius);
	padding: 1rem;
	margin-bottom: 1.5rem;
}

.theme-my-login .tml-errors li {
	color: #721c24;
	list-style: none;
	margin-bottom: 0.5rem;
}

.theme-my-login .tml-errors li:last-child {
	margin-bottom: 0;
}

/* Success Messages */
.theme-my-login .tml-message,
.theme-my-login .tml-success {
	background-color: #d4edda;
	border: 2px solid var(--kp-success);
	border-radius: var(--kp-border-radius);
	padding: 1rem;
	margin-bottom: 1.5rem;
	color: #155724;
}

/* ============================================================
   RESPONSIVE DESIGN
   ============================================================ */
@media (max-width: 767.98px) {
	.kp-form-container {
		padding: 1rem;
		margin: 1rem auto;
	}

	.kp-form-header h1 {
		font-size: 2rem;
	}

	.kp-form-header p {
		font-size: 1rem;
	}

	.kp-role-selection {
		grid-template-columns: 1fr;
	}

	.theme-my-login .tml-form,
	.tml-register-form {
		padding: 1.5rem;
		grid-template-columns: 1fr !important; /* Single column on mobile */
	}

	/* Ensure full-width elements still span on mobile */
	.tml-register-form .tml-field-wrap.tml-section_header_about_you-wrap,
	.tml-register-form .tml-field-wrap.tml-section_header_account_details-wrap,
	.tml-register-form .tml-field-wrap.tml-indicator-wrap,
	.tml-register-form .tml-field-wrap.tml-indicator_hint-wrap,
	.tml-register-form .tml-submit-wrap,
	.theme-my-login .tml-form .tml-field-wrap.tml-section_header_about_you-wrap,
	.theme-my-login
		.tml-form
		.tml-field-wrap.tml-section_header_account_details-wrap,
	.theme-my-login .tml-form .tml-field-wrap.tml-indicator-wrap,
	.theme-my-login .tml-form .tml-field-wrap.tml-indicator_hint-wrap,
	.theme-my-login .tml-form .tml-submit-wrap {
		grid-column: 1 / -1 !important;
	}
}

/* ============================================================
   ACCESSIBILITY ENHANCEMENTS
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
	}
}

/* Focus Visible for Keyboard Navigation */
*:focus-visible {
	outline: 2px solid var(--kp-primary);
	outline-offset: 2px;
}

/* High Contrast Mode Support */
@media (prefers-contrast: high) {
	.kp-form-container {
		border: 2px solid var(--kp-dark);
	}

	.form-control,
	.form-select {
		border-width: 3px;
	}
}
