/* pilotage.dgtlms.fr — feuille de style minimale */
:root {
	--primary: #4f46e5;
	--primary-dark: #4338ca;
	--bg: #f7f8fb;
	--card: #ffffff;
	--border: #e5e7eb;
	--text: #111827;
	--muted: #6b7280;
	--ok: #059669;
	--ok-bg: #ecfdf5;
	--ok-border: #a7f3d0;
	--warn: #b45309;
	--warn-bg: #fffbeb;
	--warn-border: #fde68a;
	--err: #dc2626;
	--err-bg: #fef2f2;
	--err-border: #fecaca;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
	font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
	background: var(--bg);
	color: var(--text);
	font-size: 14px;
	line-height: 1.5;
}

a { color: var(--primary); text-decoration: none; }
a:hover { text-decoration: underline; }

code, pre {
	font-family: 'SF Mono', Menlo, Consolas, monospace;
	font-size: 12.5px;
	background: #f3f4f6;
	padding: 2px 6px;
	border-radius: 4px;
}
pre {
	padding: 10px 14px;
	white-space: pre-wrap;
	word-break: break-word;
}

/* --- Topbar --- */
.topbar {
	display: flex;
	align-items: center;
	gap: 24px;
	background: #fff;
	border-bottom: 1px solid var(--border);
	padding: 12px 24px;
	position: sticky;
	top: 0;
	z-index: 10;
}
.brand {
	display: flex;
	align-items: center;
	gap: 10px;
	font-weight: 700;
	font-size: 15px;
	color: var(--text);
}
.brand:hover { text-decoration: none; }
.brand-dot {
	width: 12px; height: 12px;
	background: linear-gradient(135deg, var(--primary), #7c3aed);
	border-radius: 50%;
}
.topbar nav { display: flex; gap: 4px; flex: 1; }
.topbar nav a {
	padding: 8px 14px;
	border-radius: 7px;
	color: var(--muted);
	font-weight: 600;
	font-size: 13px;
}
.topbar nav a.active, .topbar nav a:hover { background: #f3f4f6; color: var(--text); text-decoration: none; }
.topbar .user { display: flex; align-items: center; gap: 12px; }
.topbar .user-login { font-size: 12.5px; color: var(--muted); font-weight: 600; }

/* --- Layout --- */
.container {
	max-width: 1280px;
	margin: 0 auto;
	padding: 24px;
}
h1 { font-size: 22px; font-weight: 700; margin: 0 0 16px; }
h3 { font-size: 14.5px; font-weight: 700; margin: 0; color: var(--text); }

.page-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 20px;
	gap: 12px;
}
.page-head > div { display: flex; gap: 8px; }
.muted { color: var(--muted); }
.small { font-size: 12px; }
.center { text-align: center; }

/* --- Cards --- */
.card {
	background: var(--card);
	border: 1px solid var(--border);
	border-radius: 12px;
	margin-bottom: 18px;
	overflow: hidden;
}
.card-head {
	padding: 14px 18px;
	border-bottom: 1px solid #f3f4f6;
	display: flex;
	align-items: center;
	gap: 10px;
}
.card-head h3 { flex: 1; }
.card-actions { display: flex; gap: 8px; }
.card-body { padding: 16px 18px; }

.danger-zone { border-color: var(--err-border); background: #fff8f8; }
.danger-zone h3 { color: var(--err); padding: 14px 18px 4px; }
.danger-zone p, .danger-zone form { padding: 0 18px 16px; margin: 0; }

/* --- KPI --- */
.kpi-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 14px;
	margin-bottom: 18px;
}
.kpi {
	background: #fff;
	border: 1px solid var(--border);
	border-radius: 10px;
	padding: 14px 16px;
}
.kpi-label { font-size: 11px; text-transform: uppercase; color: var(--muted); font-weight: 700; letter-spacing: 0.04em; }
.kpi-val { font-size: 24px; font-weight: 700; margin-top: 4px; color: var(--text); }
.kpi-sub { font-size: 11.5px; color: var(--muted); margin-top: 3px; }
.kpi-ai { background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%); border-color: #f59e0b40; }

/* --- Tables --- */
.table-wrap { overflow-x: auto; }
.data-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 13px;
}
.data-table th {
	background: #f9fafb;
	text-align: left;
	padding: 10px 14px;
	font-weight: 600;
	color: #374151;
	border-bottom: 1px solid var(--border);
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.03em;
}
.data-table td {
	padding: 10px 14px;
	border-bottom: 1px solid #f3f4f6;
	vertical-align: middle;
}
.data-table tr:hover td { background: #fafafa; }
.data-table .num { text-align: right; }
.data-table.compact th, .data-table.compact td { padding: 7px 12px; }
.data-table .actions { display: flex; gap: 6px; justify-content: flex-end; }
.row-inactive { opacity: 0.55; }

/* --- Pills --- */
.pill {
	display: inline-block;
	padding: 2px 9px;
	border-radius: 11px;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.03em;
}
.pill-ok      { background: var(--ok-bg);   color: var(--ok); }
.pill-warn    { background: var(--warn-bg); color: var(--warn); }
.pill-err     { background: var(--err-bg);  color: var(--err); }
.pill-neutral { background: #f1f5f9;        color: #64748b; }

/* --- Buttons --- */
.btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 14px;
	border-radius: 7px;
	font-size: 12.5px;
	font-weight: 600;
	cursor: pointer;
	border: 1px solid transparent;
	background: var(--primary);
	color: #fff;
	text-decoration: none;
	font-family: inherit;
}
.btn:hover { background: var(--primary-dark); text-decoration: none; }
.btn-ghost { background: #fff; border-color: var(--border); color: #374151; }
.btn-ghost:hover { background: #f3f4f6; color: var(--text); }
.btn-danger { background: var(--err-bg); border-color: var(--err-border); color: var(--err); }
.btn-danger:hover { background: var(--err); color: #fff; }
.btn-sm { padding: 6px 11px; font-size: 11.5px; }
.btn-block { width: 100%; justify-content: center; }
.btn-primary { background: var(--primary); color: #fff; }

/* --- Forms --- */
.form-card { padding: 20px; }
.form-row { margin-bottom: 14px; }
.form-row label { display: block; font-size: 12px; font-weight: 600; color: #374151; margin-bottom: 6px; }
.form-row input[type=text],
.form-row input[type=password],
.form-row input[type=number],
.form-row select,
.form-row textarea {
	width: 100%;
	padding: 9px 12px;
	border: 1px solid var(--border);
	border-radius: 7px;
	font-size: 13.5px;
	font-family: inherit;
	background: #fff;
}
.form-row input:focus, .form-row select:focus, .form-row textarea:focus {
	outline: none;
	border-color: var(--primary);
	box-shadow: 0 0 0 3px rgba(79,70,229,0.15);
}
.form-row small { display: block; margin-top: 4px; }
.form-row-inline { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.form-row-inline > div { margin: 0; }
.checkbox { display: flex; align-items: center; gap: 8px; }
.form-actions { display: flex; gap: 8px; padding-top: 8px; }

/* --- Alerts --- */
.alert {
	padding: 12px 16px;
	border-radius: 8px;
	border: 1px solid;
	margin-bottom: 14px;
	font-size: 13px;
}
.alert-ok   { background: var(--ok-bg);   border-color: var(--ok-border);   color: var(--ok); }
.alert-warn { background: var(--warn-bg); border-color: var(--warn-border); color: var(--warn); }
.alert-err  { background: var(--err-bg);  border-color: var(--err-border);  color: var(--err); }
.alert pre { background: #fff; margin: 8px 0 0; }

/* Charts */
.chart-wrap {
	position: relative;
	height: 280px;
	width: 100%;
}

/* Allocation presets (page Crédits IA) */
.alloc-presets {
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
	margin-top: 8px;
}
.alloc-presets .btn { font-variant-numeric: tabular-nums; }

/* --- Auth pages --- */
.auth-bg {
	background: linear-gradient(135deg, #4f46e5 0%, #7c3aed 100%);
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0;
	padding: 24px;
}
.auth-card {
	background: #fff;
	border-radius: 14px;
	padding: 32px;
	max-width: 420px;
	width: 100%;
	box-shadow: 0 12px 40px rgba(0,0,0,0.18);
}
.auth-card h1 { font-size: 18px; font-weight: 700; margin: 0 0 4px; color: var(--primary); }
.auth-card h2 { font-size: 22px; font-weight: 700; margin: 0 0 18px; }
.auth-card .muted { font-size: 13px; }
.auth-card label { display: block; font-size: 12px; font-weight: 600; color: #374151; margin-top: 12px; margin-bottom: 6px; }
.auth-card input {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid var(--border);
	border-radius: 7px;
	font-size: 14px;
	font-family: inherit;
}
.auth-card .btn { margin-top: 18px; }

/* --- Footer --- */
.footer {
	text-align: center;
	padding: 24px;
	color: var(--muted);
}
