.mainHeader {
	padding: 16px 18px 12px 18px;
	border-bottom: 1px solid var(--border);
}

	.mainHeader h2 {
		margin: 0;
		font-size: 18px;
	}

	.mainHeader .sub {
		margin: 6px 0 0 0;
		color: var(--muted);
		line-height: 1.4;
	}

.mainBody {
	padding: 16px 18px 18px 18px;
	display: grid;
	grid-template-columns: 1fr;
	gap: 14px;
}

.section {
	background: rgba(0,0,0,.14);
	border: 1px solid var(--border);
	border-radius: 14px;
	padding: 14px;
}

.sectionTitle {
	margin: 0 0 10px 0;
	font-size: 13px;
	color: var(--muted);
	text-transform: uppercase;
	letter-spacing: .08em;
}

.formGrid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
}

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

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

label {
	font-size: 13px;
	color: var(--muted);
}

input[type="number"], select {
	padding: 10px 12px;
	border-radius: 12px;
	background: var(--panel2);
	border: 1px solid var(--border);
	color: var(--text);
	outline: none;
}

.hint {
	font-size: 12px;
	color: rgba(168,179,194,.85);
	line-height: 1.35;
}

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

.btn {
	border: 1px solid var(--border);
	background: rgba(255,255,255,.04);
	color: var(--muted);
	padding: 10px 14px;
	border-radius: 12px;
	cursor: pointer;
	font-weight: 600;
}

	.btn:hover {
		background: rgba(255,255,255,.07);
	}

.warn {
	color: var(--bad);
	font-size: 13px;
	font-weight: 600;
}

.resultBox {
	display: grid;
	gap: 10px;
}

/* Allow table to scroll horizontally on small screens */
.resultValue {
	font-size: 22px;
	font-family: var(--mono);
	font-weight: 800;
	letter-spacing: 0.2px;
	overflow-x: auto;
}

.resultMeta {
	color: var(--muted);
	font-size: 13px;
	line-height: 1.4;
}

.formula {
	font-family: var(--mono);
	font-size: 13px;
	white-space: pre-wrap;
	line-height: 1.4;
	color: rgba(230,237,243,.92);
}

.note {
	font-size: 13px;
	line-height: 1.5;
	color: rgba(230,237,243,.92);
}

/* Year-by-year result table */
.resultTable {
	width: 100%;
	font-family: var(--mono);
	border-collapse: collapse;
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0;
}

	.resultTable th, .resultTable td {
		border: 1px solid var(--border);
		padding: 8px 10px;
		white-space: nowrap;
	}

	.resultTable thead th {
		background: rgba(255,255,255,.05);
		color: rgba(230,237,243,.95);
		font-weight: 800;
		text-transform: uppercase;
		letter-spacing: .08em;
		font-size: 11px;
	}

	.resultTable td {
		text-align: right;
		color: rgba(230,237,243,.92);
	}

		.resultTable td:first-child, .resultTable th:first-child {
			text-align: left;
		}

	.resultTable tbody tr:nth-child(even) td {
		background: rgba(255,255,255,.02);
	}


/* Notes enhancements */
.noteMain p {
	margin: 0 0 10px 0;
}

.noteSection {
	margin-bottom: 12px;
}

.noteSubTitle {
	margin: 0 0 6px 0;
	font-size: 12px;
	color: rgba(168,179,194,.95);
	text-transform: uppercase;
	letter-spacing: .08em;
	font-weight: 800;
}

.noteMain ul {
	margin: 0 0 10px 18px;
	padding: 0;
}

.noteMain li {
	margin: 4px 0;
}

.noteTipBox {
	margin-top: 10px;
	padding: 10px 12px;
	border-radius: 12px;
	background: rgba(0,201,122,.06);
	border: 1px solid rgba(0,201,122,.18);
}

.noteTipTitle {
	margin: 0 0 6px 0;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: .06em;
	text-transform: uppercase;
	color: rgba(230,237,243,.92);
}

.noteTipBox ul {
	margin: 0 0 0 18px;
	padding: 0;
}

.noteAdvancedWrap {
	margin-top: 10px;
}

.noteToggleBtn {
	border: 1px solid rgba(255,255,255,.10);
	background: rgba(255,255,255,.03);
	color: rgba(168,179,194,.95);
	padding: 8px 10px;
	border-radius: 12px;
	cursor: pointer;
	font-weight: 700;
	letter-spacing: .02em;
}

.noteToggleBtn:hover {
	background: rgba(255,255,255,.06);
}

.noteAdvanced {
	margin-top: 10px;
	padding: 10px 12px;
	border-radius: 12px;
	background: rgba(255,255,255,.02);
	border: 1px solid rgba(255,255,255,.08);
}

.noteAdvanced ul {
	margin: 0 0 0 18px;
	padding: 0;
}