* {
	border: 0;
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

:root {
	--hue: 223;
	--hue-error: 3;
	--bg: hsl(var(--hue), 10%, 90%);
	--fg: hsl(var(--hue), 10%, 10%);
	--primary: hsl(var(--hue), 90%, 50%);
	--trans-dur: 0.3s;
	font-size: calc(14px + (30 - 14) * (100vw - 280px) / (3840 - 280px));
}

a {
	color: var(--primary);
	transition: color var(--trans-dur);
}

a:hover {
	text-decoration: none;
}

a:visited {
	color: hsl(var(--hue), 90%, 30%);
}

body,
button,
input {
	color: var(--fg);
	font: 1em/1.5 "Nunito Sans", sans-serif;
}

body {
	background-color: var(--bg);
	display: flex;
	height: 100vh;
	transition: background-color var(--trans-dur), color var(--trans-dur);
}

h1 {
	font-size: 2em;
	margin: 0 0 1.5rem;
}

h2 {
	font-size: 1.5em;
	line-height: 1;
	margin: 0 0 3rem;
	padding-top: 0.75rem;
	color: #333;
}

p {
	margin-bottom: 1.5em;
}
.login__form p {
  color: #333;
}

.login {
	margin: auto;
	padding: 0.75em 0.75em 0;
	width: 100%;
	height: 100%;
}

.login__button,
.login__button-eye,
.login__input-checkbox,
.login__input-text,
.login__label {
	-webkit-appearance: none;
	appearance: none;
	-webkit-tap-highlight-color: transparent;
}
.login__label {
  color: #333;
}

.login__button,
.login__button-eye {
	cursor: pointer;
	display: block;
	transition: background-color var(--trans-dur), color var(--trans-dur), opacity var(--trans-dur);
}

.login__button {
	background-color: var(--primary);
	border-radius: 1.5em;
	color: hsl(0, 0%, 100%);
	margin-bottom: 1.5em;
	padding: 0.5em;
	width: 100%;
}

.login__button:disabled {
	cursor: not-allowed;
	opacity: 0.5;
}

.login__button:hover:not(:disabled) {
	background-color: hsl(var(--hue), 90%, 70%);
}

.login__button-eye {
	background-color: transparent;
	border-radius: 0.25em;
	position: absolute;
	right: 0;
	bottom: 0;
	width: 2.25em;
	height: 2.25em;
}

.login__button-eye:hover {
	background-color: hsl(var(--hue), 10%, 90%);
}

.login__error {
	color: hsl(var(--hue-error), 90%, 40%);
	display: flex;
	align-items: flex-start;
	font-size: 0.75em;
	line-height: 1.333;
	padding-top: 0.25rem;
	position: absolute;
	top: 100%;
	right: 0;
	left: 0;
	transition: color var(--trans-dur), opacity var(--trans-dur);
}

.login__field {
	margin-bottom: 1.5em;
	position: relative;
}

.login__field--sm {
	margin-bottom: 0.75em;
	padding-top: 0.75em;
}

.login__forgot {
	font-size: 0.75em;
	line-height: 2;
	position: absolute;
	top: 0;
	right: 0;
}

.login__forgot[dir="rtl"] {
	right: auto;
	left: 0;
}

.login__icon {
	flex-shrink: 0;
	pointer-events: none;
	width: 1.5em;
	height: auto;
}

.login__icon:not([display="none"]) {
	display: block;
}

.login__button-eye .login__icon {
	margin: auto;
}

.login__error .login__icon {
	display: none;
	margin-inline-end: 0.25rem;
	width: 1rem;
	height: 1rem;
}

.login__input-checkbox {
	border-radius: 0.25em;
	box-shadow: 0 0 0 1px hsl(var(--hue), 10%, 70%) inset;
	display: flex;
	margin-inline-end: 0.5em;
	width: 1em;
	height: 1em;
	transition: background-color var(--trans-dur), box-shadow var(--trans-dur);
}

.login__input-checkbox:before {
	background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpolyline fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' points='3 8,6 11,13 5' /%3E%3C/svg%3E") 0 0 / 100% auto;
	content: "";
	display: block;
	opacity: 0;
	width: inherit;
	height: inherit;
	transition: opacity var(--trans-dur);
}

.login__input-checkbox:checked {
	background-color: var(--primary);
	box-shadow: 0 0 0 1px var(--primary) inset;
}

.login__input-checkbox:checked:before {
	opacity: 1;
}

.login__input-checkbox-label {
	transition: opacity var(--trans-dur);
	color: #333;
}

.login__input-checkbox:disabled,
.login__input-checkbox:disabled ~ .login__input-checkbox-label {
	opacity: 0.5;
}

.login__input-password,
.login__input-text {
	background-color: transparent;
	border-radius: 0;
	box-shadow: 0 2px 0 hsla(var(--hue), 90%, 50%, 0), 0 1px 0 hsla(var(--hue), 10%, 70%, 1);
	outline: transparent;
	padding: 0.375em 0;
	width: 100%;
	transition: box-shadow var(--trans-dur), color var(--trans-dur), opacity var(--trans-dur);
}

.login__input-password[aria-invalid="true"],
.login__input-text[aria-invalid="true"] {
	box-shadow: 0 2px 0 hsla(var(--hue), 90%, 50%, 0), 0 1px 0 hsla(var(--hue-error), 90%, 40%, 1);
}

.login__input-password:disabled,
.login__input-text:disabled {
	opacity: 0.5;
}

.login__input-password:not(:disabled):hover,
.login__input-text:not(:disabled):hover {
	box-shadow: 0 2px 0 hsla(0, 0%, 100%, 0.5), 0 1px 0 hsla(var(--hue), 10%, 40%, 0);
}

.login__input-password:not(:disabled):focus-visible,
.login__input-text:not(:disabled):focus-visible {
	box-shadow: 0 2px 0 hsla(0, 0%, 100%, 1), 0 1px 0 hsla(var(--hue), 10%, 40%, 0);
}

.login__or {
	color: hsl(var(--hue), 10%, 40%);
	display: flex;
	align-items: center;
	font-size: 0.75em;
	line-height: 2;
	margin-bottom: 1.5em;
	text-align: center;
	transition: color var(--trans-dur);
}

.login__or:before,
.login__or:after {
	background-color: hsl(var(--hue), 10%, 70%);
	content: "";
	display: block;
	flex: 1;
	height: 1px;
	transition: background-color var(--trans-dur);
}

.login__or:before {
	margin-inline-end: 0.75em;
}

.login__or:after {
	margin-inline-start: 0.75em;
}

.login__wrapper {
	background: linear-gradient(hsl(var(--hue), 90%, 40%), hsl(283, 90%, 30%));
	border-radius: 1.25em 1.25em 0 0;
	display: flex;
	flex-direction: column;
	padding: 0.75em 0.75em 0 0.75em;
	height: min-content;
	min-height: 100%;
}

.login__cta {
	background-color: hsla(var(--hue), 10%, 90%, 0.2);
	backdrop-filter: blur(24px);
	-webkit-backdrop-filter: blur(24px);
	box-shadow: 0 -0.75em 1.5em hsla(0, 0%, 0%, 0.05), 0 1px 0 hsla(0, 0%, 100%, 0.4) inset;
	border-radius: 0;
	color: hsl(0, 0%, 100%);
	flex: 1;
	margin: 0 -1.5em;
	padding: 1.25em 2.25em;
	transition: background-color var(--trans-dur), box-shadow var(--trans-dur);
}

.login__cta-text {
	padding: 1.25em 0;

	p {
		color: hsl(var(--hue), 10%, 90%);
	}
}

@media (min-width: 1024px) {
	.login {
		display: flex;
		padding: 0.75em;
		position: relative;
		min-height: 43.5em;
		transform: translateZ(0);
	}

	.login__wrapper {
		border-radius: 1.25em;
		margin: auto calc(50% - 0.75em) auto auto;
		width: 30em;
		height: 100%;
		min-height: auto;
		max-height: 42em;
	}

	.login__wrapper[dir="rtl"] {
		margin: auto auto auto calc(50% - 0.75em);
	}

	.login__cta {
		padding: 0;
		position: fixed;
		top: 50%;
		left: 1.5em;
		width: 100%;
		height: 50%;
	}

	.login__cta:before,
	.login__cta:after {
		background-color: var(--bg);
		content: "";
		display: block;
		position: absolute;
		bottom: 0;
		width: 0.75em;
		height: calc(100% + 3em);
		transition: background-color var(--trans-dur);
	}

	.login__cta:before {
		left: 0;
		-webkit-mask: linear-gradient(90deg, hsl(0, 0%, 0%), hsla(0, 0%, 0%, 0));
	}

	.login__cta:after {
		right: 0;
		-webkit-mask: linear-gradient(-90deg, hsl(0, 0%, 0%), hsla(0, 0%, 0%, 0));
	}

	.login__cta-text {
		padding: 4.5em 0;
		position: absolute;
		right: calc(50% - 0.75em);
		width: 30em;
	}

	.login__cta-text[dir="rtl"] {
		right: auto;
		left: calc(50% - 0.75em);
	}

	.login__form {
    margin: 0 -1.5em;
    padding: 4.5em;
    position: absolute;
    top: 0;
    left: calc(50% - 2.25em);
    width: 33em;
    background: #fff;
    transform: translate(0, -50%);
    z-index: 1;
    border-radius: 1em;
}

	.login__form[dir="rtl"] {
		right: calc(50% - 2.25em);
		left: auto;
	}
}

@media (prefers-color-scheme: dark) {
	:root {
		--bg: hsl(var(--hue), 10%, 10%);
		--fg: hsl(var(--hue), 10%, 90%);
	}

	a {
		color: hsl(var(--hue), 90%, 70%);
	}

	a:visited {
		color: hsl(var(--hue), 90%, 90%);
	}

	.login__button-eye:hover {
		background-color: hsl(var(--hue), 10%, 30%);
	}

	.login__error {
		color: hsl(var(--hue-error), 90%, 70%);
	}

	.login__form {
		background-color: hsl(var(--hue), 10%, 20%);
	}

	.login__input-checkbox {
		box-shadow: 0 0 0 1px hsl(var(--hue), 10%, 40%) inset;
	}

	.login__input-password[aria-invalid="true"],
	.login__input-text[aria-invalid="true"] {
		box-shadow: 0 2px 0 hsla(var(--hue), 90%, 50%, 0), 0 1px 0 hsla(var(--hue-error), 90%, 70%, 1);
	}

	.login__or {
		color: hsl(var(--hue), 10%, 70%);
	}

	.login__or:before,
	.login__or:after {
		background-color: hsl(var(--hue), 10%, 40%);
	}

	.login__cta {
		background-color: hsla(var(--hue), 10%, 40%, 0.2);
		box-shadow: 0 -1em 1em hsla(0, 0%, 0%, 0.1), 0 1px 0 hsla(0, 0%, 100%, 0.2) inset;
	}
}
svg.login__logo {
    color: #fff;
}

@media (max-width: 1023px) {
  h2 {
  color: #fff;
}
.login__form p {
    color: #fff;
}
.login__input-checkbox-label {
  color: #fff;
}
.login__form {
    background: transparent !important;
}
}
