:root {
	--primary-color: #6c31e3;
	--text-color: #eeeeee;
	--link-color: var(--primary-color);
	--link-hover-color: darken(var(--primary-color), 10%);

	--gap: 1rem;
	--border-radius: 0.5rem;
}

html,
body {
	margin: 0;
	padding: 0;
	font-family: Arial, sans-serif;
	background-color: #1b1b1b;
	color: var(--text-color);
	font-size: 18px;
}

body {
	display: flex;
	flex-direction: column;
	min-height: 100vh;

	& > main {
		flex-grow: 1;
	}

	& > footer {
		color: white;
		padding-block: var(--gap);
		text-align: center;

		& a {
			color: white;
		}
	}
}

header {
	background-color: var(--primary-color);
	color: var(--text-color);
	display: flex;
	gap: var(--gap);
	padding-inline: var(--gap);
}

section.main {
	padding-inline: var(--gap);
}

input {
	font-size: 1rem;
	padding: var(--gap);
	border-radius: var(--border-radius);
}

button {
	background-color: var(--primary-color);
	color: white;
	padding: 0.25rem;
	box-shadow: none;
	border-radius: var(--border-radius);
	font-size: 1rem;
}

a {
	color: var(--primary-color);
}

.output-area {
	width: 100%;
	display: flex;
	background-color: white;
	border-radius: var(--border-radius);
	align-items: center;
	padding: var(--gap);
	box-sizing: border-box;
	margin-top: calc(var(--gap) * 2);
	gap: var(--gap);
}

#link-output {
	flex: 1;
	word-break: break-all;
}

.output-area:has(#link-output[href='#']) {
	display: none;
}

.input-area {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	gap: var(--gap);
	/* align-items: space-between; */
	justify-content: center;

	& input {
		flex: 1;
		min-width: 80%;
	}

	& button {
		padding: 1rem;
	}
}
