label {
	font-size: 12.5px;
	color: #000;
	opacity: .8;
	font-weight: 400
}

form {
	padding: 40px 30px;
	background: #fefefe;
	border: 1px solid rgba(206, 206, 206, 0.329);
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	padding-bottom: 20px;
	width: 400px;
	border-radius: 10px
}

form h4 {
	margin-bottom: 20px;
	color: rgba(0, 0, 0, .5);
	font-size: 2rem;
	letter-spacing: -.4px
}

form h4 span {
	color: rgba(0, 0, 0, 1);
	font-weight: 700
}

form p {
	line-height: 155%;
	margin-bottom: 5px;
	font-size: 16px;
	color: #000;
	opacity: .65;
	font-weight: 400;
	max-width: 320px;
	margin-bottom: 40px
}

a.discrete {
	color: #000;
	opacity: .65;
	font-size: 14px;
	border-bottom: solid 1px rgba(0, 0, 0, .0);
	padding-bottom: 4px;
	margin-left: auto;
	font-weight: 300;
	transition: all .3s ease;
	margin-top: 40px
}

a.discrete:hover {
	border-bottom: solid 1px rgba(0, 0, 0, .2)
}

button {
	-webkit-appearance: none;
	width: auto;
	min-width: 100px;
	border-radius: 24px;
	text-align: center;
	padding: 15px 40px;
	margin-top: 5px;
	background-color: #57a4e2;
	color: #fff;
	font-size: 14px;
	margin-left: auto;
	font-weight: 500;
	box-shadow: 0 2px 6px -1px rgba(0, 0, 0, .13);
	border: 0;
	transition: all .3s ease;
	outline: 0
}

button:hover:active {
	transform: scale(0.99)
}

input {
	font-size: 16px;
	padding: 20px 0;
	height: 56px;
	border: 0;
	border-bottom: solid 1px rgba(0, 0, 0, .1);
	background: #fff;
	width: 280px;
	box-sizing: border-box;
	transition: all .3s linear;
	color: #000;
	font-weight: 400;
	-webkit-appearance: none
}

input:focus {
	border-bottom: solid 1px #3f42d383;
	outline: 0;
	box-shadow: 0 2px 6px -8px rgba(182, 157, 230, .45)
}

.floating-label {
	position: relative;
	margin-bottom: 10px;
	width: 100%
}

.floating-label label {
	position: absolute;
	top: calc(50% - 7px);
	left: 0;
	opacity: 0;
	transition: all .3s ease;
	padding-left: 44px
}

.floating-label input {
	width: calc(100% - 44px);
	margin-left: auto;
	display: flex
}

.floating-label .icon {
	position: absolute;
	top: 0;
	left: 0;
	height: 56px;
	width: 44px;
	display: flex
}

.floating-label .icon svg {
	height: 30px;
	width: 30px;
	margin: auto;
	opacity: .15;
	transition: all .3s ease
}

.floating-label .icon svg path {
	transition: all .3s ease
}

.floating-label input:not(:placeholder-shown) {
	padding: 28px 0 12px 0
}

.floating-label input:not(:placeholder-shown)+label {
	transform: translateY(-10px);
	opacity: .7
}

.floating-label input:valid:not(:placeholder-shown)+label+.icon svg {
	opacity: 1
}

.floating-label input:valid:not(:placeholder-shown)+label+.icon svg path {
	fill: #b69de6
}

.floating-label input:not(:valid):not(:focus)+label+.icon {
	animation-name: shake-shake;
	animation-duration: .3s
}

@keyframes shake-shake {
	0% {
		transform: translateX(-3px)
	}
	20% {
		transform: translateX(3px)
	}
	40% {
		transform: translateX(-3px)
	}
	60% {
		transform: translateX(3px)
	}
	80% {
		transform: translateX(-3px)
	}
	100% {
		transform: translateX(0px)
	}
}

.session {
	display: flex;
	justify-content: center;
	align-content: center;
	flex-direction: row;
	width: auto;
	height: 500px;
	margin: auto auto;
	margin-top: 100px;
	margin-bottom: 100px;
	background: #fff;
	border-radius: 4px;
	font-family: Inter
}

.left {
	width: 350px;
	height: auto;
	min-height: 100%;
	position: relative;
	background-image: url("../img/login.jpg");
	background-size: cover;
	border-top-left-radius: 4px;
	border-bottom-left-radius: 4px
}

.left svg {
	height: 40px;
	width: auto;
	margin: 20px
}