form.form {
	margin: 0 10%;
	padding: 10px;
	border-radius: 5px;
	background-color: rgba(0, 0, 0, 0.6);
	border: 2px solid black;
	color: white;
	display: flex;
	flex-direction: column;
}

form.form:nth-child(n+1) {
	margin-top: 20px;
}

form.form h2.form-title {
	text-align: center;
	padding: 20px 0;
}

form.form div.input-box {
	display: flex;
	flex-direction: column;
}
form.form div.input-box:last-child {
	margin-top: 20px;
}
form.form div.input-box label {
	font-size: 24px;
}
form.form div.input-box input, form.form div.input-box select, form.form div.input-box textarea {
	font-size: 24px;
	padding: 8px;
}
form.form div.input-box textarea {
	resize: vertical;
	min-height: 200px;
}
form.form div.input-box input[type="submit"] {
	cursor: pointer;
}

form.form div.input-box label.file-uploader {
	position: relative;
	border: 3px dashed black;
	border-radius: 5px;
	padding: 5px;
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	justify-content: center;
	align-content: center;
	text-align: center;
	background-color: rgba(0, 0, 0, 0.4);
	height: 300px;

	transition: background 0.1s;
}
form.form div.input-box label.file-uploader:hover {
	background-color: rgba(0, 0, 0, 0.5);

	transition: background 0.1s;
}
form.form div.input-box label.file-uploader span.uploader-title {
	font-weight: 900;
}
form.form div.input-box label.file-uploader input.uploader-input {
	background-color: rgba(255, 255, 255, 0.1);
	padding: 5px;
	margin: 5px;
}
form.form div.input-box label.file-uploader input.uploader-input:focus {
	outline: 2px dashed rgba(255, 255, 255, 0.2);
	outline-offset: 2px;
}
form.form div.input-box label.file-uploader input.uploader-input::file-selector-button {
	margin-right: 8px;
	border: none;
	background: rgba(0, 0, 0, 0.5);
	padding: 8px 12px;
	color: #fff;
	cursor: pointer;

	transition: background 0.1s;
}
form.form div.input-box label.file-uploader input.uploader-input::file-selector-button:hover {
	background: rgba(0, 0, 0, 1);

	transition: background 0.1s;
}

form.form div.input-box label.file-uploader div.uploader-bar {
	position: relative;
	background-color: rgba(0, 0, 0, 1.0);
	height: 30px;
	border-radius: 4px;
	padding: 3px;
}
form.form div.input-box label.file-uploader div.uploader-bar div.uploader-bar-color {
	background-color: rgba(255, 255, 255, 0.5);
	height: 100%;
	width: 0.1%;
}
form.form div.input-box label.file-uploader div.uploader-bar p.bar-percentage {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

form.form div.input-box label.file-uploader div.drag-popup {
	position: absolute;
	display: none;
	flex-direction: column;
	justify-content: center;
	align-content: center;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	background-color: rgba(0, 0, 0, 0.8);
}
form.form div.input-box label.file-uploader.drag-active div.drag-popup {
	display: flex;
}


form.freeform {
	/**/
}

form.freeform input, form.freeform select, form.freeform textarea {
	padding: 8px;
	font-size: 20px;
}
form.freeform input[type="submit"] {
	cursor: pointer;
}
form.freeform textarea {
	resize: vertical;
}

form.freeform label.error {
	color: red;
}