/* form */

#login-article,
#subscribe,
#contact {
	align-items: center;
	display: flex;
	justify-content: center;
	min-height: 100vh;
}

#login-article {
	padding:0px;
}

#login-article form {
	margin:20px auto;
}

#login-article form,
#contact form {
	width:400px;
	max-width: 100%;
	border-radius:5px;
}

#subscribe form {
	padding:20px;
}

#subscribe form label {
	font-size:16px;
}

#subscribe form a {
	text-decoration: underline;
}

input {
	-webkit-appearance: none;
	-webkit-border-radius:0;
	border-radius:0;
}

.form-article form {
	padding:20px;
	margin-bottom:20px;
	margin: 0px;
	width:500px;
	max-width: 100%;
}

.mx-w-500 {
	width: 500px;
	max-width: 100%;

}

form {
	background: white;
	padding:20px;
	box-shadow:0px 5px 10px #0176a8bb;
	color:#044c6bfa;
}

form h3 {
	margin-bottom:10px;
}

form .row:last-of-type {
	margin-bottom:20px;
}

form .row {
	text-align: left;
	margin-bottom:10px;
}

form .row.block {
	text-align: left;
	margin-bottom:10px;
	display: block;
}

form .row span {
	display:block;
	padding-top:5px;
	font-size:12px;
}

form label {
	text-align: left;
	font-size:16px;
	display: block;
	margin-bottom: 5px;
}

form input[type='text'],
form input[type='email'],
form input[type='submit'],
form input[type='number'],
form input[type='password'],
form input[type='tel'],
form select,
form a.btn {
	border:1px solid #ddd;
	padding:10px;
	font-size:16px;
	margin:0px auto;
	width:100%;
	-moz-appearance: none;
	-webkit-appearance: none;
	/* border-radius:5px; */
}

form input:focus {
	border:none;
}
form textarea {
	width:100%;
	border:none;
	min-height:200px;
	resize: none;
	padding:10px;
	margin:0px;
	font-size:16px;
	border:1px solid #ddd;
}

form input[type='submit'],
form a.btn {
	cursor: pointer;
	background:#044c6bfa;
	color:white;
}

form .compact {
	display: flex;
}

form .numbers {
	display: flex;
}

form .radio_list {
	display: flex;
}

form .numbers .radio {
	margin: auto;
	width:40px;
}

form .flex-container {
	display:flex;
}

form input[type="checkbox"] {
	padding:5px;
	border:1px solid gray;
	cursor: pointer;
	vertical-align: bottom;
	display: inline-block;
	margin:8px 0px 8px 0px;
}

input[type="checkbox"] ~ label {
	margin: 0px;
	display: inline-block;
	vertical-align: middle;
	font-size:20px;
	margin:4px 0px 4px 8px;
}

form input[type="checkbox"]:checked {
	background:green;
}

form img {
	width:100%;
	max-width:100%;
	margin:10px auto;
	box-shadow: 0px 2px 2px #777;
	text-align: left;
}

form h4 {
	font-size: 1.5rem;
	padding:0px;
	margin: 0px;
	margin-bottom: 10px;
}

form p {
	text-align: left;
	margin-bottom: 20px;
}

#login-page {
	padding-top:0px;
	background:#60a6df;
	width:100%;
}

#login-page .login-article {
	display: flex;
	flex-wrap: wrap;
}

#login-page h1 a {
	font-size: 3rem;
	color:white;
	font-weight: bold;
	text-shadow: 0px 2px 3px #02517457;
}

@media screen and (max-width:840px) {
	#login-article {
		display: block;
		min-height:100vh;
		margin-bottom:200px;
	}

	#login-article h1 {
		padding:20px;
		font-size:2rem;
		text-align: center;
	}

	#login-article form {
		background:unset;
		box-shadow: unset;
	}
}
