.wrap.tools {
	padding: 10px 20px 28px;
}

.b64-panel {
	border: 1px solid var(--border);
	border-radius: var(--radius);
	background: linear-gradient(180deg, rgba(255, 255, 255, .03), rgba(255, 255, 255, .01));
	box-shadow: var(--shadow);
}

.b64-head {
	padding: 14px;
	border-bottom: 1px solid var(--border);
}

.b64-title {
	margin: 0 0 6px;
	font-size: 16px;
}

.b64-msg {
	margin: 0;
	color: var(--muted);
}

.b64-body {
	padding: 14px;
	display: grid;
	gap: 16px;
}

.row {
	display: grid;
	gap: var(--gap);
}

.row.cols-2 {
	grid-template-columns: 1fr 1fr;
}

.row.cols-3 {
	grid-template-columns: 1fr 1fr 1fr;
}

@media (max-width: 980px) {

	.row.cols-2,
	.row.cols-3 {
		grid-template-columns: 1fr;
	}
}

.field {
	display: grid;
	gap: 6px;
}

.field input[type="text"],
.field textarea {
	padding: 10px 12px;
	border: 1px solid var(--border);
	border-radius: 10px;
	background: var(--panel);
	color: var(--text);
	font-size: 14px;
}

textarea#outputText {
	cursor: pointer;
}

.seg {
	display: inline-flex;
	gap: 10px;
	flex-wrap: wrap;
}

.cb {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.cb input {
	width: 16px;
	height: 16px;
	accent-color: var(--accent);
}

.hidden-input {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0 0 0 0);
	border: 0;
}

.pill-muted {
	color: var(--muted);
}

.dropzone {
	position: relative;
	display: grid;
	place-items: center;
	padding: 16px;
	min-height: 120px;
	background: repeating-linear-gradient(135deg, rgba(255, 255, 255, .02) 0 6px, rgba(255, 255, 255, 0) 6px 12px);
	border: 1px dashed #39404b;
	border-radius: var(--radius);
	transition: border-color .2s, background .2s, box-shadow .2s;
	text-align: center;
	color: var(--muted);
	font-size: 14px;
}

.dropzone.dragover {
	border-color: var(--accent);
	background: radial-gradient(600px 300px at 50% 0%, rgba(101, 78, 163, .09), transparent 60%);
	box-shadow: inset 0 0 0 1px rgba(101, 78, 163, .35);
	color: var(--text);
}

.mode-wrap {
	display: grid;
	gap: 10px;
}

.mode-row {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	align-items: center;
}

.stats {
	display: grid;
	grid-template-columns: repeat(3, minmax(180px, 1fr));
	gap: 10px;
}

@media (max-width: 980px) {
	.stats {
		grid-template-columns: 1fr;
	}
}

.stat {
	border: 1px solid var(--border);
	border-radius: 10px;
	background: var(--panel);
	padding: 10px 12px;
	font-size: 13px;
	color: var(--muted);
}

.stat strong {
	color: var(--text);
}