.register-modal {
	position: fixed;
	inset: 0;
	z-index: 2600;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.2s ease;
}

.register-modal.open {
	opacity: 1;
	pointer-events: auto;
}

.register-modal-overlay {
	position: absolute;
	inset: 0;
	background: rgba(9, 10, 11, 0.65);
}

.register-modal-content {
	position: relative;
	margin: 8vh auto;
	width: min(92vw, 560px);
	background: var(--color-white);
	border-radius: 16px;
	box-shadow: 0 26px 60px rgba(0, 0, 0, 0.25);
	display: flex;
	flex-direction: column;
	overflow: hidden;
}

.register-modal-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1rem;
	padding: 1rem 1.4rem;
	border-bottom: 1px solid var(--color-border-light);
}

.register-modal-header h3 {
	margin: 0;
	font-size: 1.2rem;
}

.register-modal-subtitle {
	font-size: 0.9rem;
	color: var(--color-text-muted);
	margin-top: 0.2rem;
}

.register-modal-close {
	border: 1px solid var(--color-border-light);
	background: var(--color-surface-alt);
	color: var(--color-text);
	border-radius: 8px;
	padding: 0.35rem 0.6rem;
	cursor: pointer;
}

.register-modal-form {
	display: flex;
	flex-direction: column;
	gap: 0.8rem;
	padding: 1rem 1.4rem 1.4rem;
}

.register-modal-field {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}

.register-modal-field label {
	font-weight: 600;
	color: var(--color-text-strong);
}

.register-modal-field input {
	padding: 0.6rem 0.75rem;
	border: 1px solid var(--color-border);
	border-radius: 8px;
	font-family: inherit;
	background: var(--color-white);
}

.register-modal-field input.is-invalid {
	border-color: #dc3545;
	box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.15);
}

.register-modal-field input.is-valid {
	border-color: #28a745;
	box-shadow: 0 0 0 3px rgba(40, 167, 69, 0.15);
}

.register-modal-field .password-field input {
	padding-right: 2.6rem;
}

.register-modal-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem;
	justify-content: stretch;
	margin-top: 0.4rem;
}

.register-modal-terms {
	font-size: 0.85rem;
	color: var(--color-text-muted);
	line-height: 1.4;
	margin-top: 0.2rem;
}

.register-modal-terms a {
	color: var(--color-cta-primary);
	text-decoration: none;
	font-weight: 600;
}

.register-modal-terms a:hover {
	color: var(--color-cta-primary-hover);
	text-decoration: underline;
}

.register-modal-login {
	margin-top: 0.2rem;
	display: flex;
	align-items: center;
	align-self: center;
	justify-content: flex-end;
	gap: 0.35rem;
	font-size: 0.9rem;
	color: var(--color-text-muted);
}

.register-modal-login-link {
	border: none;
	background: none;
	color: var(--color-cta-primary);
	font: inherit;
	font-weight: 600;
	cursor: pointer;
	padding: 0;
}

.register-modal-login-link:hover {
	color: var(--color-cta-primary-hover);
	text-decoration: underline;
}

.register-modal-submit {
	border: 1px solid var(--color-cta-primary);
	background: var(--color-cta-primary);
	color: var(--color-white);
	border-radius: 8px;
	padding: 0.6rem 1rem;
	cursor: pointer;
	font-weight: 600;
	width: 100%;
}

.register-modal-submit:hover {
	background: var(--color-cta-primary-hover);
	border-color: var(--color-cta-primary-hover);
}

.register-modal-secondary {
	border: 1px solid var(--color-cta-secondary);
	background: var(--color-cta-secondary-bg-hover);
	color: var(--color-cta-secondary);
	border-radius: 8px;
	padding: 0.6rem 1rem;
	cursor: pointer;
	font-weight: 600;
}

.register-modal-secondary:hover {
	border-color: var(--color-cta-secondary-hover);
	color: var(--color-cta-secondary-hover);
}

body.register-modal-open {
	overflow: hidden;
}

@media (max-width: 600px) {
	.register-modal-content {
		margin: 10vh auto;
	}

	.register-modal-actions {
		justify-content: stretch;
	}

	.register-modal-submit,
	.register-modal-secondary {
		width: 100%;
	}
}
