/* ═══ KBudget-specific components ═══════════════════════════════════════════ */

/* ─── Page header ─────────────────────────────────────────────────────────── */
.page-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin: 4px 0 18px;
}
.page-head h1 { font: var(--font-h4); margin: 0; }
.page-head .sub { color: var(--text-dim); font: var(--font-body-small-regular); margin-top: 2px; }
.back-link {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	color: var(--text-dim);
	font: var(--font-body-small-semibold);
	margin-bottom: 10px;

	& .ms { font-size: 20px; }
}

/* Icons placed inside a WebAwesome button must track the label size, not the
   Material Symbols default of 24px (which otherwise dwarfs the text). */
wa-button .ms { font-size: 1.15em; line-height: 1; vertical-align: -0.16em; }

/* ─── Amount coloring ─────────────────────────────────────────────────────── */
.amount { font-variant-numeric: tabular-nums; white-space: nowrap; }
.amount.pos { color: var(--positive); }
.amount.neg { color: var(--negative); }

/* ─── Summary / stat cards ────────────────────────────────────────────────── */
.summary {
	background: var(--accent-grad);
	color: #fff;
	border-radius: var(--radius-card, 18px);
	padding: 20px;
	margin-bottom: 16px;
	box-shadow: 0 10px 26px rgba(22, 163, 74, 0.28);
}
.summary .label { font: var(--font-body-small-semibold); opacity: 0.9; display: flex; align-items: center; gap: 6px; }
.summary .value { font: var(--font-h2); margin-top: 4px; font-variant-numeric: tabular-nums; }
.summary .value.small { font: var(--font-h3); }

.stat-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
	margin-bottom: 18px;
}
.stat-card {
	background: var(--surface-2);
	border: 1px solid var(--border);
	border-radius: var(--radius-card, 16px);
	padding: 14px 16px;
}
.stat-card .label { color: var(--text-dim); font: var(--font-body-small-semibold); display: flex; align-items: center; gap: 5px; }
.stat-card .label .ms { font-size: 18px; }
.stat-card .num { font: var(--font-h5); margin-top: 4px; font-variant-numeric: tabular-nums; }

/* ─── Generic list ────────────────────────────────────────────────────────── */
.section-title {
	font: var(--font-h6);
	margin: 22px 0 10px;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.section-title a, .section-title button.link {
	color: var(--accent);
	font: var(--font-body-small-semibold);
	background: none; border: none; cursor: pointer;
	display: inline-flex; align-items: center; gap: 2px;
}

.list { display: flex; flex-direction: column; gap: 8px; }
.row {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 14px;
	background: var(--surface-2);
	border: 1px solid var(--border);
	border-radius: 14px;
	cursor: pointer;
	transition: background 0.12s;
}
.row:hover { background: var(--surface-3); }
.row .ic {
	width: 40px; height: 40px;
	flex-shrink: 0;
	border-radius: 12px;
	background: var(--surface-3);
	display: grid; place-items: center;
	color: var(--accent);
}
.row .ic .ms { font-size: 22px; }
.row .meta { flex: 1; min-width: 0; }
.row .meta .t { font: var(--font-body-large-semibold); color: var(--text); }
/* A .row can be a <label> (e.g. the file-import row); WebAwesome's global
   `label { color: … }` would otherwise mute its text. */
label.row { color: var(--text); font-weight: inherit; }
.row .meta .s { color: var(--text-dim); font: var(--font-body-small-regular); margin-top: 1px; }
.row .end { text-align: right; flex-shrink: 0; display: flex; flex-direction: column; align-items: flex-end; gap: 2px; }
.row .end .big { font: var(--font-body-large-semibold); font-variant-numeric: tabular-nums; }
.row .end .small { color: var(--text-faint); font: var(--font-body-xsmall-regular); }
.row .row-actions { display: flex; gap: 2px; flex-shrink: 0; }

.row-icon {
	background: none; border: none;
	color: var(--text-faint);
	display: grid; place-items: center;
	padding: 6px; cursor: pointer; border-radius: 50%;

	&:hover { color: var(--text); background: var(--surface-3); }
	& .ms { font-size: 20px; }
}

/* ─── Transaction register rows ───────────────────────────────────────────── */
.txn {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px 8px;
	border-bottom: 1px solid var(--border);
	cursor: pointer;
}
.txn:hover { background: var(--surface); border-radius: 10px; }
.txn .cat-ic {
	width: 38px; height: 38px; flex-shrink: 0;
	border-radius: 50%;
	display: grid; place-items: center;
	background: var(--surface-3);
	color: var(--text-dim);
}
.txn .cat-ic .ms { font-size: 20px; }
.txn .cat-ic.pos { color: var(--positive); }
.txn .body { flex: 1; min-width: 0; }
.txn .body .top { font: var(--font-body-medium-semibold); }
.txn .body .bot { color: var(--text-dim); font: var(--font-body-small-regular); margin-top: 1px; display: flex; gap: 6px; align-items: center; }
.txn .right { text-align: right; flex-shrink: 0; }
.txn .right .amt { font: var(--font-body-large-semibold); font-variant-numeric: tabular-nums; }
.txn .right .st { font-size: 14px; color: var(--text-faint); }
.txn .right .st.cleared { color: var(--accent); }
.day-head {
	display: flex; justify-content: space-between;
	color: var(--text-dim);
	font: var(--font-body-small-semibold);
	margin: 16px 4px 4px;
}

/* ─── Month selector ──────────────────────────────────────────────────────── */
.month-bar {
	display: flex; align-items: center; justify-content: center;
	gap: 14px;
	margin: 4px 0 16px;
}
.month-bar button {
	width: 38px; height: 38px;
	border-radius: 50%;
	border: 1px solid var(--border);
	background: var(--surface-2);
	color: var(--text);
	display: grid; place-items: center;
	cursor: pointer;

	&:hover { background: var(--surface-3); }
}
.month-bar .m-label { font: var(--font-body-large-bold); min-width: 160px; text-align: center; }

/* ─── Budget progress ─────────────────────────────────────────────────────── */
.budget-row {
	background: var(--surface-2);
	border: 1px solid var(--border);
	border-radius: 14px;
	padding: 13px 15px;
	margin-bottom: 9px;
}
.budget-row .br-top { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; }
.budget-row .br-name { font: var(--font-body-large-semibold); }
.budget-row .br-nums { font: var(--font-body-small-semibold); color: var(--text-dim); font-variant-numeric: tabular-nums; }
.progress {
	height: 8px;
	background: var(--surface-3);
	border-radius: 6px;
	overflow: hidden;
	margin-top: 9px;
}
.progress .fill { height: 100%; background: var(--accent); border-radius: 6px; transition: width 0.3s; }
.progress .fill.warn { background: var(--warning); }
.progress .fill.over { background: var(--negative); }
.budget-row .br-left { font: var(--font-body-xsmall-regular); color: var(--text-faint); margin-top: 6px; }

/* ─── Segmented control ───────────────────────────────────────────────────── */
.seg {
	display: flex;
	background: var(--surface-2);
	border: 1px solid var(--border);
	border-radius: 12px;
	padding: 3px;
	gap: 3px;
}
.seg button {
	flex: 1;
	border: none;
	background: none;
	color: var(--text-dim);
	font: var(--font-body-small-semibold);
	padding: 9px 6px;
	border-radius: 9px;
	cursor: pointer;
	display: inline-flex; align-items: center; justify-content: center; gap: 5px;

	& .ms { font-size: 18px; }
	&.on { background: var(--accent); color: #fff; }
}

/* ─── Sync status pill ────────────────────────────────────────────────────── */
.sync-pill {
	display: inline-flex; align-items: center; gap: 6px;
	background: var(--surface-2);
	border: 1px solid var(--border);
	border-radius: 999px;
	padding: 6px 12px;
	font: var(--font-body-small-semibold);
	color: var(--text-dim);

	& .ms { font-size: 18px; }
	& .ms.spin { animation: spin 1s linear infinite; }
	&.ok .ms { color: var(--accent); }
	&.off .ms { color: var(--warning); }
}

/* ─── Forms inside modal ──────────────────────────────────────────────────── */
/* Tall forms must scroll inside the modal so the footer stays reachable. */
.modal { overflow-y: auto; }
.modal-foot { position: sticky; bottom: 0; background: var(--surface-2); padding-bottom: 4px; }
.field { margin-bottom: 14px; }
.field > label { display: block; font: var(--font-body-small-semibold); color: var(--text-dim); margin-bottom: 6px; }
.input, .select, textarea.input {
	width: 100%;
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: 12px;
	color: var(--text);
	padding: 12px 14px;
	font: var(--font-body-large-regular);
	outline: none;

	&::placeholder { color: var(--text-faint); }
	&:focus { border-color: var(--accent); }
}
.amount-input { font: var(--font-h4); text-align: center; letter-spacing: 0.5px; }
.row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

/* ─── Charts ──────────────────────────────────────────────────────────────── */
.chart-card {
	background: var(--surface-2);
	border: 1px solid var(--border);
	border-radius: var(--radius-card, 16px);
	padding: 16px;
	margin-bottom: 16px;
}
.chart-card h3 { margin: 0 0 14px; font: var(--font-h6); }
.bars { display: flex; flex-direction: column; gap: 11px; }
.bar-row { display: grid; grid-template-columns: 110px 1fr auto; gap: 10px; align-items: center; }
.bar-row .bl { font: var(--font-body-small-medium); color: var(--text-dim); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bar-track { height: 14px; background: var(--surface-3); border-radius: 7px; overflow: hidden; }
.bar-track .bf { height: 100%; border-radius: 7px; }
.bar-row .bv { font: var(--font-body-small-semibold); font-variant-numeric: tabular-nums; }
.legend { display: flex; flex-wrap: wrap; gap: 10px 16px; margin-top: 14px; }
.legend .li { display: flex; align-items: center; gap: 6px; font: var(--font-body-small-regular); color: var(--text-dim); }
.legend .sw { width: 11px; height: 11px; border-radius: 3px; flex-shrink: 0; }
.donut-wrap { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }

/* ─── Empty state ─────────────────────────────────────────────────────────── */
/* Only the illustrative (direct-child) icon is large; icons inside an action
   button stay label-sized. */
.empty > .ms { font-size: 50px; }
.empty wa-button .ms { font-size: 1.15em; }

/* ─── Pill chips for category kind etc. ───────────────────────────────────── */
.tag {
	display: inline-flex; align-items: center;
	font: var(--font-body-xsmall-bold);
	padding: 2px 8px;
	border-radius: 999px;
	background: var(--surface-3);
	color: var(--text-dim);
	text-transform: uppercase;
	letter-spacing: 0.4px;
}
.tag.income { background: color-mix(in oklch, var(--positive) 20%, transparent); color: var(--positive); }
.tag.expense { background: color-mix(in oklch, var(--negative) 18%, transparent); color: var(--negative); }
