/* FormaFranchise - theme clair force, mobile-first */
:root {
  --primaire: #1a5fb4; --primaire-fonce: #144a8f;
  --fond: #f4f6fa; --carte: #ffffff; --texte: #1c2536;
  --gris: #6b7280; --bord: #e2e8f0; --ok: #16a34a; --alerte: #dc2626;
  color-scheme: light;
}
* { box-sizing: border-box; }
body { margin: 0; font-family: system-ui, -apple-system, "Segoe UI", sans-serif;
  background: var(--fond); color: var(--texte); }

.topbar { display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  background: var(--primaire); color: #fff; padding: 10px 16px; }
.brand { font-weight: 700; font-size: 17px; }
.tenant-switch select { border: 0; border-radius: 8px; padding: 6px 10px; font-size: 14px; }
.tenant-name { background: rgba(255,255,255,.15); padding: 4px 12px; border-radius: 999px; font-size: 13px; }
.userbox { margin-left: auto; font-size: 13px; }
.userbox a { color: #fff; }

.mainnav { display: flex; gap: 4px; overflow-x: auto; background: #fff;
  border-bottom: 1px solid var(--bord); padding: 0 8px; }
.mainnav a { padding: 12px 14px; text-decoration: none; color: var(--texte);
  white-space: nowrap; font-size: 14px; border-bottom: 3px solid transparent; }
.mainnav a.active { color: var(--primaire); border-bottom-color: var(--primaire); font-weight: 600; }

.content { padding: 16px; max-width: 1100px; margin: 0 auto; }
h1 { font-size: 20px; margin: 4px 0 16px; }

.cartes { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 12px; }
.carte { background: var(--carte); border: 1px solid var(--bord); border-radius: 14px;
  padding: 16px; box-shadow: 0 1px 3px rgba(16,24,40,.05); }
.carte .chiffre { font-size: 28px; font-weight: 700; color: var(--primaire); }
.carte .libelle { font-size: 13px; color: #64748b; margin-top: 2px; }

table.liste { width: 100%; border-collapse: collapse; background: #fff;
  border-radius: 12px; overflow: hidden; border: 1px solid var(--bord); font-size: 14px; }
table.liste th { text-align: left; background: #f8fafc; padding: 10px 12px;
  font-size: 12px; text-transform: uppercase; color: #64748b; }
table.liste td { padding: 10px 12px; border-top: 1px solid var(--bord); }

.btn { display: inline-block; background: var(--primaire); color: #fff; border: 0;
  padding: 10px 18px; border-radius: 10px; font-size: 14px; cursor: pointer; text-decoration: none; }
.btn:active { background: var(--primaire-fonce); }
.btn-sec { background: #e2e8f0; color: var(--texte); }

.form-champ { margin-bottom: 14px; }
.form-champ label { display: block; font-size: 13px; font-weight: 600; margin-bottom: 5px; }
.form-champ input, .form-champ select, .form-champ textarea { width: 100%;
  padding: 10px 12px; border: 1px solid var(--bord); border-radius: 10px; font-size: 15px; background: #fff; }

.login-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #1a5fb4, #0d3a75); padding: 16px; }
.login-box { background: #fff; border-radius: 18px; padding: 28px; width: 100%; max-width: 380px; }
.login-box h1 { text-align: center; }
.msg-erreur { background: #fef2f2; color: var(--alerte); border: 1px solid #fecaca;
  padding: 10px 12px; border-radius: 10px; font-size: 14px; margin-bottom: 12px; }
.badge { display: inline-block; padding: 2px 10px; border-radius: 999px; font-size: 12px;
  background: #eef2ff; color: var(--primaire); }
