/* ==========================================================================
   LendForge — Mes prêts (front public)
   ========================================================================== */

.lf-loans {
	--c-primary:     var(--lf-color-primary, #1F6F5C);
	--c-accent:      var(--lf-color-accent, #E0653A);
	--c-bg:          var(--lf-color-bg, #F6F5F1);
	--c-surface:     var(--lf-color-surface, #FFFFFF);
	--c-surface-alt: var(--lf-color-surface-alt, #EEEDE7);
	--c-text:        var(--lf-color-text, #1A1A17);
	--c-muted:       var(--lf-color-text-muted, #6E6B62);
	--c-border:      var(--lf-color-border, #E2E0D8);
	--c-success:     var(--lf-color-success, #1F7A4D);
	--c-warning:     var(--lf-color-warning, #B7791F);
	--c-error:       var(--lf-color-error, #C0392B);
	--r-sm:          var(--lf-radius-sm, 8px);
	--r-md:          var(--lf-radius-md, 14px);
	--r-lg:          var(--lf-radius-lg, 22px);
	--r-pill:        var(--lf-radius-pill, 999px);
	--sh-md:         var(--lf-shadow-md, 0 8px 28px -10px rgba(26,26,23,0.16));
	--f-head:        var(--lf-font-heading, "Fraunces", Georgia, serif);
	--f-body:        var(--lf-font-body, "Hanken Grotesk", system-ui, sans-serif);

	font-family: var(--f-body);
	color: var(--c-text);
	max-width: 760px;
	margin: 0 auto;
	padding: 30px 16px;
}
.lf-loans * { box-sizing: border-box; }

.lf-loans__head { margin-bottom: 20px; }
.lf-loans__eyebrow {
	font-size: 12px; font-weight: 600; letter-spacing: 0.16em;
	text-transform: uppercase; color: var(--c-primary); margin: 0 0 7px;
}
.lf-loans__title { font-family: var(--f-head); font-weight: 600; font-size: 28px; margin: 0; }

.lf-loans__empty {
	background: var(--c-surface-alt); border-radius: var(--r-md);
	padding: 32px; text-align: center; color: var(--c-muted); font-size: 14px;
}

.lf-loan {
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: var(--r-lg);
	box-shadow: var(--sh-md);
	padding: 24px;
	margin-bottom: 16px;
}

.lf-loan__top {
	display: flex; justify-content: space-between; align-items: flex-start;
	gap: 14px; margin-bottom: 18px;
}
.lf-loan__ref {
	font-family: "IBM Plex Mono", monospace; font-size: 11px; color: var(--c-muted);
}
.lf-loan__name { font-family: var(--f-head); font-weight: 600; font-size: 19px; margin: 3px 0 0; }
.lf-loan__status {
	font-size: 10.5px; font-weight: 700; text-transform: uppercase;
	letter-spacing: 0.04em; padding: 5px 11px; border-radius: var(--r-pill); white-space: nowrap;
}
.lf-loan__status--active   { background: #E7EAF6; color: #1B3FD8; }
.lf-loan__status--closed   { background: color-mix(in srgb, var(--c-success) 16%, transparent); color: var(--c-success); }
.lf-loan__status--defaulted{ background: color-mix(in srgb, var(--c-error) 14%, transparent); color: var(--c-error); }

.lf-loan__figures {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px;
	padding: 16px 0; border-top: 1px solid var(--c-surface-alt);
	border-bottom: 1px solid var(--c-surface-alt);
}
.lf-loan__k { display: block; font-size: 11.5px; color: var(--c-muted); margin-bottom: 4px; }
.lf-loan__v { font-family: var(--f-head); font-weight: 600; font-size: 16px; }

.lf-loan__progress { margin: 16px 0 4px; }
.lf-loan__bar {
	height: 8px; background: var(--c-surface-alt);
	border-radius: var(--r-pill); overflow: hidden;
}
.lf-loan__bar span { display: block; height: 100%; background: var(--c-primary); }
.lf-loan__progress-txt { display: block; margin-top: 6px; font-size: 11.5px; color: var(--c-muted); }

.lf-loan__details { margin-top: 12px; }
.lf-loan__details summary {
	cursor: pointer; font-size: 13px; font-weight: 600; color: var(--c-primary);
	list-style: none;
}
.lf-loan__details summary::-webkit-details-marker { display: none; }
.lf-loan__details summary::before { content: "▸ "; }
.lf-loan__details[open] summary::before { content: "▾ "; }

.lf-loan__sched-wrap {
	margin-top: 12px; max-height: 280px; overflow-y: auto;
	border: 1px solid var(--c-border); border-radius: var(--r-sm);
}
.lf-loan__sched { width: 100%; border-collapse: collapse; font-size: 12.5px; }
.lf-loan__sched thead th {
	position: sticky; top: 0; background: var(--c-surface-alt);
	text-align: left; padding: 8px 12px; font-size: 10.5px;
	text-transform: uppercase; letter-spacing: 0.04em; color: var(--c-muted);
}
.lf-loan__sched tbody td { padding: 8px 12px; border-top: 1px solid var(--c-surface-alt); }

.lf-loan__chip {
	font-size: 10.5px; font-weight: 700; padding: 3px 8px; border-radius: var(--r-sm);
}
.lf-loan__chip--pending { background: var(--c-surface-alt); color: var(--c-muted); }
.lf-loan__chip--paid    { background: color-mix(in srgb, var(--c-success) 16%, transparent); color: var(--c-success); }
.lf-loan__chip--late    { background: color-mix(in srgb, var(--c-error) 14%, transparent); color: var(--c-error); }
.lf-loan__chip--partial { background: color-mix(in srgb, var(--c-warning) 18%, transparent); color: var(--c-warning); }

@media (max-width: 560px) {
	.lf-loan__figures { grid-template-columns: 1fr; gap: 10px; }
}
