:root {
	--ec-primary: rgb(115, 167, 72);
}

* {
	box-sizing: border-box;
}

body {
	background: white;
	margin: 0;
	font-family: 'Open Sans', sans-serif;
	font-size: 0.875rem;
	line-height: 1.7;
	color: #666;
}

.btn {
	display: inline-block;
	background: var(--ec-primary);
	border: 2px solid var(--ec-primary);
	border-radius: 2em;
	padding: 0.5em 1.25em;
	font: inherit;
	font-weight: 400;
	text-decoration: none;
	color: white;
}

.alert {
	background: #fcf8e3;
	border: 1px solid #faebcc;
	border-radius: 0.25em;
	padding: 1em 1.25em;
	margin: 1em 0;
	font-weight: 400;
	color: #8a6d3b;

	p {
		margin: 0;
	}
}

.header {
	position: relative;
	display: flex;
	flex-flow: row wrap;
	align-items: center;
	background: white;
	min-height: 10vh;
	max-width: 90%;
	padding: 2% 0;
	margin: 0 auto;
	z-index: 1;

	.register {
		margin-left: auto;
		font-size: 1rem;

		.btn {
			margin-left: 1em;
			box-shadow: 0px 12px 18px -12px rgba(0, 0, 0, 0.3);
		}
	}
}

.content {
	position: relative;
	background-image: linear-gradient(180deg, #73a748 0%, #2f5335 100%);
	min-height: 90vh;
	padding: 15vh 2rem;

	&:before {
		content: '';
		position: absolute;
		top: 0;
		left: 0;
		background-image: url(data:image/svg+xml;base64,PHN2ZyAgZmlsbD0icmdiYSg3MSw3MSw3MSwwLjEpIiBoZWlnaHQ9IjgwcHgiIHdpZHRoPSI4MHB4IiB2aWV3Qm94PSIwIDAgODAgODAiIHByZXNlcnZlQXNwZWN0UmF0aW89Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PHBhdGggZD0iTTAsOFYwSDhBOCw4LDAsMCwxLDAsOFpNODAsOFYwSDcyQTgsOCwwLDAsMCw4MCw4Wk0wLDcydjhIOEE4LDgsMCwwLDAsMCw3MlpNNDAsMzJhOCw4LDAsMSwwLDgsOEE4LDgsMCwwLDAsNDAsMzJaTTgwLDcyYTgsOCwwLDAsMC04LDhoOFoiLz48L3N2Zz4=);
		background-size: 24px;
		background-repeat: repeat;
		width: 100%;
		height: 100%;
	}

	&:after {
		content: '';
		position: absolute;
		top: 0;
		left: 0;
		background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz4KPHN2ZyBpZD0iTGF5ZXJfMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB3aWR0aD0iMTgyMCIgaGVpZ2h0PSIxMDA0Ljc3IiB2aWV3Qm94PSIwIDAgMTgyMCAxMDA0Ljc3Ij4KICA8cGF0aCBkPSJNMCwwdjEwMDQuNzdDMCwzNTcuNzcsMTgyMCw2NDYuOTksMTgyMCwwIiBzdHlsZT0iZmlsbDogI2ZmZjsiLz4KPC9zdmc+);
		background-size: 100% auto;
		background-position: 0 -10px;
		background-repeat: no-repeat;
		width: 100%;
		height: 100%;
	}

	.content-inner {
		position: relative;
		margin: 0 auto;
		max-width: 600px;
		z-index: 1;
	}
}

.notice {
	font-size: 0.8125rem;
	font-weight: 400;
	text-align: center;

	a {
		color: inherit;
	}
}

.card {
	background: white;
	border-radius: 1rem;
	padding: 1.5rem 2rem 2rem;
	box-shadow: 0px 0px 18px rgba(0, 0, 0, 0.1);

	h1 {
		margin-top: 0;
		font-size: 2rem;
		font-weight: 700;
		text-align: center;
		color: black;
	}
}

form {
	display: flex;
	flex-flow: column nowrap;
	gap: 1rem;

	p {
		margin: 0;
	}

	a {
		font-size: 0.8125rem;
		font-weight: 400;
		color: inherit;
	}

	input {
		background: white;
		border: 1px solid #bbb;
		border-radius: 0.25em;
		padding: 1em 1.25em;
		font-size: 1rem;
		color: #666;

		&[disabled] {
			background: #eee;
		}
	}

	button {
		width: 100%;
	}
}