/* Make Lemons webapp — warm-glow styling.
   Brand tokens mirror ADR-014. Mobile-first; the layout is one column.
   The whole page sits on a soft sun-glow gradient — every surface is
   meant to feel like a kitchen at 9am, not a banking dashboard. */

:root {
	--color-lemon:        #F4C948;
	--color-lemon-light:  #FFE08A;
	--color-sunlit:       #E8AD2D;
	--color-sunlit-deep:  #C97E1A;
	--color-cream:        #FBF6E9;
	--color-cream-warm:   #FFF3D6;
	--color-snow:         #FFFCF4;
	--color-bone:         #EDE7D6;
	--color-mid-soft:     #E6DEC8;
	--color-ink:          #2C2A26;
	--color-deep:         #2C2A26;
	--color-mid:          #6F6B62;
	--color-muted:        #968F82;
	--color-success:      #2B6A3F;
	--color-success-bg:   #DDEFD8;
	--color-warn:         #C2410C;
	--color-citrus-deep:  #B3580E;
	--color-danger:       #7F1D1D;
	--radius-card: 16px;
	--radius-input: 10px;
	--radius-pill: 999px;
	--shadow-card:   0 1px 0 rgba(255, 233, 168, 0.50) inset,
	                 0 2px 4px rgba(180, 130, 30, 0.06),
	                 0 10px 24px rgba(180, 130, 30, 0.08);
	--shadow-lifted: 0 1px 0 rgba(255, 233, 168, 0.55) inset,
	                 0 6px 14px rgba(180, 130, 30, 0.10),
	                 0 18px 40px rgba(180, 130, 30, 0.10);
	--shadow-glow:   0 0 0 4px rgba(244, 201, 72, 0.18),
	                 0 8px 20px rgba(232, 173, 45, 0.30);
	font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
	font-feature-settings: 'tnum' 1, 'ss01' 1;
}

* { box-sizing: border-box; }

html, body {
	margin: 0;
	padding: 0;
	color: var(--color-ink);
	-webkit-font-smoothing: antialiased;
	overflow-x: hidden;
	min-height: 100%;
}
body {
	background:
		radial-gradient(1200px 600px at 50% -180px,
			rgba(244, 201, 72, 0.35) 0%,
			rgba(244, 201, 72, 0.10) 35%,
			transparent 65%),
		linear-gradient(180deg, var(--color-cream-warm) 0%, var(--color-cream) 28%, var(--color-cream) 100%);
	background-attachment: fixed;
}

/* Optional decorative second glow further down the page — kept light so
   it never interferes with reading. The aria-hidden div in Layout
   positions it; the gradient is what does the work. */
.sun-glow {
	position: fixed;
	pointer-events: none;
	z-index: 0;
	top: 28rem;
	right: -12rem;
	width: 28rem;
	height: 28rem;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(244, 201, 72, 0.18), transparent 65%);
	filter: blur(40px);
}

a { color: inherit; text-decoration: none; }

/* Display heads use Fraunces — the warm serif from ADR-014. Falls back
   to a system serif if Bunny Fonts hasn't loaded yet. */
h1, h2, h3 {
	font-family: 'Fraunces', ui-serif, Georgia, 'Times New Roman', serif;
	font-feature-settings: 'ss01' 1;
	font-weight: 500;
	letter-spacing: -0.01em;
	color: var(--color-deep);
}

.brand-bar {
	display: flex;
	align-items: center;
	padding: 16px 20px 14px;
	background: linear-gradient(180deg,
		rgba(255, 252, 244, 0.85) 0%,
		rgba(255, 252, 244, 0.70) 100%);
	backdrop-filter: saturate(120%) blur(10px);
	-webkit-backdrop-filter: saturate(120%) blur(10px);
	border-bottom: 1px solid rgba(244, 201, 72, 0.30);
	position: sticky;
	top: 0;
	z-index: 10;
}
.brand-mark { display: inline-flex; align-items: center; gap: 10px; font-weight: 600; }
.brand-emoji {
	font-size: 24px;
	display: inline-flex;
	transform-origin: 70% 70%;
	transition: transform 280ms cubic-bezier(0.2, 0.7, 0.2, 1);
}
.brand-mark:hover .brand-emoji { transform: rotate(-10deg) scale(1.08); }
.brand-name {
	font-family: 'Fraunces', ui-serif, Georgia, serif;
	font-size: 19px;
	font-weight: 500;
	letter-spacing: -0.005em;
}

.page {
	position: relative;
	z-index: 1;
	max-width: 640px;
	margin: 0 auto;
	padding: 20px 16px 96px;
	box-sizing: border-box;
}
@media (min-width: 420px) {
	.page { padding: 28px 24px 96px; }
}

/* ─── Login ───────────────────────────────────────────────────────────── */

.login-card {
	background: linear-gradient(180deg, var(--color-snow) 0%, #fffbed 100%);
	border-radius: var(--radius-card);
	padding: 32px 26px;
	box-shadow: var(--shadow-lifted);
	margin-top: 32px;
	border: 1px solid rgba(244, 201, 72, 0.18);
}
.login-title {
	font-family: 'Fraunces', ui-serif, Georgia, serif;
	font-weight: 500;
	font-size: 32px;
	margin: 0 0 6px;
	letter-spacing: -0.01em;
}
.login-sub { color: var(--color-mid); margin: 0 0 22px; font-size: 15px; }

.form-stack { display: flex; flex-direction: column; gap: 14px; }
.form-stack label { display: flex; flex-direction: column; gap: 6px; }
.form-label { font-size: 13px; color: var(--color-mid); letter-spacing: 0.005em; }
.form-stack input {
	font: inherit;
	font-size: 17px;
	padding: 12px 14px;
	border: 1px solid var(--color-mid-soft);
	border-radius: var(--radius-input);
	background: #fffdf7;
	transition: border-color 120ms ease, box-shadow 200ms ease;
}
.form-stack input:focus {
	outline: none;
	border-color: var(--color-sunlit);
	box-shadow: 0 0 0 4px rgba(244, 201, 72, 0.20);
}
.form-inline { flex-direction: row; align-items: center; gap: 12px; }
.form-inline input { width: 80px; }

.form-error {
	background: #fef3f2;
	border: 1px solid #fecaca;
	color: var(--color-danger);
	padding: 10px 12px;
	border-radius: 8px;
	margin-bottom: 16px;
	font-size: 14px;
}

.btn {
	font: inherit;
	font-weight: 600;
	border: 0;
	cursor: pointer;
	padding: 12px 20px;
	border-radius: var(--radius-input);
	transition: transform 120ms cubic-bezier(0.2, 0.7, 0.2, 1),
	            box-shadow 160ms ease, background 160ms ease;
}
.btn:active { transform: translateY(1px) scale(0.99); }
.btn-primary {
	background: linear-gradient(180deg, var(--color-lemon-light) 0%, var(--color-lemon) 55%, var(--color-sunlit) 100%);
	color: #3a2a06;
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 0.55) inset,
		0 -1px 0 rgba(180, 130, 30, 0.12) inset,
		0 4px 12px rgba(232, 173, 45, 0.25);
}
.btn-primary:hover {
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 0.65) inset,
		0 -1px 0 rgba(180, 130, 30, 0.14) inset,
		0 6px 16px rgba(232, 173, 45, 0.40);
	transform: translateY(-1px);
}
.btn-secondary {
	background: #fffdf6;
	color: var(--color-deep);
	border: 1px solid rgba(244, 201, 72, 0.40);
	box-shadow: 0 1px 0 rgba(255, 255, 255, 0.6) inset;
}
.btn-secondary:hover { background: #fff8e3; border-color: rgba(244, 201, 72, 0.65); }
.btn-link { background: transparent; color: var(--color-sunlit-deep); padding: 6px 4px; font-weight: 500; }
.btn-link:hover { color: var(--color-deep); }

/* ─── Home ────────────────────────────────────────────────────────────── */

.home-head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 16px;
	margin: 8px 0 24px;
}
.home-head h1 {
	margin: 0;
	font-family: 'Fraunces', ui-serif, Georgia, serif;
	font-weight: 500;
	font-size: 34px;
	letter-spacing: -0.015em;
	line-height: 1.1;
	background: linear-gradient(180deg, var(--color-deep) 0%, #5a4a18 100%);
	background-clip: text;
	-webkit-background-clip: text;
	color: transparent;
}

.recompute-form { display: flex; align-items: flex-end; gap: 10px; }

.group { margin-bottom: 28px; }
.group h2 {
	font-family: 'Inter', system-ui, sans-serif;
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--color-sunlit-deep);
	margin: 0 0 12px;
}

.directive-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }

.directive {
	background: linear-gradient(180deg, #fffef9 0%, var(--color-snow) 100%);
	border-radius: var(--radius-card);
	padding: 18px 18px 16px;
	box-shadow: var(--shadow-card);
	border: 1px solid rgba(244, 201, 72, 0.16);
	transition: transform 200ms ease, box-shadow 200ms ease;
}
.directive:hover {
	transform: translateY(-1px);
	box-shadow: var(--shadow-lifted);
}
.directive-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 8px; }

.pill {
	display: inline-block;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	padding: 5px 11px;
	border-radius: var(--radius-pill);
	background: linear-gradient(180deg, #fff5ce 0%, #fdedb8 100%);
	color: var(--color-sunlit-deep);
	border: 1px solid rgba(244, 201, 72, 0.40);
}
.pill-question { background: linear-gradient(180deg, #fff0c2 0%, #fde08a 100%); color: #7a4d00; }

.amount {
	font-variant-numeric: tabular-nums;
	font-weight: 600;
	font-size: 16px;
}

.directive-headline { margin: 0 0 6px; font-size: 16px; line-height: 1.4; color: var(--color-deep); }
.directive-headline strong { color: var(--color-deep); }
.directive-reason { margin: 0 0 14px; color: var(--color-mid); font-size: 14px; line-height: 1.55; }

.directive-actions { display: flex; gap: 8px; }
.btn-action {
	flex: 1;
	padding: 10px 14px;
	font-size: 14px;
	border: 1px solid rgba(244, 201, 72, 0.30);
	background: #fffdf6;
	color: var(--color-deep);
	border-radius: var(--radius-input);
	transition: background 160ms ease, border-color 160ms ease, box-shadow 200ms ease;
}
.btn-action:hover { background: #fff7df; border-color: rgba(244, 201, 72, 0.55); }
.btn-done {
	background: linear-gradient(180deg, #e3f3da 0%, var(--color-success-bg) 100%);
	color: var(--color-success);
	border-color: rgba(43, 106, 63, 0.20);
}
.btn-done:hover { background: linear-gradient(180deg, #d4ebc6 0%, #c8e8be 100%); }
.btn-defer { background: #fffdf6; color: var(--color-deep); }
.btn-dismiss { background: #fffdf6; color: var(--color-mid); }

.dismiss-reasons {
	background: var(--color-cream);
	border-radius: 10px;
	padding: 12px;
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.dismiss-prompt { margin: 0; font-size: 13px; color: var(--color-mid); }
.reason-buttons { display: flex; flex-wrap: wrap; gap: 6px; }
.btn-reason {
	background: var(--color-snow);
	border: 1px solid var(--color-bone);
	padding: 8px 12px;
	font-size: 13px;
	border-radius: 8px;
}
.btn-reason:hover { background: var(--color-lemon); }

.empty {
	position: relative;
	background:
		radial-gradient(160px 100px at 50% 0%, rgba(244, 201, 72, 0.20), transparent 70%),
		linear-gradient(180deg, #fffef7 0%, var(--color-snow) 100%);
	border-radius: var(--radius-card);
	padding: 36px 22px 28px;
	color: var(--color-mid);
	text-align: center;
	border: 1px solid rgba(244, 201, 72, 0.20);
	box-shadow: var(--shadow-card);
}
.empty p { margin: 0 0 10px; }
.empty p:first-child { color: var(--color-deep); font-size: 16px; font-weight: 500; }
.empty p:last-child { margin-bottom: 0; font-size: 14px; }
.empty::before {
	content: "🍋";
	display: block;
	font-size: 32px;
	margin-bottom: 8px;
	filter: drop-shadow(0 4px 12px rgba(232, 173, 45, 0.35));
}

/* ─── Auth (login/register/TOTP) ─────────────────────────────────────────── */

.auth-card {
	background: linear-gradient(180deg, var(--color-snow) 0%, #fffbed 100%);
	border-radius: var(--radius-card);
	padding: 32px 26px;
	box-shadow: var(--shadow-lifted);
	margin-top: 32px;
	border: 1px solid rgba(244, 201, 72, 0.18);
}
.auth-card-wide { max-width: 540px; margin-left: auto; margin-right: auto; }
.auth-title {
	font-family: 'Fraunces', ui-serif, Georgia, serif;
	font-weight: 500;
	font-size: 28px;
	margin: 0 0 6px;
	letter-spacing: -0.01em;
}
.auth-sub { color: var(--color-mid); margin: 0 0 22px; font-size: 15px; }
.auth-fine { color: var(--color-mid); margin: 12px 0 0; font-size: 13px; }

.totp-qr-wrap {
	display: flex;
	justify-content: center;
	margin: 8px 0 16px;
}
.totp-qr {
	width: 200px; height: 200px;
	background: white;
	padding: 8px;
	border-radius: 12px;
	border: 1px solid rgba(244, 201, 72, 0.30);
	box-shadow: var(--shadow-card);
}
.totp-secret {
	background: white;
	border: 1px dashed rgba(244, 201, 72, 0.55);
	border-radius: 10px;
	padding: 10px 12px;
	font: 16px/1.4 ui-monospace, SFMono-Regular, Menlo, monospace;
	letter-spacing: 0.05em;
	text-align: center;
	user-select: all;
}

/* ─── Welcome (onboarding wizard) ─────────────────────────────────────────── */

.welcome { padding: 0 4px; }
.welcome-head h1 {
	font-family: 'Fraunces', ui-serif, Georgia, serif;
	font-weight: 500;
	font-size: 32px;
	margin: 8px 0 8px;
	letter-spacing: -0.015em;
}
.welcome-sub { color: var(--color-mid); margin: 0 0 18px; font-size: 15px; line-height: 1.5; }
.welcome-form { display: flex; flex-direction: column; gap: 16px; }
.welcome-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
}
.welcome-card {
	display: flex;
	gap: 10px;
	align-items: center;
	padding: 14px 14px;
	background: linear-gradient(180deg, #fffdf3 0%, var(--color-snow) 100%);
	border: 1px solid rgba(244, 201, 72, 0.22);
	border-radius: var(--radius-card);
	box-shadow: var(--shadow-card);
	cursor: pointer;
	transition: border-color 160ms ease, transform 160ms ease, box-shadow 160ms ease;
}
.welcome-card:hover {
	border-color: rgba(244, 201, 72, 0.55);
	transform: translateY(-1px);
}
.welcome-card input[type="checkbox"] {
	flex: 0 0 auto;
	width: 18px;
	height: 18px;
	accent-color: var(--color-sunlit);
}
.welcome-card:has(input:checked) {
	background: linear-gradient(180deg, #fff4cd 0%, #fff8dc 100%);
	border-color: var(--color-sunlit);
	box-shadow: var(--shadow-glow);
}
.welcome-emoji { font-size: 22px; flex: 0 0 auto; }
.welcome-question { font-size: 14px; line-height: 1.35; color: var(--color-deep); }
.welcome-actions { display: flex; gap: 14px; align-items: center; }

/* ─── Squeeze tasks + upsell band ────────────────────────────────────────── */

.task-section-head {
	font-family: 'Inter', system-ui, sans-serif;
	margin: 22px 0 4px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--color-sunlit-deep);
}
.task-section-sub {
	margin: 0 0 12px;
	color: var(--color-mid);
	font-size: 13px;
	line-height: 1.5;
}

.task-list { list-style: none; padding: 0; margin: 8px 0 24px; display: flex; flex-direction: column; gap: 10px; }
.task-row {
	padding: 14px 16px;
	background: linear-gradient(180deg, #fffef8 0%, var(--color-snow) 100%);
	border-radius: var(--radius-card);
	border: 1px solid rgba(244, 201, 72, 0.18);
	box-shadow: var(--shadow-card);
}
.task-row-main { display: flex; flex-direction: column; gap: 4px; }
.task-title { font-weight: 600; font-size: 15px; color: var(--color-deep); }
.task-meta { display: flex; gap: 6px; align-items: baseline; font-size: 13px; color: var(--color-mid); flex-wrap: wrap; }
.task-due { font-variant-numeric: tabular-nums; }
.task-dot { color: var(--color-mid-soft); }
.task-cost {
	font-variant-numeric: tabular-nums;
	color: var(--color-mid);
	font-weight: 500;
	display: inline-flex;
	align-items: baseline;
	gap: 4px;
}
.task-cost-tilde { color: var(--color-muted); font-size: 12px; }
.task-cost-label {
	font-size: 11px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--color-muted);
	font-weight: 600;
	margin-left: 2px;
}

.welcome-banner {
	display: flex;
	gap: 12px;
	align-items: flex-start;
	margin: 8px 0 18px;
	padding: 14px 16px;
	background:
		radial-gradient(20rem 8rem at 0% 0%, rgba(244, 201, 72, 0.28), transparent 70%),
		linear-gradient(180deg, #fff4cd 0%, #fff8dc 100%);
	border: 1px solid rgba(244, 201, 72, 0.45);
	border-radius: var(--radius-card);
	box-shadow: var(--shadow-card);
}
.welcome-banner-emoji {
	font-size: 26px;
	filter: drop-shadow(0 4px 12px rgba(232, 173, 45, 0.40));
	flex: 0 0 auto;
}
.welcome-banner-body { display: flex; flex-direction: column; gap: 2px; }
.welcome-banner-body strong { font-size: 15px; color: var(--color-deep); }
.welcome-banner-body span:last-child { font-size: 13px; color: var(--color-mid); line-height: 1.5; }

.upsell-block {
	margin-top: 28px;
	padding: 20px;
	background:
		radial-gradient(180px 100px at 100% 0%, rgba(244, 201, 72, 0.22), transparent 70%),
		linear-gradient(180deg, #fffdf6 0%, var(--color-snow) 100%);
	border: 1px solid rgba(244, 201, 72, 0.30);
	border-radius: var(--radius-card);
	box-shadow: var(--shadow-card);
}
.upsell-block h2 {
	font-family: 'Inter', system-ui, sans-serif;
	margin: 0 0 6px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--color-sunlit-deep);
}
.upsell-block p { margin: 0 0 14px; font-size: 14px; color: var(--color-deep); line-height: 1.5; }

/* ─── Recovery codes ────────────────────────────────────────────────────── */

.recovery { padding: 0 16px; }
.recovery-head { margin: 4px 0 16px; }
.recovery-head h1 { margin: 4px 0; font-family: 'Fraunces', ui-serif, Georgia, serif; font-weight: 500; font-size: 32px; letter-spacing: -0.015em; line-height: 1.1; }
.recovery-sub { margin: 4px 0 12px; color: var(--color-mid); font-size: 14px; }
.recovery-warning {
	background: #fff4d4;
	color: #6b4e00;
	padding: 10px 12px;
	border-radius: var(--radius-card);
	font-size: 14px;
}
.recovery-fresh {
	background: var(--color-snow);
	border-radius: var(--radius-card);
	padding: 16px;
	margin-bottom: 16px;
}
.recovery-fresh h2 { margin: 0 0 8px; font-size: 16px; }
.recovery-codes {
	font: 18px/1.5 ui-monospace, SFMono-Regular, Menlo, monospace;
	letter-spacing: 0.04em;
	padding-left: 24px;
}
.recovery-codes code { background: white; padding: 4px 8px; border-radius: 6px; }

/* ─── Manual transaction form ────────────────────────────────────────────── */

.tx-new { padding: 0 16px; }
.tx-new-head { margin: 4px 0 16px; }
.tx-new-head h1 { margin: 4px 0; font-family: 'Fraunces', ui-serif, Georgia, serif; font-weight: 500; font-size: 32px; letter-spacing: -0.015em; line-height: 1.1; }
.tx-new-sub { margin: 4px 0 0; color: var(--color-mid); font-size: 14px; }

.tx-form {
	background: linear-gradient(180deg, #fffdf6 0%, var(--color-snow) 100%);
	border-radius: var(--radius-card);
	padding: 18px;
	display: flex;
	flex-direction: column;
	gap: 14px;
	border: 1px solid rgba(244, 201, 72, 0.18);
	box-shadow: var(--shadow-card);
}
.tx-form label { display: flex; flex-direction: column; gap: 4px; font-size: 13px; }
.tx-form input, .tx-form select {
	padding: 10px 12px;
	font: 15px/1.2 inherit;
	border: 1px solid var(--color-mid-soft, #e6e2d8);
	border-radius: 8px;
	background: white;
}

/* ─── Household / invites ───────────────────────────────────────────────── */

.household { padding: 0 16px; }
.household-head { margin: 4px 0 16px; }
.household-head h1 { margin: 4px 0; font-family: 'Fraunces', ui-serif, Georgia, serif; font-weight: 500; font-size: 32px; letter-spacing: -0.015em; line-height: 1.1; }
.household-sub { margin: 4px 0 0; color: var(--color-mid); font-size: 14px; }

.invite-list { list-style: none; padding: 0; margin: 8px 0 24px; }
.invite-row {
	padding: 14px 16px;
	background: linear-gradient(180deg, #fffef8 0%, var(--color-snow) 100%);
	border-radius: var(--radius-card);
	margin-bottom: 10px;
	border: 1px solid rgba(244, 201, 72, 0.18);
	box-shadow: var(--shadow-card);
}
.invite-head {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 8px;
	margin-bottom: 6px;
}
.invite-email { font-weight: 600; font-size: 15px; word-break: break-all; }
.invite-status { font-size: 12px; color: var(--color-mid); white-space: nowrap; }
.invite-url-row { display: flex; gap: 8px; }
.invite-url {
	flex: 1 1 auto;
	min-width: 0;
	padding: 8px 10px;
	font: 12px/1.3 ui-monospace, SFMono-Regular, Menlo, monospace;
	background: white;
	border: 1px solid var(--color-mid-soft, #e6e2d8);
	border-radius: 8px;
}
.invite-expires { font-size: 12px; color: var(--color-mid); margin-top: 6px; }

.invite-form {
	background: var(--color-snow);
	border-radius: var(--radius-card);
	padding: 16px;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.invite-form h2 { margin: 0; font-size: 16px; }
.invite-form label { display: flex; flex-direction: column; gap: 4px; font-size: 13px; }
.invite-form small { color: var(--color-mid); font-size: 12px; }
.invite-form input {
	padding: 10px 12px;
	font: 15px/1.2 inherit;
	border: 1px solid var(--color-mid-soft, #e6e2d8);
	border-radius: 8px;
}

.invite-landing { padding: 24px 16px; max-width: 480px; margin: 0 auto; }
.invite-landing h1 { margin: 0 0 16px; font-size: 26px; }
.invite-landing p { font-size: 16px; line-height: 1.4; }

/* ─── Debts ─────────────────────────────────────────────────────────────── */

.debts { padding: 0 16px; }
.debts-head { margin: 4px 0 16px; }
.debts-head h1 { margin: 4px 0; font-family: 'Fraunces', ui-serif, Georgia, serif; font-weight: 500; font-size: 32px; letter-spacing: -0.015em; line-height: 1.1; }
.debts-sub { margin: 4px 0 0; color: var(--color-mid); font-size: 14px; }

.debt-list { list-style: none; padding: 0; margin: 8px 0 24px; }
.debt-row {
	padding: 14px 16px;
	background: linear-gradient(180deg, #fffef8 0%, var(--color-snow) 100%);
	border-radius: var(--radius-card);
	margin-bottom: 10px;
	border: 1px solid rgba(244, 201, 72, 0.18);
	box-shadow: var(--shadow-card);
}
.debt-name { font-weight: 600; font-size: 16px; }
.debt-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 4px;
	font-size: 13px;
	color: var(--color-mid);
}
.debt-apr { font-variant-numeric: tabular-nums; font-weight: 600; color: var(--color-citrus-deep, #b3580e); }

.debt-form {
	background: linear-gradient(180deg, #fffdf6 0%, var(--color-snow) 100%);
	border-radius: var(--radius-card);
	padding: 18px;
	display: flex;
	flex-direction: column;
	gap: 14px;
	border: 1px solid rgba(244, 201, 72, 0.18);
	box-shadow: var(--shadow-card);
}
.debt-form h2 { margin: 0; font-size: 16px; }
.debt-form label { display: flex; flex-direction: column; gap: 4px; font-size: 13px; }
.debt-form input {
	padding: 10px 12px;
	font: 15px/1.2 inherit;
	border: 1px solid var(--color-mid-soft, #e6e2d8);
	border-radius: 8px;
}
.form-error {
	background: #fdecea;
	color: #a4170c;
	border-radius: var(--radius-card);
	padding: 12px 14px;
	margin: 0 0 16px;
	font-size: 14px;
}

/* ─── Audit / Activity log ──────────────────────────────────────────────── */

.audit { padding: 0 16px; }
.audit-head { margin: 4px 0 20px; }
.audit-head h1 { margin: 4px 0; font-family: 'Fraunces', ui-serif, Georgia, serif; font-weight: 500; font-size: 32px; letter-spacing: -0.015em; line-height: 1.1; }
.audit-period { margin: 4px 0 0; color: var(--color-mid); font-size: 14px; }

.audit-list { list-style: none; padding: 0; margin: 8px 0 0; }
.audit-row {
	padding: 10px 0;
	border-bottom: 1px solid var(--color-mid-soft, #eee5d2);
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 2px 12px;
	align-items: baseline;
}
.audit-when { grid-column: 1 / -1; font-size: 12px; color: var(--color-mid); }
.audit-line { grid-column: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.audit-action { font-weight: 600; font-size: 14px; }
.audit-note { color: var(--color-deep); font-size: 14px; }
.audit-actor { grid-column: 2; font-size: 12px; color: var(--color-mid); }

/* ─── Calendar subscription block (Home) ─────────────────────────────────── */

.calendar-block {
	margin-top: 28px;
	padding: 20px;
	background:
		radial-gradient(180px 100px at 100% 0%, rgba(244, 201, 72, 0.22), transparent 70%),
		linear-gradient(180deg, #fffdf6 0%, var(--color-snow) 100%);
	border-radius: var(--radius-card);
	border: 1px solid rgba(244, 201, 72, 0.22);
	box-shadow: var(--shadow-card);
}
.calendar-block h2 {
	font-family: 'Inter', system-ui, sans-serif;
	margin: 0 0 6px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--color-sunlit-deep);
}
.calendar-block p { margin: 0 0 12px; font-size: 14px; color: var(--color-deep); }
.calendar-url-row {
	display: flex;
	gap: 8px;
	align-items: stretch;
	margin-bottom: 8px;
}
.calendar-url {
	flex: 1 1 auto;
	min-width: 0;
	padding: 8px 10px;
	font: 13px/1.3 ui-monospace, SFMono-Regular, Menlo, monospace;
	background: white;
	border: 1px solid var(--color-mid-soft, #e6e2d8);
	border-radius: var(--radius-input, 8px);
	color: var(--color-deep);
}
.calendar-rotate-form {
	display: flex;
	flex-direction: column;
	gap: 4px;
	margin-top: 4px;
}
.calendar-rotate-form small { color: var(--color-mid); font-size: 12px; }
.btn-danger-link {
	color: var(--color-citrus-deep, #b3580e);
	padding: 0;
	background: none;
	border: 0;
	text-align: left;
	font-size: 13px;
	cursor: pointer;
}
.btn-danger-link:hover { text-decoration: underline; }

/* ─── Money Dashboard ──────────────────────────────────────────────────── */

.home-head-actions { display: flex; flex-direction: column; align-items: flex-end; gap: 6px; }

.money-nav { margin-bottom: 8px; }
.money-head { margin: 4px 0 20px; }
.money-head h1 {
	margin: 0;
	font-family: 'Fraunces', ui-serif, Georgia, serif;
	font-weight: 500;
	font-size: 34px;
	letter-spacing: -0.015em;
}
.money-period { margin: 4px 0 0; color: var(--color-mid); font-size: 14px; }

.net-worth {
	background:
		radial-gradient(220px 120px at 0% 0%, rgba(244, 201, 72, 0.22), transparent 70%),
		linear-gradient(180deg, #fffdf3 0%, var(--color-snow) 100%);
	border-radius: var(--radius-card);
	padding: 22px;
	box-shadow: var(--shadow-card);
	margin-bottom: 16px;
	border: 1px solid rgba(244, 201, 72, 0.20);
}
.net-worth-label { font-size: 11px; color: var(--color-sunlit-deep); margin: 0 0 6px; text-transform: uppercase; letter-spacing: 0.12em; font-weight: 600; }
.net-worth-amount {
	margin: 0;
	font-family: 'Fraunces', ui-serif, Georgia, serif;
	font-weight: 500;
	font-size: 36px;
	font-variant-numeric: tabular-nums;
	letter-spacing: -0.02em;
	color: var(--color-deep);
}

.month-summary {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 8px;
	margin-bottom: 24px;
}
.summary-card {
	background: linear-gradient(180deg, #fffdf6 0%, var(--color-snow) 100%);
	border-radius: var(--radius-card);
	padding: 14px 10px;
	box-shadow: var(--shadow-card);
	text-align: center;
	min-width: 0;
	border: 1px solid rgba(244, 201, 72, 0.18);
}
.summary-label { font-size: 10px; color: var(--color-sunlit-deep); margin: 0 0 6px; text-transform: uppercase; letter-spacing: 0.10em; font-weight: 700; }
.summary-amount { margin: 0; font-size: 15px; font-weight: 600; font-variant-numeric: tabular-nums; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
@media (min-width: 420px) {
	.month-summary { gap: 10px; }
	.summary-card { padding: 14px 12px; }
	.summary-amount { font-size: 18px; }
}
.summary-income .summary-amount { color: var(--color-success); }
.summary-spend .summary-amount { color: var(--color-warn); }
.summary-saved-negative .summary-amount { color: var(--color-danger); }

.dashboard-section {
	background: linear-gradient(180deg, #fffdf6 0%, var(--color-snow) 100%);
	border-radius: var(--radius-card);
	padding: 20px;
	box-shadow: var(--shadow-card);
	margin-bottom: 16px;
	border: 1px solid rgba(244, 201, 72, 0.18);
}
.dashboard-section h2 {
	font-family: 'Inter', system-ui, sans-serif;
	margin: 0 0 14px;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--color-sunlit-deep);
}
.empty-line { margin: 0; color: var(--color-mid); font-size: 14px; }

/* Allocation rings */
.ring-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 18px;
}
.ring-card {
	display: grid;
	grid-template-columns: 130px 1fr;
	gap: 14px;
	align-items: center;
}
.ring-wrap { width: 130px; height: 130px; }
.ring-svg { width: 100%; height: 100%; }
.ring-track { fill: transparent; stroke: rgba(244, 201, 72, 0.20); stroke-width: 14; }
.ring-amount-text { font-size: 9px; font-weight: 700; fill: var(--color-ink); font-variant-numeric: tabular-nums; }
.ring-label-text { font-size: 6px; fill: var(--color-mid); }
.ring-legend { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.ring-legend li { display: flex; align-items: center; gap: 8px; font-size: 13px; }
.legend-swatch { width: 10px; height: 10px; border-radius: 2px; flex: none; }
.legend-swatch-unalloc { background: var(--color-bone); }
.legend-name { flex: 1; }
.legend-amount { font-variant-numeric: tabular-nums; color: var(--color-mid); }

/* Bucket progress */
.bucket-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 14px; }
.bucket-row-head { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: baseline; margin-bottom: 6px; gap: 4px 8px; }
.bucket-name { font-weight: 600; min-width: 0; flex: 1 1 auto; }
.bucket-amount { font-variant-numeric: tabular-nums; font-size: 13px; color: var(--color-mid); white-space: nowrap; flex: 0 0 auto; }
.progress-track { background: rgba(244, 201, 72, 0.20); height: 10px; border-radius: 6px; overflow: hidden; box-shadow: inset 0 1px 2px rgba(180, 130, 30, 0.10); }
.progress-fill {
	height: 100%;
	background: linear-gradient(90deg, var(--color-lemon-light), var(--color-lemon) 50%, var(--color-sunlit));
	transition: width 200ms ease;
	box-shadow: 0 0 12px rgba(244, 201, 72, 0.45);
}
.bucket-row-behind .progress-fill { background: var(--color-warn); }
.bucket-row-foot { display: flex; justify-content: space-between; align-items: center; margin-top: 6px; font-size: 12px; color: var(--color-mid); }
.bucket-due { font-variant-numeric: tabular-nums; }
.pill-behind { background: #fde4cf; color: var(--color-warn); }
.pill-ontrack { background: var(--color-success-bg); color: var(--color-success); }

/* Category spend bars */
.category-bars { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.cat-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 4px; font-size: 14px; }
.cat-amount { font-variant-numeric: tabular-nums; color: var(--color-mid); }
.cat-track { background: rgba(244, 201, 72, 0.18); height: 7px; border-radius: 4px; overflow: hidden; }
.cat-fill { height: 100%; background: linear-gradient(90deg, var(--color-lemon-light), var(--color-sunlit)); }

/* Recent activity */
.recent-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.recent-list li { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: 6px 10px; padding: 8px 0; border-bottom: 1px solid var(--color-bone); }
.recent-list li:last-child { border-bottom: 0; }
.recent-head { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.recent-day { font-size: 12px; color: var(--color-mid); }
.recent-desc { font-size: 14px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.recent-head { flex: 1 1 auto; min-width: 0; }
.recent-amount { font-variant-numeric: tabular-nums; font-weight: 600; font-size: 14px; flex: none; }
.recent-credit { color: var(--color-success); }
.recent-debit { color: var(--color-ink); }

@media (min-width: 640px) {
	.ring-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 640px) {
	.directive-actions { gap: 10px; }
	.directive { padding: 18px 20px; }
}
