@import url("./assets/fonts/google-fonts-local.css");

:root {
  color-scheme: light;
  --bg: #f5f7fa;
  --surface: #ffffff;
  --surface-2: #eef2f6;
  --surface-3: #f8fafc;
  --surface-soft: var(--surface-3); /* carte douce (synthèse, chips) : surface subtile TOUJOURS lisible avec --ink/--muted */
  --ink: #172033;
  --muted: #667085;
  --line: #d9e2ec;
  --line-strong: #a8b5c5;
  --accent: #2563eb;
  --accent-2: #dc2626;
  --accent-3: #d97706;
  --accent-4: #475569;
  --on-accent: #fff; /* texte lisible SUR un fond --accent (boutons primaires, chips actives, badges pleins) */
  --gold: #c59b2d;
  --danger: #dc2626;
  --success: #16a34a;
  /* Niveaux de disponibilité (pastilles + cellules) : teintes DISTINCTES garanties,
     indépendantes de --gold/--accent-3 qui se confondent dans certains thèmes. */
  --avail-good: #16a34a;
  --avail-mid: #eab308;
  --avail-low: #ea7a30;
  --avail-full: #dc2626;
  /* Ombre de base allégée et en couches (plus moderne, moins « flottante »). Chaque thème garde
     sa propre ombre s'il en redéfinit une -> identité visuelle des thèmes préservée. */
  --shadow: 0 1px 3px rgba(15, 23, 42, 0.05), 0 12px 28px rgba(15, 23, 42, 0.07);
  --radius: 8px;
  /* Rayon des petits éléments (champ de recherche, mini-badges…). Était utilisé sans être
     défini -> coins carrés. Défini une seule fois ici ; les thèmes l'héritent. */
  --radius-sm: 7px;
  --font-body: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-title: Lobster, cursive;
  --font-button: Poppins, Inter, ui-sans-serif, system-ui, sans-serif;
  --font-menu: Ubuntu, Inter, ui-sans-serif, system-ui, sans-serif;
  --font-size-scale: 1;
  --font-weight-base: 400;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.startup-screen {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 32px;
  background: var(--bg);
  color: var(--ink);
}

.startup-card {
  display: grid;
  gap: 8px;
  min-width: min(380px, 100%);
  padding: 24px 28px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--shadow);
}

.startup-card strong {
  font-family: var(--font-title);
  font-size: 24px;
}

.startup-card span {
  color: var(--muted);
  font-weight: 600;
}

:root[data-theme="dark"] {
  color-scheme: dark;
  --bg: #202020;
  --surface: #2b2b2b;
  --surface-2: #383838;
  --surface-3: #242424;
  --ink: #f2f2f2;
  --muted: #b7b7b7;
  --line: #484848;
  --line-strong: #6a6a6a;
  --accent: #4cc2a0;
  --accent-2: #ff7f73;
  --accent-3: #f0b057;
  --accent-4: #8fb8ff;
  --gold: #e0b642;
  --danger: #f87171;
  --success: #4ade80;
  --shadow: 0 12px 28px rgba(0, 0, 0, 0.26);
}

:root[data-theme="ubuntu"] {
  color-scheme: light;
  --bg: #f7f1ec;
  --surface: #fffaf7;
  --surface-2: #f1e1d7;
  --surface-3: #2c001e;
  --surface-soft: var(--surface-2);
  --ink: #2b1724;
  --muted: #7a635f;
  --line: #e5cfc3;
  --line-strong: #c99b85;
  --accent: #e95420;
  --accent-2: #c7162b;
  --accent-3: #77216f;
  --accent-4: #5e2750;
  --gold: #f5b642;
  --shadow: 0 18px 38px rgba(119, 33, 111, 0.13);
  --radius: 10px;
  font-family: Ubuntu, Inter, ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
}


:root[data-theme="mac"] {
  color-scheme: light;
  --bg: #e8eaed;
  --surface: #f8f9fa;
  --surface-2: #dcdfe4;
  --surface-3: #ffffff;
  --ink: #1a1c1f;
  --muted: #5f636b;
  --line: #c2c7ce;
  --line-strong: #9aa0a9;
  --accent: #4a5560;
  --accent-2: #c0392b;
  --accent-3: #b07d2b;
  --accent-4: #566573;
  --gold: #b8902f;
  --shadow: 0 16px 40px rgba(30, 34, 40, 0.16);
  --radius: 10px;
  font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", Inter, "Segoe UI", sans-serif;
}

:root[data-theme="graphite"] {
  color-scheme: light;
  --bg: #eee9dc;
  --surface: #fbf7ea;
  --surface-2: #ebe4d3;
  --surface-3: #fffdf5;
  --ink: #242424;
  --muted: #676258;
  --line: #918b7e;
  --line-strong: #48443d;
  --accent: #4d5966;
  --accent-2: #9a5148;
  --accent-3: #8a6f35;
  --accent-4: #606060;
  --gold: #a98638;
  --shadow: 5px 7px 0 rgba(48, 45, 38, 0.14);
  --radius: 11px;
  font-family: Nunito, "Comic Sans MS", "Trebuchet MS", Inter, ui-sans-serif, system-ui, sans-serif;
}

:root[data-theme="windows"] {
  color-scheme: light;
  --bg: #f3f0e3;
  --surface: rgba(255, 252, 242, 0.88);
  --surface-2: rgba(239, 232, 209, 0.88);
  --surface-3: rgba(255, 253, 247, 0.94);
  --ink: #1e2a32;
  --muted: #68705f;
  --line: rgba(109, 104, 82, 0.32);
  --line-strong: rgba(52, 74, 86, 0.56);
  --accent: #226ca6;
  --accent-2: #d95a3f;
  --accent-3: #4d9b62;
  --accent-4: #9a6dcc;
  --gold: #d9a32b;
  --shadow: 4px 6px 0 rgba(83, 73, 47, 0.14), 0 16px 32px rgba(36, 69, 85, 0.08);
  --radius: 12px 9px 14px 10px;
  font-family: Nunito, Poppins, Inter, ui-sans-serif, system-ui, sans-serif;
}

:root[data-theme="win11"] {
  color-scheme: light;
  --bg: #eef3fb;
  --surface: rgba(255, 255, 255, 0.82);
  --surface-2: #eef6ff;
  --surface-3: #f9fbff;
  --ink: #111827;
  --muted: #5f6f86;
  --line: rgba(116, 139, 170, 0.26);
  --line-strong: rgba(0, 103, 192, 0.45);
  --accent: #0067c0;
  --accent-2: #c42b1c;
  --accent-3: #f7b500;
  --accent-4: #735bc1;
  --gold: #f7b500;
  --shadow: 0 18px 42px rgba(31, 78, 121, 0.14);
  --radius: 12px;
  font-family: "Segoe UI Variable", "Segoe UI", Inter, ui-sans-serif, system-ui, sans-serif;
}

:root[data-theme="classic-dark"] {
  color-scheme: dark;
  --bg: #0f172a;
  --surface: #172033;
  --surface-2: #223047;
  --surface-3: #0b1120;
  --ink: #f8fafc;
  --muted: #b8c2d2;
  --line: #2e3b52;
  --line-strong: #4a5c78;
  --accent: #60a5fa;
  --accent-2: #f87171;
  --accent-3: #fbbf24;
  --accent-4: #93c5fd;
  --gold: #d8b34c;
  --danger: #f87171;
  --success: #34d399;
  --shadow: 0 16px 36px rgba(0, 0, 0, 0.32);
  --radius: 8px;
}

:root[data-theme="ubuntu-dark"] {
  color-scheme: dark;
  --bg: #1d0718;
  --surface: #2b1026;
  --surface-2: #3a1833;
  --surface-3: #13000d;
  --ink: #fff7f0;
  --muted: #d8bdb2;
  --line: #55304b;
  --line-strong: #875575;
  --accent: #ff7b42;
  --accent-2: #ff5a6c;
  --accent-3: #d76bd0;
  --accent-4: #ffb18d;
  --gold: #ffbe5c;
  --danger: #ff5a6c;
  --success: #86efac;
  --shadow: 0 18px 42px rgba(0, 0, 0, 0.36);
  --radius: 10px;
  font-family: Ubuntu, Inter, ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
}


:root[data-theme="mac-dark"] {
  color-scheme: dark;
  --bg: #0c0d0f;
  --surface: #1a1c1f;
  --surface-2: #1f2125;
  --surface-3: #050506;
  --ink: #eceef1;
  --muted: #9ca2ac;
  --line: #34373d;
  --line-strong: #565b64;
  --accent: #7a8694;
  --accent-2: #e0564b;
  --accent-3: #d39a3f;
  --accent-4: #8a97a6;
  --gold: #d4af52;
  --danger: #e0564b;
  --success: #4ade80;
  --shadow: 0 18px 44px rgba(0, 0, 0, 0.5);
  --radius: 10px;
  font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", Inter, "Segoe UI", sans-serif;
}

:root[data-theme="graphite-dark"] {
  color-scheme: dark;
  --bg: #1f1f1d;
  --surface: #2c2b28;
  --surface-2: #383630;
  --surface-3: #24231f;
  --ink: #f2eee2;
  --muted: #c7c0ad;
  --line: rgb(96 91 77);
  --line-strong: rgb(34 32 27);
  --accent: #b6c1c9;
  --accent-2: #e08b7e;
  --accent-3: #d8bd78;
  --accent-4: #ded8ca;
  --gold: #d6b86c;
  --danger: #e08b7e;
  --success: #86efac;
  --shadow: 5px 7px 0 rgba(0, 0, 0, 0.34);
  --radius: 11px;
  font-family: Nunito, "Comic Sans MS", "Trebuchet MS", Inter, ui-sans-serif, system-ui, sans-serif;
}

:root[data-theme="windows-dark"] {
  color-scheme: dark;
  --bg: #111816;
  --surface: rgba(29, 33, 28, 0.92);
  --surface-2: rgba(44, 46, 37, 0.92);
  --surface-3: rgba(20, 24, 22, 0.96);
  --ink: #f7f0dc;
  --muted: #c3bda8;
  --line: rgba(210, 202, 168, 0.24);
  --line-strong: rgba(237, 219, 160, 0.48);
  --accent: #7abde6;
  --accent-2: #ff8f66;
  --accent-3: #8bd184;
  --accent-4: #d4b5ff;
  --gold: #f2cf6b;
  --danger: #ff8f66;
  --success: #86efac;
  --shadow: 5px 7px 0 rgba(0, 0, 0, 0.34), 0 18px 42px rgba(0, 0, 0, 0.36);
  --radius: 12px 9px 14px 10px;
  font-family: Nunito, Poppins, Inter, ui-sans-serif, system-ui, sans-serif;
}

:root[data-theme="win11-dark"] {
  color-scheme: dark;
  --bg: #10141c;
  --surface: rgba(31, 35, 46, 0.82);
  --surface-2: #273142;
  --surface-3: #0a0d13;
  --ink: #f7f9fd;
  --muted: #b3bfd1;
  --line: rgba(154, 173, 202, 0.2);
  --line-strong: rgba(96, 205, 255, 0.44);
  --accent: #60cdff;
  --accent-2: #ff8a80;
  --accent-3: #ffd45a;
  --accent-4: #b69cff;
  --gold: #ffd45a;
  --danger: #ff8a80;
  --success: #86efac;
  --shadow: 0 18px 44px rgba(0, 0, 0, 0.34);
  --radius: 12px;
  font-family: "Segoe UI Variable", "Segoe UI", Inter, ui-sans-serif, system-ui, sans-serif;
}

/* Thèmes sombres : --accent est volontairement CLAIR (texte/lien sur fond sombre).
   Utilisé comme FOND plein (bouton primaire, chip active, badge), le texte doit être
   foncé pour rester lisible. Variable sémantique, pas de rustine par composant. */
:root[data-theme="dark"],
:root[data-theme="classic-dark"],
:root[data-theme="ubuntu-dark"],
:root[data-theme="mac-dark"],
:root[data-theme="graphite-dark"],
:root[data-theme="windows-dark"],
:root[data-theme="win11-dark"] {
  --on-accent: #15181d;
  --avail-good: #4ade80;
  --avail-mid: #facc15;
  --avail-low: #fb923c;
  --avail-full: #f87171;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  background: linear-gradient(180deg, var(--surface-3), var(--bg) 240px);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: calc(16px * var(--font-size-scale));
  font-weight: var(--font-weight-base);
}

h1,
h2,
h3,
.band-title strong,
.kpi strong {
  font-family: var(--font-title);
}

.sidebar,
.sidebar button,
.subnav {
  font-family: var(--font-menu);
}

a {
  color: var(--accent);
  text-decoration: none;
}

a:hover {
  color: var(--accent-4);
  text-decoration: none;
}

button,
input,
select,
textarea {
  font: inherit;
}

button,
.button-like {
  font-family: var(--font-button);
}

button {
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--ink);
  min-height: 36px;
  border-radius: 7px;
  padding: 0 12px;
  cursor: pointer;
  transition: border-color 0.16s ease, background 0.16s ease, color 0.16s ease, transform 0.16s ease;
}

button:hover {
  border-color: var(--line-strong);
  transform: translateY(-1px);
}

button.primary {
  background: var(--accent);
  color: var(--on-accent);
  border-color: var(--accent);
  /* Ombre alignée sur l'accent du thème (était teintée en vert, héritage d'un ancien thème). */
  box-shadow: 0 6px 16px color-mix(in srgb, var(--accent) 28%, transparent);
}

button.danger {
  color: var(--accent-2);
  border-color: #e0b8b3;
}

button.icon {
  width: 34px;
  min-height: 34px;
  padding: 0;
  font-size: 18px;
  line-height: 1;
}

input,
select,
textarea {
  width: 100%;
  min-height: 36px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink);
  border-radius: 7px;
  padding: 7px 9px;
}

input[type="checkbox"] {
  width: 18px;
  height: 18px;
  min-height: 18px;
  padding: 0;
  border: 0;
  border-radius: 4px;
  background: transparent;
  box-shadow: none;
  accent-color: var(--accent);
  cursor: pointer;
}

input:focus,
select:focus,
textarea:focus {
  outline: 2px solid color-mix(in srgb, var(--accent) 24%, transparent);
  border-color: var(--accent);
}

:root[data-theme="dark"] input,
:root[data-theme="dark"] select,
:root[data-theme="dark"] textarea,
:root[data-theme="dark"] button,
:root[data-theme="dark"] .sidebar,
:root[data-theme="dark"] .segmented,
:root[data-theme="dark"] details {
  background: var(--surface);
  color: var(--ink);
}

:root[data-theme="dark"] th {
  background: #303030;
  color: var(--muted);
}

:root[data-theme="dark"] .topbar {
  background: rgba(32, 32, 32, 0.94);
}

:root[data-theme="dark"] .bar-track {
  background: #3b3b3b;
}

:root[data-theme="dark"] .status {
  background: #3a3f3d;
  color: #d5ddd9;
}

:root[data-theme="dark"] .status.ok {
  background: #174735;
  color: #b5f4d9;
}

:root[data-theme="dark"] .status.due {
  background: #57390f;
  color: #ffdca6;
}

:root[data-theme="dark"] .status.late {
  background: #60251f;
  color: #ffc4bd;
}

:root[data-theme="dark"] .status.wait {
  background: #263e68;
  color: #c8dcff;
}

:root[data-theme$="-dark"] input,
:root[data-theme$="-dark"] select,
:root[data-theme$="-dark"] textarea,
:root[data-theme$="-dark"] button,
:root[data-theme$="-dark"] .sidebar,
:root[data-theme$="-dark"] .segmented,
:root[data-theme$="-dark"] details {
  background: var(--surface);
  color: var(--ink);
}

:root[data-theme$="-dark"] th {
  background: var(--surface-2);
  color: var(--muted);
}

:root[data-theme$="-dark"] .topbar {
  background: color-mix(in srgb, var(--surface-3) 88%, transparent);
}

:root[data-theme$="-dark"] .bar-track {
  background: var(--surface-2);
}

:root[data-theme$="-dark"] .status {
  background: color-mix(in srgb, var(--surface-2) 85%, var(--ink) 15%);
  color: var(--ink);
}

:root[data-theme$="-dark"] .status.ok {
  background: #174735;
  color: #b5f4d9;
}

:root[data-theme$="-dark"] .status.due {
  background: #57390f;
  color: #ffdca6;
}

:root[data-theme$="-dark"] .status.late {
  background: #60251f;
  color: #ffc4bd;
}

:root[data-theme$="-dark"] .status.wait {
  background: #263e68;
  color: #c8dcff;
}

:root[data-theme="classic-dark"] body {
  background: linear-gradient(180deg, #0b1120, #0f172a 260px);
}

:root[data-theme="ubuntu"] body {
  background: linear-gradient(135deg, #2c001e 0, #77216f 180px, var(--bg) 181px);
}

:root[data-theme="ubuntu"] .sidebar {
  background: #2c001e;
  color: #fff7f0;
}

:root[data-theme="ubuntu"] .nav button {
  color: #fff7f0;
}

:root[data-theme="ubuntu"] .nav button.active {
  color: #ffffff;
  background: #e95420;
  border-color: #ffb088;
}

:root[data-theme="ubuntu"] .brand span,
:root[data-theme="ubuntu"] .backup-actions span {
  color: #ffd6bd;
}

:root[data-theme="ubuntu"] .topbar {
  background: rgba(255, 250, 247, 0.92);
}

:root[data-theme="ubuntu-dark"] body {
  background: linear-gradient(135deg, #13000d 0, #2b1026 220px, var(--bg) 221px);
}

:root[data-theme="ubuntu-dark"] .sidebar {
  background: #13000d;
  color: #fff7f0;
}

:root[data-theme="ubuntu-dark"] .nav button {
  color: #fff7f0;
}

:root[data-theme="ubuntu-dark"] .nav button.active {
  color: #ffffff;
  background: #e95420;
  border-color: #ffb088;
}

:root[data-theme="ubuntu-dark"] .brand span,
:root[data-theme="ubuntu-dark"] .backup-actions span {
  color: #ffcab0;
}

:root[data-theme="ubuntu-dark"] .topbar {
  background: rgba(43, 16, 38, 0.92);
}

/* ===== THÈMES CUIR / INOX — cuir.png + inox brossé chrome.png ===== */

/* Body : texture cuir.png tilée */
:root[data-theme="mac"] body {
  background-image:
    linear-gradient(180deg, rgba(232,234,237,0.62) 0%, rgba(215,218,222,0.58) 100%),
    url("./assets/cuir.png");
  background-size: 100% 100%, 500px 500px;
  background-attachment: fixed, fixed;
  background-color: var(--bg);
}

:root[data-theme="mac-dark"] body {
  background-image: url("./assets/cuir.png");
  background-size: 500px 500px;
  background-attachment: fixed;
  background-color: var(--bg);
}

:root[data-theme="mac"] .topbar,
:root[data-theme="mac"] .band,
:root[data-theme="mac"] .kpi,
:root[data-theme="mac"] .dialog,
:root[data-theme="mac-dark"] .topbar,
:root[data-theme="mac-dark"] .band,
:root[data-theme="mac-dark"] .kpi,
:root[data-theme="mac-dark"] .dialog {
  backdrop-filter: blur(20px);
}

:root[data-theme="mac"] button,
:root[data-theme="mac"] input,
:root[data-theme="mac"] select,
:root[data-theme="mac"] textarea,
:root[data-theme="mac-dark"] button,
:root[data-theme="mac-dark"] input,
:root[data-theme="mac-dark"] select,
:root[data-theme="mac-dark"] textarea {
  border-radius: 11px;
}

/* === Topbar */
:root[data-theme="mac"] .topbar {
  border-bottom: 1px solid rgba(255,255,255,0.6);
  box-shadow: 0 1px 0 rgba(0,0,0,0.08), 0 2px 5px rgba(0,0,0,0.05);
}
:root[data-theme="mac-dark"] .topbar {
  border-bottom: 1px solid rgba(255,255,255,0.09);
  box-shadow: 0 1px 0 rgba(0,0,0,0.5), 0 2px 8px rgba(0,0,0,0.3);
}

/* === Nav active : chrome.png (inox brossé) */
:root[data-theme="mac"] .nav button.active {
  background-image: url("./assets/chrome.png");
  background-size: cover;
  background-position: center;
  color: #1a1c1f;
  border: 1px solid rgba(0,0,0,0.18);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.6),
    inset 0 -1px 0 rgba(0,0,0,0.14),
    0 2px 4px rgba(0,0,0,0.16);
}

:root[data-theme="mac-dark"] .nav button.active {
  background-image:
    linear-gradient(180deg, rgba(18,22,28,0.58) 0%, rgba(12,16,22,0.68) 100%),
    url("./assets/chrome.png");
  background-size: 100% 100%, cover;
  background-position: center;
  color: #eef0f2;
  border: 1px solid rgba(255,255,255,0.09);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.12),
    inset 0 -1px 0 rgba(0,0,0,0.45),
    0 2px 6px rgba(0,0,0,0.45);
}

/* Survol du menu */
:root[data-theme="mac"] .nav button:hover:not(.active) {
  background-image:
    linear-gradient(180deg, rgba(255,255,255,0.45) 0%, rgba(255,255,255,0.30) 100%),
    url("./assets/chrome.png");
  background-size: 100% 100%, cover;
  background-position: center;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.5);
}

:root[data-theme="mac-dark"] .nav button:hover:not(.active) {
  background-image:
    linear-gradient(180deg, rgba(18,22,28,0.75) 0%, rgba(12,16,22,0.82) 100%),
    url("./assets/chrome.png");
  background-size: 100% 100%, cover;
  background-position: center;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.07);
}

/* === En-têtes de bandeaux : chrome.png satiné */
:root[data-theme="mac"] .band-title {
  background-image:
    linear-gradient(180deg, rgba(245,247,249,0.65) 0%, rgba(228,232,236,0.60) 100%),
    url("./assets/chrome.png");
  background-size: 100% 100%, cover;
  background-position: center;
  border-bottom: 1px solid rgba(255,255,255,0.7);
  box-shadow: inset 0 -1px 0 rgba(0,0,0,0.07);
}

:root[data-theme="mac-dark"] .band-title {
  background-image:
    linear-gradient(180deg, rgba(22,26,34,0.68) 0%, rgba(16,20,28,0.75) 100%),
    url("./assets/chrome.png");
  background-size: 100% 100%, cover;
  background-position: center;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04), inset 0 -1px 0 rgba(0,0,0,0.4);
}

/* Bandeaux cliquables : léger reflet au survol */
:root[data-theme="mac"] .clickable-band:hover,
:root[data-theme="mac"] .collapsible-title-row:hover {
  background-image:
    linear-gradient(180deg, rgba(255,255,255,0.48) 0%, rgba(255,255,255,0.32) 100%),
    url("./assets/chrome.png");
  background-size: 100% 100%, cover;
  background-position: center;
}

:root[data-theme="mac-dark"] .clickable-band:hover,
:root[data-theme="mac-dark"] .collapsible-title-row:hover {
  background-image:
    linear-gradient(180deg, rgba(18,22,28,0.80) 0%, rgba(12,16,22,0.86) 100%),
    url("./assets/chrome.png");
  background-size: 100% 100%, cover;
  background-position: center;
}

/* === Boutons primaires : inox brossé chrome.png === */
:root[data-theme="mac"] button.primary {
  background-image: url("./assets/chrome.png");
  background-size: cover;
  background-position: center;
  border: 1px solid rgba(0,0,0,0.20);
  color: #1a1c1f;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.55),
    inset 0 -1px 0 rgba(0,0,0,0.18),
    0 2px 5px rgba(0,0,0,0.18);
  text-shadow: 0 1px 0 rgba(255,255,255,0.5);
}
:root[data-theme="mac"] button.primary:hover {
  filter: brightness(1.06);
}
:root[data-theme="mac"] button.primary:active {
  filter: brightness(0.93);
  box-shadow: inset 0 2px 4px rgba(0,0,0,0.18), 0 1px 2px rgba(0,0,0,0.10);
}

:root[data-theme="mac-dark"] button.primary {
  background-image:
    linear-gradient(180deg, rgba(18,22,28,0.52) 0%, rgba(12,16,22,0.62) 100%),
    url("./assets/chrome.png");
  background-size: 100% 100%, cover;
  background-position: center;
  border: 1px solid rgba(255,255,255,0.10);
  color: #f0f2f4;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.14),
    inset 0 -1px 0 rgba(0,0,0,0.45),
    0 2px 6px rgba(0,0,0,0.4);
  text-shadow: 0 1px 2px rgba(0,0,0,0.5);
}
:root[data-theme="mac-dark"] button.primary:hover {
  filter: brightness(1.10);
}
:root[data-theme="mac-dark"] button.primary:active {
  filter: brightness(0.88);
  box-shadow: inset 0 2px 4px rgba(0,0,0,0.55), 0 1px 2px rgba(0,0,0,0.3);
}

/* === Cartes : liseré satiné */
:root[data-theme="mac"] .membership-card,
:root[data-theme="mac"] .contact-card,
:root[data-theme="mac"] .shop-card {
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.75),
    inset 0 -1px 0 rgba(0,0,0,0.05),
    0 1px 3px rgba(0,0,0,0.08);
}
:root[data-theme="mac-dark"] .membership-card,
:root[data-theme="mac-dark"] .contact-card,
:root[data-theme="mac-dark"] .shop-card {
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    inset 0 -1px 0 rgba(0,0,0,0.35),
    0 2px 4px rgba(0,0,0,0.3);
}

/* === Focus sur les champs */
:root[data-theme="mac"] input:focus,
:root[data-theme="mac"] select:focus,
:root[data-theme="mac"] textarea:focus {
  outline: 2px solid rgba(110,120,135,0.50);
  outline-offset: 1px;
}
:root[data-theme="mac-dark"] input:focus,
:root[data-theme="mac-dark"] select:focus,
:root[data-theme="mac-dark"] textarea:focus {
  outline: 2px solid rgba(150,165,185,0.40);
  outline-offset: 1px;
}


:root[data-theme="graphite"] body {
  background:
    radial-gradient(ellipse at 12% 10%, rgba(255, 255, 255, 0.80), transparent 260px),
    repeating-linear-gradient(102deg, rgba(36, 36, 36, 0.035) 0 1px, transparent 1px 9px),
    repeating-linear-gradient(6deg, rgba(36, 36, 36, 0.025) 0 1px, transparent 1px 17px),
    linear-gradient(180deg, #f7f1e3, #e5decd);
  background-attachment: fixed;
}

:root[data-theme="graphite-dark"] body {
  background:
    repeating-linear-gradient(102deg, rgba(255, 255, 255, 0.045) 0 1px, transparent 1px 9px),
    repeating-linear-gradient(6deg, rgba(255, 255, 255, 0.028) 0 1px, transparent 1px 17px),
    var(--bg);
  background-attachment: fixed;
}

:root[data-theme="graphite"] .sidebar,
:root[data-theme="graphite"] .topbar,
:root[data-theme="graphite"] .band,
:root[data-theme="graphite"] .kpi,
:root[data-theme="graphite"] .dialog,
:root[data-theme="graphite-dark"] .sidebar,
:root[data-theme="graphite-dark"] .topbar,
:root[data-theme="graphite-dark"] .band,
:root[data-theme="graphite-dark"] .kpi,
:root[data-theme="graphite-dark"] .dialog {
  background:
    linear-gradient(2deg, transparent, rgba(255, 255, 255, 0.06)),
    repeating-linear-gradient(96deg, rgba(0, 0, 0, 0.035) 0 1px, transparent 1px 12px),
    var(--surface);
  border: 2px solid var(--line-strong);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

:root[data-theme="graphite-dark"] .sidebar,
:root[data-theme="graphite-dark"] .topbar,
:root[data-theme="graphite-dark"] .band,
:root[data-theme="graphite-dark"] .kpi,
:root[data-theme="graphite-dark"] .dialog {
  background:
    repeating-linear-gradient(96deg, rgba(255, 255, 255, 0.038) 0 1px, transparent 1px 12px),
    var(--surface);
}

:root[data-theme="graphite"] .band,
:root[data-theme="graphite"] .kpi,
:root[data-theme="graphite-dark"] .band,
:root[data-theme="graphite-dark"] .kpi {
  transform: rotate(-0.12deg);
}

:root[data-theme="graphite"] .band:nth-of-type(even),
:root[data-theme="graphite-dark"] .band:nth-of-type(even) {
  transform: rotate(0.10deg);
}

:root[data-theme="graphite"] .topbar,
:root[data-theme="graphite-dark"] .topbar {
  border-radius: 14px 9px 15px 10px;
}

:root[data-theme="graphite"] .dialog,
:root[data-theme="graphite-dark"] .dialog {
  border-radius: 18px 13px 17px 12px;
}

:root[data-theme="graphite"] .dialog-header,
:root[data-theme="graphite-dark"] .dialog-header {
  border-top-left-radius: 16px;
  border-top-right-radius: 11px;
}

:root[data-theme="graphite"] .dialog-footer,
:root[data-theme="graphite-dark"] .dialog-footer {
  border-bottom-right-radius: 15px;
  border-bottom-left-radius: 10px;
}

:root[data-theme="graphite"] .dialog-header,
:root[data-theme="graphite-dark"] .dialog-header,
:root[data-theme="graphite"] .band-title,
:root[data-theme="graphite-dark"] .band-title {
  background:
    repeating-linear-gradient(100deg, rgba(0, 0, 0, 0.06) 0 1px, transparent 1px 8px),
    color-mix(in srgb, var(--surface-2) 72%, transparent);
  border-bottom: 2px solid var(--line);
}

:root[data-theme="graphite"] button,
:root[data-theme="graphite"] input,
:root[data-theme="graphite"] select,
:root[data-theme="graphite"] textarea,
:root[data-theme="graphite"] .tool-group,
:root[data-theme="graphite-dark"] button,
:root[data-theme="graphite-dark"] input,
:root[data-theme="graphite-dark"] select,
:root[data-theme="graphite-dark"] textarea,
:root[data-theme="graphite-dark"] .tool-group {
  border: 2px solid var(--line-strong);
  border-radius: 13px 9px 14px 10px;
  background:
    linear-gradient(178deg, rgba(255, 255, 255, 0.12), transparent),
    var(--surface-3);
  box-shadow: 2px 3px 0 rgba(0, 0, 0, 0.12);
}

:root[data-theme="graphite-dark"] button,
:root[data-theme="graphite-dark"] input,
:root[data-theme="graphite-dark"] select,
:root[data-theme="graphite-dark"] textarea,
:root[data-theme="graphite-dark"] .tool-group {
  background:
    repeating-linear-gradient(96deg, rgba(255, 255, 255, 0.035) 0 1px, transparent 1px 12px),
    var(--surface-3);
}

:root[data-theme="graphite"] button:hover,
:root[data-theme="graphite-dark"] button:hover {
  transform: rotate(-0.4deg) translateY(-1px);
}

:root[data-theme="graphite"] button.primary,
:root[data-theme="graphite-dark"] button.primary {
  background:
    repeating-linear-gradient(112deg, rgba(255, 255, 255, 0.20) 0 1px, transparent 1px 8px),
    var(--accent);
  border-color: color-mix(in srgb, var(--accent) 55%, #111111 45%);
  color: var(--on-accent);
}

:root[data-theme="graphite"] .nav button,
:root[data-theme="graphite-dark"] .nav button {
  border: 2px solid transparent;
  background: transparent;
  box-shadow: none;
}

:root[data-theme="graphite"] .nav button.active,
:root[data-theme="graphite-dark"] .nav button.active {
  border-color: var(--line-strong);
  background:
    repeating-linear-gradient(110deg, color-mix(in srgb, var(--accent) 22%, transparent) 0 2px, transparent 2px 9px),
    color-mix(in srgb, var(--accent) 12%, var(--surface));
  color: var(--ink);
}

:root[data-theme="graphite"] .brand img,
:root[data-theme="graphite-dark"] .brand img {
  border: 2px solid var(--line-strong);
  border-radius: 15px 10px 14px 11px;
  filter: grayscale(0.24) contrast(1.06);
}

:root[data-theme="graphite"] .theme-swatch,
:root[data-theme="graphite-dark"] .theme-swatch {
  border-radius: 8px 5px 9px 6px;
}

:root[data-theme="graphite"] th,
:root[data-theme="graphite-dark"] th {
  background:
    repeating-linear-gradient(100deg, rgba(0, 0, 0, 0.05) 0 1px, transparent 1px 9px),
    var(--surface-2);
}

/* ===== ANIMATIONS VISUELLES ===== */

@keyframes mgc-ambient-drift {
  0%, 100% { transform: translate(0, 0) scale(1); }
  30%       { transform: translate(6%, -5%) scale(1.07); }
  65%       { transform: translate(-5%, 7%) scale(0.95); }
}

@keyframes mgc-lines-drift {
  0%   { background-position: 0 0, 0 0, 0 0, 0 0; }
  50%  { background-position: 80px 40px, -40px 80px, 0 0, 0 0; }
  100% { background-position: 0 0, 0 0, 0 0, 0 0; }
}

@keyframes mgc-leather-drift {
  0%   { background-position: 100% 100%, 0 0; }
  50%  { background-position: 100% 100%, 28px 14px; }
  100% { background-position: 100% 100%, 0 0; }
}

@keyframes mgc-shine-sweep {
  0%, 60%  { background-position: -180% 0, center; }
  100%     { background-position: 380% 0, center; }
}

@keyframes mgc-pulse-glow {
  0%, 100% { box-shadow: 0 0 0 0 transparent, var(--base-shadow, none); }
  50%      { box-shadow: 0 0 18px 2px color-mix(in srgb, var(--accent) 28%, transparent), var(--base-shadow, none); }
}

/* Ambiance douce sur tous les thèmes */
:root[data-theme-animations="on"] body::before {
  content: "";
  position: fixed;
  inset: -30%;
  pointer-events: none;
  z-index: -1;
  background:
    radial-gradient(ellipse 55% 50% at 22% 18%, color-mix(in srgb, var(--accent) 11%, transparent), transparent),
    radial-gradient(ellipse 40% 35% at 78% 78%, color-mix(in srgb, var(--accent-3) 7%, transparent), transparent);
  filter: blur(50px);
  animation: mgc-ambient-drift 16s ease-in-out infinite;
}

/* Graphite : dérive lente des traits */
:root[data-theme="graphite"][data-theme-animations="on"] body {
  animation: mgc-lines-drift 22s ease-in-out infinite;
}

:root[data-theme="graphite-dark"][data-theme-animations="on"] body {
  animation: mgc-lines-drift 26s ease-in-out infinite;
}

/* Cuir/Inox : dérive douce de la texture cuir */
:root[data-theme="mac"][data-theme-animations="on"] body {
  animation: mgc-leather-drift 20s ease-in-out infinite;
}

:root[data-theme="mac-dark"][data-theme-animations="on"] body {
  animation: mgc-leather-drift 24s ease-in-out infinite;
}

/* Reflet balayant sur les boutons primaires — TOUS les thèmes */
@keyframes mgc-btn-shine {
  0%, 55% { transform: translateX(-120%) skewX(-18deg); }
  100%    { transform: translateX(320%) skewX(-18deg); }
}

:root[data-theme-animations="on"] button.primary {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

:root[data-theme-animations="on"] button.primary::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 45%;
  pointer-events: none;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.4), transparent);
  animation: mgc-btn-shine 6s ease-in-out infinite;
}

/* Lueur pulsée sur l'item actif de la nav (tous thèmes) */
:root[data-theme-animations="on"] .nav button.active {
  --base-shadow: var(--shadow, none);
  animation: mgc-pulse-glow 4s ease-in-out infinite;
}

/* Vie au survol des fiches et cartes — tous les thèmes */
:root[data-theme-animations="on"] .kpi,
:root[data-theme-animations="on"] .clickable-card,
:root[data-theme-animations="on"] .membership-card,
:root[data-theme-animations="on"] .registration-line,
:root[data-theme-animations="on"] .contact-recap-row {
  transition: transform .22s ease, box-shadow .22s ease;
  will-change: transform;
}

:root[data-theme-animations="on"] .kpi:hover,
:root[data-theme-animations="on"] .clickable-card:hover,
:root[data-theme-animations="on"] .membership-card:hover,
:root[data-theme-animations="on"] .registration-line:hover,
:root[data-theme-animations="on"] .contact-recap-row:hover {
  transform: translateY(-3px) rotate(0deg) scale(1.012);
}

/* Vie au survol des miniatures et photos — tous les thèmes */
:root[data-theme-animations="on"] .article-image,
:root[data-theme-animations="on"] .article-library-thumb,
:root[data-theme-animations="on"] .identity-photo img,
:root[data-theme-animations="on"] .avatar {
  transition: transform .2s ease;
}

:root[data-theme-animations="on"] .article-image:hover,
:root[data-theme-animations="on"] .article-library-thumb:hover {
  transform: scale(1.07) rotate(-1.5deg);
}

:root[data-theme-animations="on"] .identity-photo:hover img,
:root[data-theme-animations="on"] .avatar:hover {
  transform: scale(1.08);
}

@media (prefers-reduced-motion: reduce) {
  :root[data-theme-animations="on"] body::before,
  :root[data-theme-animations="on"] body,
  :root[data-theme-animations="on"] button.primary,
  :root[data-theme-animations="on"] button.primary::after,
  :root[data-theme-animations="on"] .nav button.active {
    animation: none !important;
  }
  :root[data-theme-animations="on"] button.primary::after {
    display: none !important;
  }
  :root[data-theme-animations="on"] .kpi,
  :root[data-theme-animations="on"] .clickable-card,
  :root[data-theme-animations="on"] .membership-card,
  :root[data-theme-animations="on"] .registration-line,
  :root[data-theme-animations="on"] .contact-recap-row,
  :root[data-theme-animations="on"] .article-image,
  :root[data-theme-animations="on"] .article-library-thumb,
  :root[data-theme-animations="on"] .identity-photo img,
  :root[data-theme-animations="on"] .avatar {
    transition: none !important;
    transform: none !important;
  }
}

/* ===== UI TOGGLE ANIMATIONS ===== */

.theme-anim-row {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 16px;
}

.theme-anim-row > div {
  flex: 1;
  display: grid;
  gap: 3px;
}

.theme-anim-row small {
  color: var(--muted);
  font-size: .85rem;
  font-weight: normal;
}

:root[data-theme="windows"] body {
  position: relative;
  background:
    repeating-linear-gradient(102deg, rgba(88, 105, 69, 0.035) 0 1px, transparent 1px 13px),
    radial-gradient(circle at 12% 12%, rgba(68, 149, 111, 0.12), transparent 300px),
    radial-gradient(circle at 92% 8%, rgba(219, 121, 72, 0.10), transparent 330px),
    linear-gradient(180deg, #fffdf4, var(--bg) 430px);
}

:root[data-theme="windows-dark"] body {
  position: relative;
  background:
    repeating-linear-gradient(102deg, rgba(255, 244, 207, 0.035) 0 1px, transparent 1px 13px),
    radial-gradient(circle at 12% 10%, rgba(122, 189, 230, 0.14), transparent 310px),
    radial-gradient(circle at 88% 12%, rgba(139, 209, 132, 0.10), transparent 300px),
    radial-gradient(circle at 52% 0, rgba(255, 143, 102, 0.08), transparent 360px),
    linear-gradient(180deg, #0b1115, var(--bg) 440px);
}

:root[data-theme="windows"] body::before,
:root[data-theme="windows-dark"] body::before,
:root[data-theme="windows"] body::after,
:root[data-theme="windows-dark"] body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background-repeat: no-repeat;
}

:root[data-theme="windows"] body::before {
  opacity: 0.22;
  mix-blend-mode: multiply;
  background-image:
    url("./assets/themes/sport-football.png"),
    url("./assets/themes/sport-tennis.png"),
    url("./assets/themes/sport-running.png"),
    url("./assets/themes/sport-judo.png");
  background-size:
    min(420px, 31vw) auto,
    min(460px, 34vw) auto,
    min(520px, 38vw) auto,
    min(470px, 35vw) auto;
  background-position:
    right 34px top 96px,
    left max(310px, 22vw) top 260px,
    right 12vw bottom -28px,
    left max(340px, 24vw) bottom -24px;
}

:root[data-theme="windows"] body::after {
  opacity: 0.17;
  mix-blend-mode: multiply;
  background-image:
    url("./assets/themes/sport-basket.png"),
    url("./assets/themes/sport-kayak.png"),
    url("./assets/themes/sport-pingpong.png"),
    url("./assets/themes/sport-rugby.png");
  background-size:
    min(390px, 29vw) auto,
    min(500px, 36vw) auto,
    min(380px, 28vw) auto,
    min(440px, 32vw) auto;
  background-position:
    left max(320px, 23vw) top 110px,
    right 4vw top 48vh,
    left max(320px, 23vw) bottom 14vh,
    right 38vw bottom 2vh;
}

:root[data-theme="windows-dark"] body::before {
  opacity: 0.20;
  filter: invert(1) hue-rotate(178deg) saturate(1.15) contrast(0.92);
  mix-blend-mode: screen;
  background-image:
    url("./assets/themes/sport-football.png"),
    url("./assets/themes/sport-tennis.png"),
    url("./assets/themes/sport-running.png"),
    url("./assets/themes/sport-judo.png");
  background-size:
    min(420px, 31vw) auto,
    min(460px, 34vw) auto,
    min(520px, 38vw) auto,
    min(470px, 35vw) auto;
  background-position:
    right 34px top 96px,
    left max(310px, 22vw) top 260px,
    right 12vw bottom -28px,
    left max(340px, 24vw) bottom -24px;
}

:root[data-theme="windows-dark"] body::after {
  opacity: 0.16;
  filter: invert(1) hue-rotate(178deg) saturate(1.15) contrast(0.92);
  mix-blend-mode: screen;
  background-image:
    url("./assets/themes/sport-basket.png"),
    url("./assets/themes/sport-kayak.png"),
    url("./assets/themes/sport-pingpong.png"),
    url("./assets/themes/sport-rugby.png");
  background-size:
    min(390px, 29vw) auto,
    min(500px, 36vw) auto,
    min(380px, 28vw) auto,
    min(440px, 32vw) auto;
  background-position:
    left max(320px, 23vw) top 110px,
    right 4vw top 48vh,
    left max(320px, 23vw) bottom 14vh,
    right 38vw bottom 2vh;
}

:root[data-theme="windows"] .shell,
:root[data-theme="windows-dark"] .shell {
  position: relative;
  z-index: 1;
}

:root[data-theme="windows"] .sidebar,
:root[data-theme="windows"] .topbar,
:root[data-theme="windows"] .band,
:root[data-theme="windows"] .kpi,
:root[data-theme="windows"] button,
:root[data-theme="windows"] input,
:root[data-theme="windows"] select,
:root[data-theme="windows"] textarea,
:root[data-theme="windows-dark"] .sidebar,
:root[data-theme="windows-dark"] .topbar,
:root[data-theme="windows-dark"] .band,
:root[data-theme="windows-dark"] .kpi,
:root[data-theme="windows-dark"] button,
:root[data-theme="windows-dark"] input,
:root[data-theme="windows-dark"] select,
:root[data-theme="windows-dark"] textarea {
  border-radius: var(--radius);
}

:root[data-theme="windows"] .sidebar,
:root[data-theme="windows-dark"] .sidebar,
:root[data-theme="windows"] .topbar,
:root[data-theme="windows-dark"] .topbar {
  background:
    repeating-linear-gradient(105deg, color-mix(in srgb, var(--line) 28%, transparent) 0 1px, transparent 1px 12px),
    linear-gradient(135deg, color-mix(in srgb, var(--accent) 8%, transparent), transparent 42%),
    linear-gradient(90deg, color-mix(in srgb, var(--accent-3) 7%, transparent), transparent 58%),
    color-mix(in srgb, var(--surface) 95%, var(--bg));
}

:root[data-theme="windows"] .topbar,
:root[data-theme="windows-dark"] .topbar {
  border-bottom-color: color-mix(in srgb, var(--accent) 24%, var(--line));
  overflow: hidden;
}

:root[data-theme="windows"] .topbar::after,
:root[data-theme="windows-dark"] .topbar::after {
  content: "";
  position: absolute;
  right: 18px;
  bottom: -50px;
  width: min(360px, 30vw);
  height: 180px;
  pointer-events: none;
  opacity: 0.18;
  mix-blend-mode: multiply;
  background: url("./assets/themes/sport-running.png") right bottom / contain no-repeat;
}

:root[data-theme="windows-dark"] .topbar::after {
  opacity: 0.18;
  filter: invert(1) hue-rotate(178deg) saturate(1.2) contrast(0.95);
  mix-blend-mode: screen;
}

:root[data-theme="windows"] .band,
:root[data-theme="windows-dark"] .band,
:root[data-theme="windows"] .kpi,
:root[data-theme="windows-dark"] .kpi {
  position: relative;
  isolation: isolate;
  overflow: hidden;
}

:root[data-theme="windows"] .band::after,
:root[data-theme="windows-dark"] .band::after,
:root[data-theme="windows"] .kpi::after,
:root[data-theme="windows-dark"] .kpi::after {
  content: "";
  position: absolute;
  inset: auto -22px -24px auto;
  width: 190px;
  height: 150px;
  pointer-events: none;
  z-index: 0;
  opacity: 0.15;
  mix-blend-mode: multiply;
  background: url("./assets/themes/sport-football.png") center / contain no-repeat;
}

:root[data-theme="windows"] .band:nth-of-type(2n)::after,
:root[data-theme="windows"] .kpi:nth-of-type(2n)::after {
  background-image: url("./assets/themes/sport-basket.png");
}

:root[data-theme="windows"] .band:nth-of-type(3n)::after,
:root[data-theme="windows"] .kpi:nth-of-type(3n)::after {
  background-image: url("./assets/themes/sport-tennis.png");
}

:root[data-theme="windows"] .band:nth-of-type(4n)::after,
:root[data-theme="windows"] .kpi:nth-of-type(4n)::after {
  background-image: url("./assets/themes/sport-pingpong.png");
}

:root[data-theme="windows-dark"] .band::after,
:root[data-theme="windows-dark"] .kpi::after {
  opacity: 0.17;
  filter: invert(1) hue-rotate(178deg) saturate(1.15) contrast(0.95);
  mix-blend-mode: screen;
  background-image: url("./assets/themes/sport-football.png");
}

:root[data-theme="windows-dark"] .band:nth-of-type(2n)::after,
:root[data-theme="windows-dark"] .kpi:nth-of-type(2n)::after {
  background-image: url("./assets/themes/sport-basket.png");
}

:root[data-theme="windows-dark"] .band:nth-of-type(3n)::after,
:root[data-theme="windows-dark"] .kpi:nth-of-type(3n)::after {
  background-image: url("./assets/themes/sport-tennis.png");
}

:root[data-theme="windows-dark"] .band:nth-of-type(4n)::after,
:root[data-theme="windows-dark"] .kpi:nth-of-type(4n)::after {
  background-image: url("./assets/themes/sport-pingpong.png");
}

:root[data-theme="windows"] .band > *,
:root[data-theme="windows-dark"] .band > *,
:root[data-theme="windows"] .kpi > *,
:root[data-theme="windows-dark"] .kpi > * {
  position: relative;
  z-index: 1;
}

:root[data-theme="windows"] .nav button.active,
:root[data-theme="windows-dark"] .nav button.active {
  border-left: 4px solid var(--accent-3);
  background:
    repeating-linear-gradient(110deg, color-mix(in srgb, var(--accent-3) 20%, transparent) 0 2px, transparent 2px 10px),
    linear-gradient(90deg, color-mix(in srgb, var(--accent) 16%, transparent), transparent),
    var(--surface-2);
}

:root[data-theme="windows"] button.primary,
:root[data-theme="windows-dark"] button.primary {
  background: linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent-3) 38%, var(--accent)));
  color: var(--on-accent);
  border-color: color-mix(in srgb, var(--accent) 70%, var(--line-strong));
}

:root[data-theme="windows"] .band-title,
:root[data-theme="windows-dark"] .band-title,
:root[data-theme="windows"] th,
:root[data-theme="windows-dark"] th {
  background:
    repeating-linear-gradient(108deg, color-mix(in srgb, var(--line) 26%, transparent) 0 1px, transparent 1px 10px),
    linear-gradient(90deg, color-mix(in srgb, var(--accent-3) 12%, transparent), transparent),
    var(--surface-2);
}

:root[data-theme="win11"] body {
  background:
    radial-gradient(circle at 18% 12%, rgba(96, 205, 255, 0.30), transparent 260px),
    radial-gradient(circle at 84% 0, rgba(115, 91, 193, 0.18), transparent 330px),
    linear-gradient(180deg, #f9fbff, #eef3fb 310px, var(--bg));
}

:root[data-theme="win11-dark"] body {
  background:
    radial-gradient(circle at 18% 12%, rgba(96, 205, 255, 0.14), transparent 280px),
    radial-gradient(circle at 84% 0, rgba(182, 156, 255, 0.12), transparent 330px),
    linear-gradient(180deg, #0a0d13, #10141c 310px);
}

:root[data-theme="win11"] .sidebar,
:root[data-theme="win11"] .topbar,
:root[data-theme="win11"] .band,
:root[data-theme="win11"] .kpi,
:root[data-theme="win11"] .dialog,
:root[data-theme="win11-dark"] .sidebar,
:root[data-theme="win11-dark"] .topbar,
:root[data-theme="win11-dark"] .band,
:root[data-theme="win11-dark"] .kpi,
:root[data-theme="win11-dark"] .dialog {
  backdrop-filter: blur(22px) saturate(1.18);
}

:root[data-theme="win11"] .sidebar,
:root[data-theme="win11-dark"] .sidebar {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 76%, var(--accent) 10%), color-mix(in srgb, var(--surface) 90%, transparent)),
    var(--surface);
}

:root[data-theme="win11"] .topbar,
:root[data-theme="win11-dark"] .topbar {
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--accent) 10%, transparent), transparent 46%),
    color-mix(in srgb, var(--surface) 86%, transparent);
}

:root[data-theme="win11"] button,
:root[data-theme="win11"] input,
:root[data-theme="win11"] select,
:root[data-theme="win11"] textarea,
:root[data-theme="win11"] .tool-group,
:root[data-theme="win11-dark"] button,
:root[data-theme="win11-dark"] input,
:root[data-theme="win11-dark"] select,
:root[data-theme="win11-dark"] textarea,
:root[data-theme="win11-dark"] .tool-group {
  border-radius: var(--radius);
}

:root[data-theme="win11"] .brand img,
:root[data-theme="win11-dark"] .brand img {
  border-radius: 14px;
}

:root[data-theme="win11"] .nav button,
:root[data-theme="win11-dark"] .nav button {
  border-radius: 10px;
}

:root[data-theme="win11"] .nav button.active,
:root[data-theme="win11-dark"] .nav button.active {
  background: color-mix(in srgb, var(--accent) 12%, var(--surface));
  border-color: color-mix(in srgb, var(--accent) 26%, var(--line));
  box-shadow: inset 3px 0 0 var(--accent);
}

:root[data-theme="win11"] button.primary,
:root[data-theme="win11-dark"] button.primary {
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 88%, #ffffff 12%), var(--accent));
  border-color: var(--accent);
  color: var(--on-accent);
}

textarea {
  min-height: 78px;
  resize: vertical;
}

label {
  display: grid;
  gap: 5px;
  /* Libellés plus contrastés que le gris « muted » (meilleure lisibilité des formulaires),
     en restant theme-aware (mélange encre + muted du thème actif). */
  color: color-mix(in srgb, var(--ink) 78%, var(--muted));
  font-size: 0.82rem;
  font-weight: 650;
}

table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}

th,
td {
  border-bottom: 1px solid var(--line);
  padding: 8px 10px;
  text-align: left;
  vertical-align: middle;
  white-space: nowrap;
}

th {
  position: sticky;
  top: 0;
  z-index: 1;
  /* En-tête aligné sur le thème (était codé en dur en tons verts) + meilleur contraste. */
  background: var(--surface-2);
  color: var(--muted);
  font-weight: 700;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  user-select: none;
}

td {
  font-size: 0.84rem;
}

tfoot td {
  border-top: 2px solid var(--line-strong);
  border-bottom: 0;
  background: color-mix(in srgb, var(--surface-2) 72%, var(--surface));
  color: var(--ink);
  font-weight: 850;
}

.shell {
  display: grid;
  grid-template-columns: 248px minmax(0, 1fr);
  min-height: 100vh;
}

.shell.sidebar-hidden {
  grid-template-columns: minmax(0, 1fr);
}

.shell.sidebar-hidden > .sidebar {
  display: none;
}

.topbar-title-row {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.topbar-title-row h1 {
  min-width: 0;
}

.sidebar-toggle {
  flex: none;
  width: 38px;
  min-height: 38px;
  padding: 0;
  font-size: 1.2rem;
  line-height: 1;
  border-radius: 9px;
  cursor: pointer;
}

.content.topbar-hidden > .topbar {
  display: none;
}

.topbar-show-btn {
  display: none;
}

.content.topbar-hidden > .topbar-show-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  position: sticky;
  top: 8px;
  z-index: 6;
  margin: 8px 0 0 22px;
  padding: 6px 14px;
  font-size: 0.85rem;
  font-weight: 700;
  border-radius: 9px;
  cursor: pointer;
  opacity: 0.85;
}

.content.topbar-hidden > .topbar-show-btn:hover {
  opacity: 1;
}

.sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  min-height: 0;
  padding: 18px;
  border-right: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 96%, var(--accent) 4%);
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr) auto;
  gap: 18px;
  align-items: start;
  align-content: start;
  overflow: hidden;
}

.brand {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
}

.brand img {
  width: 58px;
  height: 58px;
  object-fit: contain;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.brand strong {
  display: block;
  font-size: 1.18rem;
}

.brand span {
  display: block;
  color: var(--muted);
  font-size: 0.82rem;
}

.nav {
  display: grid;
  gap: 6px;
  width: 100%;
  height: 100%;
  min-height: 0;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding-right: 2px;
  align-self: stretch;
  align-content: start;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.nav::-webkit-scrollbar {
  width: 0;
  height: 0;
  display: none;
}

.nav button {
  display: grid;
  grid-template-columns: 20px minmax(0, 1fr);
  gap: 9px;
  align-items: center;
  justify-content: flex-start;
  text-align: left;
  border-color: transparent;
  background: transparent;
  min-height: 36px;
  height: auto;
}

.nav-icon {
  width: 20px;
  height: 20px;
  display: inline-grid;
  place-items: center;
  color: color-mix(in srgb, var(--muted) 82%, var(--accent) 18%);
}

.nav-icon .tool-icon {
  width: 18px;
  height: 18px;
  stroke-width: 2.15;
}

.nav-label {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.nav button.active {
  background: var(--surface-2);
  border-color: var(--line);
  color: var(--accent);
  font-weight: 750;
}

.nav button.active .nav-icon {
  color: var(--accent);
}

.nav-submenu {
  display: none;
  gap: 5px;
  padding: 4px 0 4px 14px;
  border-left: 2px solid var(--line);
}

.nav-submenu.open {
  display: grid;
  align-content: start;
}

.nav-submenu button {
  grid-template-columns: 18px minmax(0, 1fr);
  gap: 8px;
  min-height: 34px;
  padding: 6px 10px;
  font-size: 0.86rem;
}

.nav-submenu .nav-icon {
  width: 18px;
  height: 18px;
}

.nav-submenu .nav-icon .tool-icon {
  width: 16px;
  height: 16px;
}

.backup-actions {
  display: grid;
  gap: 8px;
  width: 100%;
  align-self: end;
  background: inherit;
  z-index: 2;
}

.backup-actions span {
  color: var(--muted);
  font-size: 0.78rem;
}

.content {
  min-width: 0;
}

.content.help-content-shell .help-view {
  height: var(--help-view-height, calc(100vh - 160px));
  overflow: hidden;
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 4;
  background: color-mix(in srgb, var(--bg) 86%, transparent);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
  padding: 12px 22px 14px;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 9px;
  align-items: stretch;
}

.topbar h1 {
  margin: 0;
  min-width: 0;
  font-size: 1.35rem;
  line-height: 1.18;
  overflow-wrap: anywhere;
}

.topbar-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  width: 100%;
}

.app-toolbar {
  flex-wrap: wrap;
  justify-content: flex-start;
}

.tool-group {
  display: inline-flex;
  gap: 4px;
  align-items: center;
  padding: 3px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 88%, var(--surface-2));
}

.tool-button {
  min-width: 36px;
  min-height: 34px;
  padding: 0 9px;
  border-color: transparent;
  background: transparent;
  font-weight: 800;
}

.tool-text-icon {
  display: block;
  font-weight: 900;
  line-height: 1;
}

.tool-label {
  display: none;
  max-width: 64px;
  overflow: hidden;
  color: var(--muted);
  font-size: 0.66rem;
  font-weight: 800;
  line-height: 1.05;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.app-toolbar.show-labels .tool-button {
  min-width: 58px;
  min-height: 46px;
  padding: 5px 7px;
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
  align-items: center;
  justify-content: center;
}

.app-toolbar.show-labels .tool-label {
  display: block;
}

.mgc-icon { width: 20px; height: 20px; display: block; flex: 0 0 auto; }
.nav-icon .mgc-icon { width: 20px; height: 20px; }
/* Mini-lot Coachs/Salles — pictos méta compacts inline */
.meta-mgc-icon { display: inline-flex; align-items: center; vertical-align: -0.18em; margin-right: 3px; }
.meta-mgc-icon .mgc-icon { width: 16px; height: 16px; display: block; }
/* Lot Photos coachs — carte identité + avatar carré arrondi */
.coach-card-identity { display: flex; gap: 12px; align-items: flex-start; flex-wrap: wrap; }
.coach-card-id-main { flex: 1 1 180px; min-width: 0; }
.coach-avatar { flex: 0 0 auto; width: 68px; height: 68px; border-radius: 16px; overflow: hidden; display: inline-flex; align-items: center; justify-content: center; background: var(--surface-soft, rgba(0,0,0,0.04)); border: 1px solid var(--line, rgba(0,0,0,0.12)); }
.coach-avatar-lg { width: 96px; height: 96px; border-radius: 20px; }
.coach-avatar-photo { width: 100%; height: 100%; object-fit: cover; display: block; }
.coach-avatar.is-default { background: color-mix(in srgb, var(--accent, #9fb3c3) 14%, var(--surface, #fff)); }
.coach-avatar-placeholder { width: 68%; height: 68%; display: inline-flex; align-items: center; justify-content: center; opacity: 0.92; }
.coach-avatar-placeholder .mgc-icon { width: 100%; height: 100%; }
.coach-photo-field { display: flex; flex-direction: column; gap: 10px; padding: 14px; margin-bottom: 14px; border: 1px solid var(--line); border-radius: 14px; background: var(--surface-2, var(--surface)); }
.coach-photo-field-title { font-size: 0.82rem; font-weight: 800; letter-spacing: 0.02em; color: var(--ink); opacity: 0.9; }
.coach-photo-row { display: flex; gap: 14px; align-items: flex-start; flex-wrap: wrap; }
.coach-photo-controls { display: flex; flex-direction: column; gap: 10px; flex: 1 1 auto; min-width: 0; }
.coach-photo-help, .coach-photo-help-short { color: var(--muted); font-size: 0.78rem; line-height: 1.35; }
.coach-photo-field[data-has-photo="true"] .coach-avatar-choice { display: none; }
.coach-photo-field[data-has-photo="true"] .coach-photo-help { display: none; }
.coach-photo-field[data-has-photo="false"] .coach-photo-help-short { display: none; }
.coach-form-identity { grid-column: 1 / -1; display: grid; grid-template-columns: minmax(176px, 216px) 1fr; gap: 16px; align-items: start; margin-bottom: 14px; }
.coach-form-identity .coach-photo-field { margin-bottom: 0; }
.coach-form-identity .coach-photo-row { flex-direction: column; align-items: center; text-align: center; }
.coach-form-identity .coach-photo-controls { width: 100%; align-items: center; }
.coach-form-identity .coach-avatar-choice { align-items: center; }
.coach-form-identity .coach-avatar-choice-btns { justify-content: center; }
.coach-form-main-fields { display: flex; flex-direction: column; gap: 10px; min-width: 0; }
@media (max-width: 620px) {
  .coach-form-identity { grid-template-columns: 1fr; }
  .coach-form-identity .coach-photo-row { flex-direction: row; align-items: flex-start; text-align: left; }
  .coach-form-identity .coach-photo-controls { align-items: flex-start; }
  .coach-form-identity .coach-avatar-choice { align-items: flex-start; }
  .coach-form-identity .coach-avatar-choice-btns { justify-content: flex-start; }
}
.coach-photo-buttons { display: flex; gap: 8px; flex-wrap: wrap; }
.coach-avatar-choice { display: flex; flex-direction: column; gap: 4px; }
.coach-avatar-choice-label { font-size: 0.78rem; font-weight: 700; color: var(--ink); opacity: 0.85; }
.coach-avatar-choice-btns { display: inline-flex; gap: 4px; flex-wrap: wrap; }
.coach-avatar-choice-btn { padding: 0; width: 42px; height: 42px; border: 2px solid var(--line); border-radius: 12px; background: var(--surface); color: var(--ink); cursor: pointer; overflow: hidden; display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; }
.coach-avatar-choice-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.coach-avatar-choice-icon { width: 78%; height: 78%; display: inline-flex; align-items: center; justify-content: center; }
.coach-avatar-choice-icon .mgc-icon { width: 100%; height: 100%; }
.coach-avatar-choice-btn:hover { border-color: var(--accent); }
.coach-avatar-choice-btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 1px; }
.coach-photo-field .coach-avatar-choice-btn.active { border-color: var(--accent); box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 60%, transparent); }
@media (max-width: 460px) { .coach-card-identity { flex-direction: column; align-items: center; text-align: center; } }
@media (max-width: 520px) { .coach-photo-row { flex-direction: column; align-items: center; text-align: center; } .coach-photo-controls { align-items: center; } }
.topmenu .nav-icon .mgc-icon { width: 18px; height: 18px; }
.menu-order-icon .mgc-icon { width: 22px; height: 22px; }
.icon-picker-btn .mgc-icon { width: 32px; height: 32px; }
.tool-icon {
  width: 18px;
  height: 18px;
  display: block;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.tool-button:hover {
  background: var(--surface-2);
  transform: none;
}

.save-group {
  gap: 8px;
  padding-left: 6px;
}

.save-button {
  min-height: 34px;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.save-state {
  max-width: 190px;
  color: var(--muted);
  font-size: 0.76rem;
  line-height: 1.15;
  white-space: normal;
}

.search-tool-group {
  min-width: min(300px, 24vw);
}

.global-search-input {
  min-width: 150px;
  max-width: 220px;
  height: 34px;
  padding: 0 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface);
  color: var(--ink);
  font-weight: 700;
}

.view {
  padding: 22px;
  display: grid;
  gap: 18px;
}

.band {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.clickable-band {
  cursor: pointer;
}

.clickable-band:hover {
  border-color: var(--line-strong);
}

.cockpit-hero {
  min-height: 156px;
  padding: 22px;
  border: 1px solid color-mix(in srgb, var(--accent) 28%, var(--line));
  border-radius: var(--radius);
  background:
    linear-gradient(115deg, color-mix(in srgb, var(--accent) 14%, var(--surface)), var(--surface) 54%),
    var(--surface);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: end;
  box-shadow: var(--shadow);
}

.cockpit-hero span {
  color: var(--accent);
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
}

.cockpit-hero h2 {
  margin: 5px 0 6px;
  font-size: clamp(1.7rem, 3vw, 2.6rem);
  line-height: 1.05;
}

.cockpit-hero p {
  margin: 0;
  max-width: 760px;
  color: var(--muted);
}

.quick-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(96px, 1fr));
  gap: 8px;
}

.band.pad {
  padding: 16px;
}

.band-title {
  padding: 13px 16px;
  border-bottom: 1px solid var(--line);
  display: flex;
  gap: 12px;
  align-items: center;
  justify-content: space-between;
}

.band-title h2 {
  margin: 0;
  font-size: 1rem;
}

.collapsible-band:not(.open) .band-title {
  border-bottom-color: transparent;
}

.stats-kpi-title {
  margin: 22px 2px 0;
  font-size: 1rem;
  font-weight: 700;
  color: var(--ink);
}

.accounting-subtitle {
  margin: 18px 16px 0;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text);
}

.collapsible-title {
  width: 100%;
  min-height: 48px;
  padding: 13px 16px;
  border: 0;
  border-bottom: 1px solid var(--line);
  border-radius: 0;
  background: transparent;
  color: var(--ink);
  text-align: left;
}

.collapsible-title:hover {
  background: color-mix(in srgb, var(--surface-2) 72%, var(--accent) 6%);
  transform: none;
}

.collapsible-title-row {
  min-height: 48px;
  cursor: pointer;
}

.collapsible-title-row:hover {
  background: color-mix(in srgb, var(--surface-2) 72%, var(--accent) 6%);
}

.collapsible-title h2,
.collapsible-title-row h2 {
  flex: 1;
}

.collapsible-meta {
  min-width: 34px;
  height: 26px;
  padding: 3px 9px;
  display: inline-grid;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-2);
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 900;
}

.collapsible-arrow {
  width: 26px;
  height: 26px;
  display: inline-grid;
  place-items: center;
  color: var(--accent);
  font-size: 1.4rem;
  font-weight: 900;
  line-height: 1;
  transition: transform 0.22s ease;
}

.collapsible-band.open .collapsible-arrow {
  transform: rotate(90deg);
}

.collapsible-content {
  display: grid;
  grid-template-rows: 0fr;
  overflow: hidden;
  transition: grid-template-rows 0.24s ease;
}

.collapsible-band.open .collapsible-content {
  grid-template-rows: 1fr;
}

.collapsible-inner {
  min-height: 0;
  overflow: hidden;
}

.collapsible-band:not(.open) .collapsible-inner {
  max-height: 0;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  opacity: 0;
  pointer-events: none;
}

.collapsible-inner > .stock-alert-edit-list {
  padding: 10px;
}

.overview-inner {
  padding: 12px;
}

.overview-band:not(.open) {
  overflow: hidden;
}

.overview-inner .grid {
  margin: 0;
}

.collapsible-inner > .tariff-vat-panel {
  padding: 16px;
}

.shop-collapsible-band .collapsible-inner {
  padding: 10px;
}

.shop-collapsible-band .bar-list {
  padding: 0;
}

.band-title-button {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 4px 10px;
  border: 1px solid var(--line-strong);
  border-radius: 7px;
  background: color-mix(in srgb, var(--surface-2) 78%, var(--accent) 8%);
  color: var(--accent);
  cursor: pointer;
}

.clickable-band:hover .band-title-button {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 12%, var(--surface));
}

.band-title p {
  margin: 4px 0 0;
}

.grid {
  display: grid;
  gap: 14px;
}

.grid.two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.grid.three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.grid.four {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.grid.dynamic-grid {
  grid-template-columns: repeat(var(--dynamic-grid-columns, 1), minmax(0, 1fr));
}

/* Bloc « À surveiller » (accueil) : marge interne autour des tuiles pour qu'elles
   ne touchent pas les bords de l'encadré. Le gap entre tuiles (14px) est conservé. */
.home-watch .grid {
  padding: 16px;
}

/* ===== Centre de Vigilance (Accueil) ===== */
.vigilance { display: flex; flex-direction: column; gap: 14px; }
.vigilance-band + .vigilance-band { margin-top: 0; }
/* Bandeau d'état : ton apaisé, teinte selon le niveau (dérivée des tokens du thème) */
.vigilance-state { display: flex; align-items: center; gap: 14px; padding: 14px 18px; border-width: 1px; border-style: solid; }
.vigilance-state-emoji { font-size: 1.7rem; flex: 0 0 auto; }
.vigilance-state-text h2 { margin: 0; font-size: 1.05rem; }
.vigilance-state-text p { margin: 2px 0 0; }
.vigilance-state-green { border-color: color-mix(in srgb, var(--success) 40%, var(--line)); background: color-mix(in srgb, var(--success) 12%, var(--surface)); }
.vigilance-state-amber { border-color: color-mix(in srgb, var(--accent-3) 42%, var(--line)); background: color-mix(in srgb, var(--accent-3) 12%, var(--surface)); }
.vigilance-state-red   { border-color: color-mix(in srgb, var(--danger) 42%, var(--line)); background: color-mix(in srgb, var(--danger) 11%, var(--surface)); }
/* Sections + grille de cartes-ACTION (pas des KPI) */
.vigilance-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 12px; padding: 14px; align-items: stretch; }
.vigilance-card {
  display: flex; flex-direction: column; gap: 6px; text-align: left;
  padding: 14px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface);
  cursor: pointer; font: inherit; color: inherit;
  transition: transform 0.08s ease, box-shadow 0.12s ease;
}
.vigilance-card:hover { transform: translateY(-1px); box-shadow: var(--shadow); }
.vigilance-card:focus-visible { outline: 2px solid var(--accent); outline-offset: 1px; }
.vigilance-card-head { display: flex; align-items: center; gap: 8px; }
.vigilance-card-icon { font-size: 1.25rem; line-height: 1; flex: 0 0 auto; }
.vigilance-card-icon .mgc-icon { display: block; width: 26px; height: 26px; }
.vigilance-dialog-title { display: flex; align-items: center; gap: 8px; }
.vigilance-dialog-ico { display: inline-flex; align-items: center; flex: 0 0 auto; }
.vigilance-dialog-ico .mgc-icon { width: 24px; height: 24px; }
.vigilance-card-title { font-size: 0.95rem; font-weight: 700; line-height: 1.2; }
.vigilance-card-count { color: var(--ink); font-weight: 800; font-size: 1.3rem; line-height: 1.15; }
.vigilance-card-verb { font-weight: 700; font-size: 0.9rem; line-height: 1.15; }
.vigilance-card.vigilance-red .vigilance-card-verb { color: color-mix(in srgb, var(--danger) 75%, var(--ink)); }
.vigilance-card.vigilance-amber .vigilance-card-verb { color: color-mix(in srgb, var(--accent-3) 75%, var(--ink)); }
.vigilance-card-qualifier { color: var(--muted); font-size: 0.82rem; line-height: 1.2; }
.vigilance-card-cta { margin-top: auto; font-weight: 700; font-size: 0.86rem; color: var(--accent); }
.vigilance-card.vigilance-red { border-color: color-mix(in srgb, var(--danger) 45%, var(--line)); background: color-mix(in srgb, var(--danger) 8%, var(--surface)); }
.vigilance-card.vigilance-red .vigilance-card-cta { color: color-mix(in srgb, var(--danger) 70%, var(--ink)); }
.vigilance-card.vigilance-amber { border-color: color-mix(in srgb, var(--accent-3) 48%, var(--line)); background: color-mix(in srgb, var(--accent-3) 9%, var(--surface)); }
.vigilance-card.vigilance-amber .vigilance-card-cta { color: color-mix(in srgb, var(--accent-3) 70%, var(--ink)); }
.vigilance-card.vigilance-more { border-style: dashed; background: var(--surface); }
.vigilance-card.vigilance-more .vigilance-card-title { color: var(--muted); }
/* Confirmation visuelle : carte « réglé » (fondu doux, sobre) */
.vigilance-card.vigilance-confirm { border-color: color-mix(in srgb, var(--success) 50%, var(--line)); background: color-mix(in srgb, var(--success) 12%, var(--surface)); cursor: default; animation: vigilance-confirm-in 0.3s ease-out; }
.vigilance-card.vigilance-confirm .vigilance-card-icon { color: color-mix(in srgb, var(--success) 60%, var(--ink)); }
.vigilance-card.vigilance-confirm .vigilance-card-title { color: color-mix(in srgb, var(--success) 45%, var(--ink)); }
.vigilance-card.vigilance-confirm.is-leaving { opacity: 0; transition: opacity 0.32s ease; }
@keyframes vigilance-confirm-in { from { opacity: 0; transform: translateY(-2px); } to { opacity: 1; transform: none; } }
/* Bloc vert : vérifications rassurantes */
.vigilance-green-band .band-title h2 { color: color-mix(in srgb, var(--success) 50%, var(--ink)); }
.vigilance-green { list-style: none; margin: 0; padding: 12px 16px; display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 6px 18px; }
.vigilance-green li { font-weight: 700; color: color-mix(in srgb, var(--success) 45%, var(--ink)); }
/* Surbrillance temporaire (navigation intelligente) — discrète, non agressive */
@keyframes vigilance-flash {
  0% { background-color: color-mix(in srgb, var(--accent) 22%, transparent); box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 45%, transparent); }
  100% { background-color: transparent; box-shadow: 0 0 0 0 transparent; }
}
.vigilance-flash { animation: vigilance-flash 2.4s ease-out 1; border-radius: var(--radius-sm, 7px); }
/* Fenêtre de résolution (principe de continuité) */
.vigilance-resolve-list { display: flex; flex-direction: column; gap: 8px; min-width: min(440px, 80vw); }
.vigilance-resolve-item { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 10px 12px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface-3, var(--surface)); }
.vigilance-resolve-info { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.vigilance-resolve-info strong { font-weight: 700; }
.vigilance-resolve-info .muted { font-size: 0.86rem; }
.vigilance-resolve-btn { flex: 0 0 auto; }
.vigilance-resolve-progress { display: flex; flex-direction: column; gap: 1px; margin: 0 0 10px; }
.vigilance-resolve-progress strong { font-size: 0.98rem; }
.vigilance-resolve-progress .muted { font-size: 0.85rem; }
.vigilance-resolve-rows { display: flex; flex-direction: column; gap: 8px; }
.vigilance-resolve-rows { max-height: min(48vh, 420px); overflow: auto; }
.vigilance-resolve-done { margin: 8px 4px; font-weight: 800; color: color-mix(in srgb, var(--success) 50%, var(--ink)); font-size: 1.02rem; }
.vigilance-resolve-all { margin-right: auto; }
@media (max-width: 640px) {
  .vigilance-grid { grid-template-columns: 1fr 1fr; }
  .vigilance-state { flex-wrap: wrap; }
}

.kpi {
  padding: 14px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  display: grid;
  gap: 5px;
  /* Ombre neutre et discrète (était teintée en vert). */
  box-shadow: 0 1px 2px rgba(16, 24, 40, 0.04), 0 6px 16px rgba(16, 24, 40, 0.05);
}

.kpi span {
  color: var(--muted);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0;
}

.kpi strong {
  font-size: 1.55rem;
}

.kpi-link {
  width: 100%;
  color: var(--ink);
  text-align: left;
  cursor: pointer;
}

.kpi-link:hover {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--surface) 86%, var(--accent) 10%);
  transform: translateY(-1px);
}

.kpi-link strong {
  color: var(--accent-2);
}

.signal-list,
.action-list {
  display: grid;
  gap: 8px;
  padding: 14px;
}

.signal-row {
  width: 100%;
  min-height: 54px;
  display: grid;
  grid-template-columns: 92px minmax(132px, 1fr) auto 92px;
  gap: 10px;
  align-items: center;
  text-align: left;
  border-color: var(--line);
}

.signal-row > span:first-child {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
}

.payment-signal-list .signal-row {
  grid-template-columns: 132px minmax(150px, 1fr) auto 92px;
  column-gap: 18px;
}

.payment-signal-list .signal-row > span:first-child {
  min-width: 0;
  padding-right: 14px;
  border-right: 1px solid var(--line);
  overflow: hidden;
  text-overflow: ellipsis;
}

.signal-row strong:last-child {
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.stock-signal-row {
  grid-template-columns: minmax(0, 1fr) auto auto;
  column-gap: 18px;
}

.stock-signal-name {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.stock-signal-current,
.stock-signal-threshold {
  padding-left: 18px;
  border-left: 1px solid var(--line);
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
  white-space: nowrap;
}

.stock-signal-current {
  color: var(--ink);
}

.stock-signal-row.stock-warning {
  border-color: color-mix(in srgb, #f59e0b 54%, var(--line));
  background: color-mix(in srgb, #f59e0b 16%, var(--surface));
}

.stock-signal-row.stock-negative {
  border-color: color-mix(in srgb, #dc2626 58%, var(--line));
  background: color-mix(in srgb, #dc2626 16%, var(--surface));
}

.action-list button {
  min-height: 42px;
  justify-content: flex-start;
  text-align: left;
}

.toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
}

.toolbar .left,
.toolbar .right {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}

.search {
  width: min(420px, 100%);
}

.segmented {
  display: flex;
  gap: 4px;
  padding: 3px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
}

.segmented button {
  border: 0;
  background: transparent;
  min-height: 30px;
}

.segmented button.active {
  background: var(--surface-2);
  color: var(--accent);
  font-weight: 750;
}

.table-wrap {
  overflow: auto;
  max-height: calc(100vh - 250px);
  max-width: 100%;
  scrollbar-gutter: stable;
  overscroll-behavior-inline: contain;
}

.table-wrap table {
  min-width: max-content;
}

.table-wrap::-webkit-scrollbar {
  width: 12px;
  height: 12px;
}

.table-wrap::-webkit-scrollbar-track {
  background: var(--surface-2);
  border-radius: 999px;
}

.table-wrap::-webkit-scrollbar-thumb {
  background: color-mix(in srgb, var(--line-strong) 72%, var(--accent) 28%);
  border: 3px solid var(--surface-2);
  border-radius: 999px;
}

.table-wrap::-webkit-scrollbar-thumb:hover {
  background: var(--accent);
}

.muted {
  color: var(--muted);
}

.money {
  font-variant-numeric: tabular-nums;
  text-align: right;
}

.status {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  border-radius: 999px;
  padding: 2px 8px;
  font-size: 0.78rem;
  font-weight: 750;
  background: #eef3f0;
  color: #52615b;
}

.status.ok {
  background: #e3f4eb;
  color: #126340;
}

.status.due {
  background: #fff1db;
  color: #8a5209;
}

.status.late {
  background: #fbe5e1;
  color: #9a2d22;
}

.payment-contact-link {
  border: 0;
  cursor: pointer;
  justify-self: flex-start;
}

.payment-contact-link:hover {
  text-decoration: underline;
  transform: none;
}

.dialog-contact-popover {
  position: sticky;
  top: 0;
  z-index: 5;
  display: grid;
  gap: 10px;
  margin-bottom: 12px;
  padding: 12px;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--shadow);
}

.dialog-contact-popover-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.status.wait {
  background: #e9f0fb;
  color: #294e8f;
}

.actions {
  display: flex;
  gap: 6px;
  justify-content: flex-end;
}

.discipline-binder {
  overflow: visible;
}

.membership-binder {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 58px;
  gap: 14px;
  padding: 14px;
}

.membership-binder-content {
  display: grid;
  gap: 18px;
  min-width: 0;
}

.membership-letter-group {
  scroll-margin-top: 16px;
}

.membership-letter-title {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}

.membership-letter-title span {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--accent);
  color: var(--accent-contrast);
  font-weight: 850;
}

.membership-letter-title strong {
  color: var(--muted);
  font-size: 0.78rem;
  text-transform: uppercase;
}

/* ===== ORDRE DU MENU ===== */

.menu-order-group {
  margin-bottom: 14px;
}

.menu-order-group h4 {
  margin: 0 0 8px;
  font-size: 0.82rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
}

.menu-order-list {
  display: grid;
  gap: 6px;
  min-height: 40px;
  padding: 4px;
  border: 1px dashed transparent;
  border-radius: 8px;
}

.menu-order-list:empty::before {
  content: "Glissez un élément ici";
  color: var(--muted);
  font-size: 0.82rem;
  padding: 8px;
}

.menu-order-list.drag-over {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 8%, transparent);
}

.menu-order-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface-2);
  cursor: grab;
  user-select: none;
  transition: border-color 0.12s, background 0.12s;
}

.menu-order-item.dragging {
  opacity: 0.4;
  cursor: grabbing;
}

.menu-order-item.drag-over {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 10%, var(--surface));
  outline: 2px dashed var(--accent);
  outline-offset: 1px;
}

.menu-order-item-hidden {
  opacity: 0.5;
}

.menu-order-handle {
  color: var(--muted);
  font-size: 1.2rem;
  line-height: 1;
  flex-shrink: 0;
  cursor: grab;
}

.menu-order-label {
  flex: 1;
  font-weight: 800;
}

.menu-order-badge {
  font-size: .78rem;
  padding: 2px 7px;
  border-radius: 99px;
  background: var(--surface-3);
  border: 1px solid var(--line);
  color: var(--muted);
  flex-shrink: 0;
}

.menu-order-btns {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
}

.menu-order-btns button {
  padding: 3px 9px;
  font-size: .8rem;
  line-height: 1.4;
}

/* ===== PAIEMENTS DUS ===== */

.due-payments-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 14px;
  padding: 16px;
  align-items: start;
}

.due-card {
  display: grid;
  gap: 10px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--shadow);
}

.due-card.payment-late {
  border-color: color-mix(in srgb, var(--danger) 40%, var(--line));
  background: color-mix(in srgb, var(--danger) 4%, var(--surface));
}

.due-card.payment-due {
  border-color: color-mix(in srgb, var(--accent-3) 35%, var(--line));
}

.due-card-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
}

.due-card-identity {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.due-card-identity strong {
  font-size: 1rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.due-card-total {
  display: grid;
  gap: 2px;
  text-align: right;
  flex-shrink: 0;
}

.due-amount {
  font-size: 1.15rem;
  color: var(--danger);
}

.due-card-contact {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 14px;
  font-size: .88rem;
  color: var(--muted);
}

.due-card-contact a {
  color: var(--accent);
}

.due-card-items {
  display: grid;
  gap: 8px;
  border-top: 1px solid var(--line);
  padding-top: 10px;
}

.due-item {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 8px;
  align-items: center;
}

.due-item-info {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  min-width: 0;
}

.due-item-module {
  font-size: .88rem;
  color: var(--muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.due-item-amount {
  font-size: .95rem;
  color: var(--danger);
  white-space: nowrap;
}

.membership-card-list {
  display: grid;
  gap: 8px;
}

.membership-card {
  display: grid;
  grid-template-columns: minmax(118px, 180px) minmax(142px, 0.85fr) minmax(190px, 1fr) minmax(178px, 0.8fr);
  gap: 8px;
  align-items: center;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-left: 4px solid var(--accent);
  border-radius: var(--radius);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 88%, white 12%), var(--surface));
  box-shadow: 0 8px 22px rgba(20, 28, 24, 0.06);
}

.membership-card[data-action] {
  cursor: pointer;
}

.membership-card[data-action]:hover {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface-2) 82%, white 18%), var(--surface));
}

.membership-card.payment-paid {
  border-left-color: #20a464;
}

.membership-card.payment-pending {
  border-left-color: #f2a321;
}

.membership-card.payment-due {
  border-left-color: #d8483e;
}

.membership-card-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 6px;
  align-items: start;
}

.membership-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.membership-card-meta span {
  min-height: 24px;
  display: inline-flex;
  align-items: center;
  padding: 3px 8px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  background: var(--surface-2);
  font-size: 0.76rem;
  font-weight: 750;
}

.membership-card-meta .alert-info-badge {
  border-color: color-mix(in srgb, var(--accent-2) 30%, var(--line));
  background: color-mix(in srgb, var(--accent-2) 8%, var(--surface));
  color: color-mix(in srgb, var(--accent-2) 62%, var(--ink));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent-2) 8%, transparent);
}

.membership-card-totals {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.membership-card-totals div {
  display: grid;
  gap: 2px;
  padding: 8px;
  border-radius: 8px;
  background: var(--surface-2);
}

.membership-card-totals span {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
}

.membership-card-totals strong {
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.membership-card-totals .due strong {
  color: var(--accent-3);
}

.membership-card-payments {
  min-width: 0;
}

.membership-card .payment-drawer {
  width: 100%;
  min-width: 0;
}

.contact-line {
  cursor: pointer;
  grid-template-columns: minmax(118px, 180px) minmax(180px, 1fr) minmax(240px, 1fr) minmax(120px, 0.55fr);
}

.contact-line:hover {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface-2) 84%, white 16%), var(--surface-2));
}

.contact-line-info a,
.contact-line-info span {
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
}

.contact-line-status {
  align-items: start;
}

.contact-paperclip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  width: fit-content;
  padding: 2px 8px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface);
  color: var(--text);
  font-size: 0.78rem;
}

.registration-line {
  grid-template-columns: minmax(118px, 180px) minmax(210px, 1fr) minmax(178px, 0.8fr) minmax(178px, 0.8fr);
}

.registration-payments {
  min-width: 0;
}

.membership-alpha-tabs {
  position: sticky;
  top: 14px;
  align-self: start;
  display: grid;
  gap: 3px;
  padding: 5px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: color-mix(in srgb, var(--surface) 88%, transparent);
  box-shadow: var(--shadow);
}

.membership-alpha-tabs button,
.membership-alpha-tabs span {
  width: 30px;
  height: 26px;
  min-height: 26px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  border: 0;
  padding: 0;
  background: transparent;
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 850;
}

.membership-alpha-tabs button:first-child {
  width: auto;
  padding: 0 7px;
}

.membership-alpha-tabs button.active {
  color: var(--accent-contrast);
  background: var(--accent);
}

.membership-alpha-tabs button:hover {
  transform: none;
}

.membership-alpha-tabs span {
  opacity: 0.34;
}

.payment-label {
  display: inline-grid;
  place-items: center;
  min-width: 34px;
  min-height: 28px;
  padding: 0 7px;
  border-radius: 6px;
  background: var(--surface-2);
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 750;
}

.payment-drawer {
  width: 100%;
  min-width: 0;
  padding: 0;
  border: 0;
  background: var(--surface);
  overflow: visible;
}

.payment-drawer.live {
  position: relative;
  background: transparent;
}

.payment-form-compact {
  min-width: 0;
}

.payment-balance-grid {
  display: grid;
  grid-template-columns: minmax(160px, 1fr);
  gap: 8px;
  margin: 0 0 8px;
}

.payment-balance-grid label {
  min-width: 0;
  font-size: 0.72rem;
}

.payment-balance-grid input[readonly] {
  min-height: 32px;
  font-weight: 850;
  color: var(--ink);
  background: color-mix(in srgb, var(--surface) 88%, var(--accent) 6%);
}

.stage-price-line {
  grid-template-columns: minmax(124px, 0.8fr) minmax(130px, 1fr) minmax(130px, 1fr) minmax(116px, 0.9fr);
  gap: 10px;
}

.stage-price-line label,
.stage-price-line input {
  min-width: 0;
  width: 100%;
}

.stage-tabs {
  align-items: stretch;
}

.stage-tabs button {
  min-height: 42px;
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  gap: 1px;
}

.stage-tabs button small {
  font-size: 0.66rem;
  font-weight: 800;
  opacity: 0.78;
}

.stage-tabs button.stage-past,
.stage-tabs button.stage-closed {
  opacity: 0.58;
  filter: grayscale(0.55);
}

.stage-tabs button.stage-reopened {
  border-color: var(--accent-3);
}

.stage-status-banner {
  margin: 0 0 12px;
  padding: 10px 12px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  color: var(--muted);
}

.stage-status-banner strong {
  color: var(--ink);
}

.stage-status-banner.stage-open {
  border-color: color-mix(in srgb, var(--accent) 35%, var(--line));
}

.stage-status-banner.stage-closed,
.stage-status-banner.stage-past {
  border-color: color-mix(in srgb, var(--accent-2) 32%, var(--line));
  background: color-mix(in srgb, var(--surface) 86%, var(--accent-2) 8%);
}

.stage-status-banner.stage-reopened {
  border-color: color-mix(in srgb, var(--accent-3) 45%, var(--line));
  background: color-mix(in srgb, var(--surface) 84%, var(--accent-3) 10%);
}

/* ===== Carte « Informations du stage » (identité regroupée) ===== */
.stage-info-band { overflow: visible; }
/* Renforcement visuel du statut sur la carte principale du stage (badge conservé).
   Bordure gauche + fond TRÈS léger, teintes alignées sur les pastilles (vert/ambre/rouge),
   lisibles en clair et sombre. Aucune logique métier modifiée. */
.band.stage-info-band.stage-open { border-left: 5px solid color-mix(in srgb, var(--success) 70%, var(--line-strong)); }
.band.stage-info-band.stage-reopened { border-left: 5px solid color-mix(in srgb, var(--accent-3) 70%, var(--line-strong)); }
.band.stage-info-band.stage-closed,
.band.stage-info-band.stage-past { border-left: 5px solid color-mix(in srgb, var(--accent-2) 55%, var(--line-strong)); }
.stage-info-title { gap: 10px; flex-wrap: wrap; }
.stage-info-title h2 { flex: 1 1 auto; }
.stage-info-name { padding: 12px 16px 0; font-family: var(--font-title); font-size: 1.5rem; line-height: 1.1; }
.stage-info-grid {
  margin: 0; padding: 14px 16px;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 12px 24px;
}
.stage-info-row { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.stage-info-row dt { font-size: 0.74rem; text-transform: uppercase; letter-spacing: 0.03em; color: var(--muted); font-weight: 700; }
.stage-info-row dd { margin: 0; font-weight: 700; overflow-wrap: anywhere; }
.stage-info-note { margin: 0 16px 14px; color: var(--muted); font-size: 0.85rem; font-style: italic; }

.discipline-binder.stage-past,
.discipline-binder.stage-closed {
  opacity: 0.72;
  filter: grayscale(0.35);
}

.discipline-binder.stage-reopened {
  border-color: color-mix(in srgb, var(--accent-3) 55%, var(--line));
}

.payment-drawer summary {
  min-height: 30px;
  padding: 4px 5px;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 0;
  align-items: center;
  list-style: none;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: var(--surface);
}

.payment-drawer summary::-webkit-details-marker {
  display: none;
}

.payment-drawer-title {
  display: none;
}

.payment-mini-list {
  display: flex;
  flex-wrap: wrap;
  gap: 3px;
  min-width: 0;
}

/* Bouton discret « Tout afficher » : revient à la vue complète après une sélection focalisée. */
.payment-show-all {
  justify-self: start;
  width: auto;
  min-height: 24px;
  margin-top: 4px;
  padding: 2px 10px;
  font-size: 0.74rem;
  font-weight: 700;
  color: var(--accent);
  background: transparent;
  border: 1px solid color-mix(in srgb, var(--accent) 40%, var(--line));
  border-radius: 999px;
  cursor: pointer;
}

.payment-show-all:hover {
  background: color-mix(in srgb, var(--accent) 12%, var(--surface));
}

.payment-show-all[hidden] {
  display: none;
}

.payment-mini-chip {
  width: auto;
  min-width: 58px;
  max-width: 76px;
  flex: 0 0 auto;
  min-height: 24px;
  padding: 2px 4px;
  border: 1px solid var(--line);
  border-radius: 6px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) 7px;
  gap: 3px;
  align-items: center;
  color: var(--muted);
  background: var(--surface-2);
  font-size: 0.64rem;
  text-align: left;
  cursor: pointer;
}

.payment-mini-chip[hidden] {
  display: none;
}

.payment-mini-chip.filled {
  border-color: color-mix(in srgb, var(--accent) 35%, var(--line));
  background: color-mix(in srgb, var(--accent) 9%, var(--surface));
}

.payment-mini-chip.active {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 16%, var(--surface));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 22%, transparent);
}

.payment-mini-chip:hover {
  transform: none;
  border-color: var(--accent);
}

.payment-mini-chip b {
  color: var(--ink);
  font-size: 0.66rem;
}

.payment-mini-chip span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.payment-mini-chip i {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  font-style: normal;
  font-size: 0;
  background: var(--muted);
}

.payment-mini-chip.ok i {
  background: #20a464;
}

.payment-mini-chip.due i {
  background: #f2a321;
}

.payment-mini-chip.late i {
  background: #d8483e;
}

.payment-mini-chip.wait i {
  background: #f2a321;
}

.payment-drawer-body {
  padding: 0 8px 8px;
  display: grid;
  gap: 5px;
}

.payment-drawer.live .payment-drawer-body {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: min(560px, calc(100vw - 44px));
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: 0 18px 48px rgba(18, 28, 24, 0.24);
  z-index: 80;
}

/* Empilement ET débordement des tiroirs de paiement flottants (live).
   1) Avec les animations activées, .membership-card / .registration-line / .contact-recap-row
      reçoivent `will-change: transform` -> chaque carte devient un contexte d'empilement.
      Le panneau flottant (position:absolute; z-index:80) reste alors prisonnier du contexte
      de SA carte et passe derrière les cartes suivantes -> on élève la carte ouverte (z-index:1,
      sous la toolbar/onglets sticky à 4-6).
   2) Le thème Graphite ajoute `overflow: hidden` sur .membership-card (pour clipper ses bordures
      décoratives ::before/::after) : ce clip ROGNAIT le panneau « Tout afficher » qui déborde sous
      la carte. On rétablit overflow:visible tant qu'un tiroir est ouvert (no-op sur les thèmes sans
      overflow). Spécificité (0,4,0) > règle Graphite (0,3,0), donc l'override s'applique bien.
   3) Même cas dans Boutique : .shop-order-card a overflow:hidden en permanence (clip de ses
      bordures arrondies) ET devient un contexte d'empilement -> le détail de paiement d'une
      commande passait derrière les commandes suivantes. Même correction que les autres listes.
   Correction commune à toutes les listes utilisant ce composant. */
.membership-card:has(.payment-drawer.live[open]),
.registration-line:has(.payment-drawer.live[open]),
.contact-recap-row:has(.payment-drawer.live[open]),
.shop-order-card:has(.payment-drawer.live[open]) {
  position: relative;
  z-index: 1;
  overflow: visible;
}

/* Boutique : la liste des commandes vit dans une bande dépliable dont les conteneurs
   (.band -> .collapsible-content -> .collapsible-inner) ont overflow:hidden (requis par
   l'animation de dépliage grid-template-rows). Une fois la bande OUVERTE, ce clip rognait
   le panneau de paiement flottant d'une commande, et la commande suivante repassait au-dessus.
   Tant qu'un tiroir de paiement est ouvert (bande forcément dépliée, hors animation), on
   rétablit overflow:visible sur cette chaîne -> le panneau peut déborder et rester au-dessus.
   Ciblé Boutique (.shop-collapsible-band) : aucun effet sur les autres bandes/listes, ni sur
   les commandes fermées (la règle ne s'active qu'avec un .payment-drawer.live[open]). */
.shop-collapsible-band:has(.payment-drawer.live[open]),
.shop-collapsible-band:has(.payment-drawer.live[open]) .collapsible-content,
.shop-collapsible-band:has(.payment-drawer.live[open]) .collapsible-inner {
  overflow: visible;
}

.payment-drawer.live .payment-drawer-body::before {
  content: "";
  position: absolute;
  top: -7px;
  right: 22px;
  width: 12px;
  height: 12px;
  transform: rotate(45deg);
  border-left: 1px solid var(--line);
  border-top: 1px solid var(--line);
  background: var(--surface);
}

/* Ligne de paiement (mode / somme / date / état / payer) : flex qui passe à la ligne (flex-wrap)
   quand la modale est trop étroite, au lieu d'une grille rigide qui comprimait et chevauchait les
   champs. Chaque champ garde une largeur minimale lisible ; les boutons restent détachés des inputs. */
.payment-mini-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 10px;
  align-items: end;
}

.payment-mini-row[hidden] {
  display: none;
}

/* Ligne de paiement VALIDÉE (verrouillée) : champs non éditables et non interactifs. Seul le bouton
   « Annuler paiement » reste actif (il n'est ni input ni select). Renforce le readonly/tabindex posés
   sur les champs côté HTML. */
.payment-mini-row.locked input,
.payment-mini-row.locked select,
.payment-mini-row.locked .number-stepper {
  pointer-events: none;
  cursor: not-allowed;
  opacity: 0.72;
  background: color-mix(in srgb, var(--surface-2) 72%, transparent);
}
/* le bouton « Annuler paiement » reste pleinement actif */
.payment-mini-row.locked .payment-ok {
  pointer-events: auto;
  opacity: 1;
  cursor: pointer;
}

.payment-mini-row > .payment-label {
  flex: 0 0 auto;
  align-self: end;
}

/* Répartition proportionnelle des champs : tous grandissent (flex-grow) pour occuper toute la largeur
   disponible — pas de vide à droite — avec des proportions cohérentes : « Somme » reste courte,
   « Mode » et « Payé le » sont moyens, « État » moyen. La ligne ne passe à la ligne que si la largeur
   est vraiment insuffisante (min-width). Composant commun : vaut pour tous les modules de paiement. */
.payment-mini-row > label {
  flex: 2 1 100px;            /* Mode : moyen */
  min-width: 86px;
}

.payment-mini-row > label:has(input[type="number"]) {
  flex: 1 1 92px;            /* Somme (avec boutons +/-) : court */
  min-width: 88px;
}

.payment-mini-row > label.payment-date-field {
  flex: 2 1 132px;           /* Payé le : moyen + (la date a besoin de place) */
  min-width: 126px;
}

.payment-mini-row > label.payment-check-number-field {
  flex: 1.4 1 100px;
  min-width: 92px;
}

.payment-mini-row > label.payment-state-field {
  flex: 1.6 1 112px;         /* État (mode formulaire) */
  min-width: 100px;
}

.payment-mini-row > .computed-payment-status {
  flex: 0 1 auto;            /* État (mode live) : taille naturelle, ne gonfle pas au retour à la ligne */
  min-width: 76px;
}

.payment-mini-row > .payment-ok {
  flex: 0 0 auto;
  align-self: end;
}

.payment-mini-row label > input,
.payment-mini-row label > select,
.payment-mini-row label > .number-stepper {
  width: 100%;
}

.payment-mini-row .number-stepper {
  min-width: 0;
}

.payment-mini-row.immediate-payment .payment-check-number-field,
.payment-mini-row.immediate-payment .payment-state-field {
  display: none;
}

.payment-mini-row label {
  gap: 3px;
  font-size: 0.68rem;
  line-height: 1.05;
  white-space: nowrap;
}

.payment-mini-row input,
.payment-mini-row select,
.payment-mini-row button {
  min-height: 30px;
  padding: 4px 5px;
  font-size: 0.74rem;
}

.payment-mini-row .computed-payment-status {
  gap: 3px;
  align-content: end;
}

.payment-mini-row .computed-payment-status span:first-child {
  font-size: 0.66rem;
}

.person-cell {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.person-cell strong {
  font-weight: 800;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.person-cell span {
  color: var(--muted);
  font-size: 0.86rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.order-items {
  display: grid;
  gap: 6px;
  min-width: 180px;
  white-space: normal;
}

.order-items div {
  display: grid;
  gap: 2px;
}

.order-items strong {
  font-weight: 750;
}

.order-items span {
  color: var(--muted);
  font-size: 0.82rem;
}

.shop-overview {
  display: grid;
  grid-template-columns: minmax(280px, 0.9fr) minmax(360px, 1.1fr);
  gap: 14px;
}

.shop-catalog-grid {
  padding: 14px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}

.shop-catalog-card {
  min-width: 0;
  padding: 12px;
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  border: 1px solid var(--line);
  border-left: 4px solid var(--accent);
  border-radius: var(--radius);
  background: var(--surface-2);
}

.shop-catalog-card.stock-warning {
  border-left-color: #f59e0b;
}

.shop-catalog-card.stock-negative {
  border-left-color: #dc2626;
}

.shop-catalog-image {
  display: grid;
  place-items: start center;
}

.shop-catalog-info {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.shop-catalog-info strong,
.shop-catalog-info span,
.shop-catalog-info small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.shop-catalog-info span,
.shop-catalog-info small,
.shop-catalog-footer span {
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 750;
}

.shop-catalog-footer {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1fr 1fr auto;
  gap: 8px;
  align-items: end;
}

.shop-catalog-footer div {
  display: grid;
  gap: 2px;
}

.shop-catalog-footer strong {
  font-variant-numeric: tabular-nums;
}

.shop-sale-steps {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.shop-sale-steps span {
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-2);
  color: var(--accent);
  text-align: center;
  font-size: 0.82rem;
  font-weight: 900;
}

.sale-step-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 10px;
}

.dialog-section[data-sale-step="client"] {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.dialog-section[data-sale-step="client"] h3,
.dialog-section[data-sale-step="client"] .wide,
.dialog-section[data-sale-step="client"] .sale-step-actions {
  grid-column: 1 / -1;
}

.shop-follow-list,
.shop-article-list,
.shop-order-list {
  display: grid;
  gap: 10px;
  padding: 14px;
}

.shop-follow-row {
  width: 100%;
  min-height: 58px;
  display: grid;
  grid-template-columns: minmax(120px, 1fr) auto 112px;
  gap: 10px;
  align-items: center;
  text-align: left;
  border-color: var(--line);
}

.shop-follow-row strong {
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.shop-article-row {
  display: grid;
  grid-template-columns: 32px minmax(130px, 1fr) 56px 98px;
  gap: 10px;
  align-items: center;
  min-height: 34px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--line);
}

.shop-article-row:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.shop-order-list {
  padding: 16px;
}

.shop-order-card {
  border: 1px solid var(--line);
  border-left: 4px solid var(--accent);
  border-radius: var(--radius);
  background: var(--surface);
  overflow: hidden;
}

.shop-order-card.has-due {
  border-left-color: var(--accent-3);
}

.shop-order-card summary {
  list-style: none;
}

.shop-order-card summary::-webkit-details-marker {
  display: none;
}

.shop-order-summary {
  min-height: 58px;
  display: grid;
  grid-template-columns: minmax(150px, 1.4fr) auto minmax(86px, 0.55fr) minmax(86px, 0.55fr) minmax(98px, 0.6fr) 24px;
  gap: 10px;
  align-items: center;
  padding: 10px 12px;
  cursor: pointer;
}

.shop-order-summary:hover {
  background: color-mix(in srgb, var(--surface-2) 68%, transparent);
}

.shop-order-client,
.shop-order-amount,
.shop-order-meta {
  min-width: 0;
}

.shop-order-client {
  display: grid;
  gap: 2px;
}

.shop-order-client strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.shop-order-client small,
.shop-order-amount small,
.shop-order-meta {
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 750;
  text-transform: uppercase;
}

.shop-order-amount {
  display: grid;
  gap: 2px;
  justify-items: end;
}

.shop-order-amount strong {
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.shop-order-items-preview {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  min-width: 0;
}

.order-summary-items {
  margin-top: 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.shop-order-item-chip {
  max-width: 100%;
  min-height: 26px;
  padding: 4px 8px;
  display: inline-flex;
  gap: 6px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-2);
  color: var(--ink);
  font-size: 0.78rem;
}

.shop-order-item-chip strong,
.shop-order-item-chip em {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.shop-order-item-chip em {
  color: var(--muted);
  font-style: normal;
  font-weight: 750;
}

.shop-order-amount.due strong {
  color: var(--accent-3);
}

.shop-order-toggle {
  width: 24px;
  height: 24px;
  display: grid;
  place-items: center;
  color: var(--muted);
  font-size: 1.2rem;
  transition: transform 0.16s ease;
}

.shop-order-card[open] .shop-order-toggle {
  transform: rotate(90deg);
}

.shop-order-detail {
  display: grid;
  gap: 12px;
  padding: 0 12px 12px;
  border-top: 1px solid var(--line);
}

.shop-order-meta {
  display: grid;
  gap: 4px;
  padding-top: 12px;
  text-transform: none;
  font-weight: 650;
}

.shop-order-head,
.shop-item-line,
.shop-total-grid,
.shop-order-actions {
  display: grid;
  gap: 10px;
  align-items: center;
}

.shop-order-head {
  grid-template-columns: minmax(180px, 1fr) auto;
}

.shop-contact {
  margin-top: 5px;
  color: var(--muted);
  font-size: 0.84rem;
}

.shop-member-select select {
  min-height: 40px;
  font-weight: 650;
}

.shop-order-status {
  display: grid;
  justify-items: end;
  gap: 3px;
}

.shop-order-status strong {
  font-size: 1.25rem;
  font-variant-numeric: tabular-nums;
}

.shop-order-status span:last-child {
  color: var(--muted);
  font-size: 0.74rem;
  text-transform: uppercase;
  font-weight: 750;
}

.shop-items-list {
  display: grid;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
}

.shop-item-line {
  grid-template-columns: 34px minmax(170px, 1fr) 74px 92px 100px;
  min-height: 44px;
  padding: 9px 10px;
  border-bottom: 1px solid var(--line);
}

.shop-item-line:last-child {
  border-bottom: 0;
}

.shop-item-line div {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.shop-item-line strong,
.shop-article-row > span:not(.article-image) {
  overflow: hidden;
  text-overflow: ellipsis;
}

.shop-item-line span {
  color: var(--muted);
}

.shop-total-grid {
  grid-template-columns: repeat(4, minmax(110px, 1fr));
}

.shop-total-grid div {
  display: grid;
  gap: 3px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface-2);
}

.shop-total-grid span {
  color: var(--muted);
  font-size: 0.74rem;
  text-transform: uppercase;
  font-weight: 750;
}

.shop-payments {
  padding: 10px;
}

.shop-payments summary {
  margin-bottom: 8px;
}

.shop-order-actions {
  grid-template-columns: repeat(2, max-content);
  justify-content: end;
}

.empty.compact {
  padding: 12px;
}

.dialog-table-wrap {
  margin-top: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
}

.dialog-table-scroll {
  max-height: 42vh;
  overflow-y: auto;
}

.dialog-table-scroll::-webkit-scrollbar {
  width: 0;
}

.shop-order-editor h3 {
  margin-bottom: 6px;
}

.order-add-line {
  display: flex;
  align-items: end;
  gap: 8px;
  flex-wrap: wrap;
}

.order-add-line label {
  min-width: min(280px, 100%);
}

.order-editor-table td {
  vertical-align: top;
}

.order-editor-table {
  table-layout: auto;
  min-width: 820px;
  width: 100%;
}

.order-editor-table th:nth-child(3),
.order-editor-table td:nth-child(3) {
  min-width: 200px;
  width: 30%;
}

.order-editor-table input,
.order-editor-table select {
  min-width: 68px;
}

.order-size-select {
  min-width: 116px;
  width: 100%;
}

.stock-table th,
.stock-table td {
  vertical-align: middle;
}

.stock-table {
  min-width: 860px;
}

.stock-row td {
  padding-top: 8px;
  padding-bottom: 8px;
}

.stock-row.stock-warning td {
  background: color-mix(in srgb, #f59e0b 14%, var(--surface));
}

.stock-row.stock-negative td {
  background: color-mix(in srgb, #dc2626 15%, var(--surface));
}

.stock-row.stock-warning td:first-child {
  border-left: 4px solid #f59e0b;
}

.stock-row.stock-negative td:first-child {
  border-left: 4px solid #dc2626;
}

.stock-article-main,
.stock-price-cell,
.stock-count-cell,
.stock-value-cell {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.stock-article-main strong {
  overflow: hidden;
  text-overflow: ellipsis;
}

.stock-article-main span,
.stock-price-cell span,
.stock-count-cell span,
.stock-value-cell span {
  color: var(--muted);
  font-size: 0.78rem;
  white-space: nowrap;
}

.stock-price-cell strong,
.stock-count-cell strong {
  color: var(--ink);
}

.stock-article-dialog-head {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  align-items: start;
}

.dialog-mini-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}

.dialog-mini-title h3 {
  margin: 0;
}

.size-stock-form {
  display: grid;
  gap: 8px;
}

.size-stock-form [data-size-stock-list] {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(242px, 1fr));
  gap: 8px;
}

.size-stock-form-row {
  display: grid;
  grid-template-columns: minmax(70px, 0.85fr) minmax(116px, 1fr) 32px;
  gap: 6px;
  align-items: end;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: var(--surface-3);
}

.size-stock-form-row label {
  gap: 3px;
  font-size: 0.72rem;
}

.size-stock-form-row input {
  min-height: 30px;
  padding: 4px 6px;
}

.size-stock-form-row .number-stepper {
  min-width: 0;
  width: 100%;
  grid-template-columns: minmax(34px, 1fr) auto;
}

.size-stock-form-row .number-stepper-controls {
  grid-template-columns: repeat(2, 20px);
  gap: 4px;
}

.size-stock-form-row .number-stepper-controls button {
  width: 20px;
  min-width: 20px;
}

.size-stock-form-row > button.icon {
  width: 32px;
  min-width: 32px;
}

.stock-size-editor,
.order-size-editor {
  min-width: 120px;
}

.stock-size-editor {
  display: inline-grid;
  grid-template-columns: 64px minmax(108px, auto);
  gap: 8px;
  align-items: center;
}

.stock-size-editor.no-sizes {
  grid-template-columns: minmax(108px, 118px) minmax(76px, 104px);
  gap: 7px;
  min-width: 196px;
}

.stock-size-editor.no-sizes .number-stepper {
  min-width: 0;
  width: 100%;
  grid-template-columns: minmax(34px, 1fr) auto;
}

.stock-size-editor.no-sizes .number-stepper-controls {
  grid-template-columns: repeat(2, 20px);
  gap: 4px;
}

.stock-size-editor.no-sizes .number-stepper-controls button {
  width: 20px;
  min-width: 20px;
}

.stock-size-editor.no-sizes > button {
  min-width: 0;
  white-space: nowrap;
}

.stock-size-editor button {
  min-height: 26px;
  padding: 2px 6px;
  font-size: 0.7rem;
}

.stock-qty-stepper {
  width: 68px;
  min-height: 28px;
  padding: 3px 6px;
  font-size: 0.82rem;
}

input[type="number"] {
  text-align: left;
  -moz-appearance: textfield;
  appearance: textfield;
}

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  margin: 0;
  -webkit-appearance: none;
}

.number-stepper {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 5px;
  align-items: center;
  width: 100%;
  min-width: 96px;
}

.number-stepper input[type="number"] {
  width: 100%;
  min-width: 0;
  padding-right: 7px;
  text-align: left;
}

.number-stepper-controls {
  display: grid;
  grid-template-columns: repeat(2, 22px);
  gap: 5px;
  align-items: center;
}

.number-stepper-controls button {
  width: 22px;
  min-width: 22px;
  min-height: 24px;
  padding: 0;
  display: inline-grid;
  place-items: center;
  border-radius: 6px;
  font-size: 0.9rem;
  font-weight: 900;
  line-height: 1;
}

.order-stock-control {
  display: grid;
  gap: 4px;
}

.order-stock-control input,
.order-size-pill input {
  color: var(--text);
  background: var(--surface);
  transition: border-color 0.16s ease, background 0.16s ease, box-shadow 0.16s ease;
}

.order-stock-control input.stock-qty-warning,
.order-size-pill input.stock-qty-warning {
  border-color: #f59e0b;
  background: #fff7ed;
  color: #7c2d12;
  box-shadow: 0 0 0 2px rgba(245, 158, 11, 0.18);
}

.order-stock-control input.stock-qty-danger,
.order-size-pill input.stock-qty-danger {
  border-color: #dc2626;
  background: #fef2f2;
  color: #7f1d1d;
  box-shadow: 0 0 0 2px rgba(220, 38, 38, 0.18);
}

.stock-message {
  font-size: 0.68rem;
  font-weight: 800;
}

.stock-message.warning {
  color: #b45309;
}

.stock-message.danger {
  color: #b91c1c;
}

.size-stock-starter {
  display: grid;
  gap: 6px;
  justify-items: start;
}

.stock-alert-panel {
  display: block;
  gap: 0;
}

.stock-alert-edit-list {
  display: grid;
  gap: 8px;
}

.stock-alert-edit-row {
  display: grid;
  grid-template-columns: minmax(190px, 1fr) auto minmax(120px, 150px);
  gap: 10px;
  align-items: center;
  padding: 8px;
  border: 1px solid var(--line);
  border-left: 4px solid #f59e0b;
  border-radius: 7px;
  background: var(--surface-2);
}

.stock-alert-edit-row.stock-negative {
  border-left-color: #dc2626;
}

.stock-alert-edit-row button {
  justify-content: flex-start;
  display: grid;
  gap: 2px;
  text-align: left;
}

.stock-alert-edit-row label {
  margin: 0;
}

.stock-alert-edit-row input {
  min-height: 30px;
  padding: 4px 6px;
}

.order-size-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 6px;
}

.order-size-pill {
  display: grid;
  grid-template-columns: minmax(44px, auto) minmax(76px, 1fr);
  gap: 6px;
  align-items: center;
  padding: 7px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--surface-3);
  font-size: 0.78rem;
}

.order-size-pill input {
  width: 100%;
  min-height: 32px;
  padding: 4px 6px;
  text-align: left;
}

.order-size-pill small {
  grid-column: 1 / -1;
  color: var(--muted);
  font-size: 0.7rem;
}

.order-size-editor summary {
  min-height: 32px;
  padding: 6px 8px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--surface-3);
  cursor: pointer;
  list-style: none;
}

.order-size-editor summary::-webkit-details-marker {
  display: none;
}

.order-size-editor[open] summary {
  margin-bottom: 6px;
}

.shop-editor-article {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 3px;
  align-items: center;
  min-width: 122px;
  white-space: normal;
}

.shop-editor-article span {
  color: var(--muted);
  font-size: 0.8rem;
}

.article-image {
  display: inline-grid;
  place-items: center;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--surface-2);
  color: var(--muted);
  object-fit: cover;
  font-size: 0.62rem;
  font-weight: 850;
}

.article-image-button {
  display: inline-grid;
  place-items: center;
  width: max-content;
  min-height: 0;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  position: relative;
}

.article-image-button:hover {
  transform: none;
}

.article-image-tiny {
  width: 30px;
  height: 30px;
}

.article-image-small {
  width: 42px;
  height: 42px;
}

.article-image-medium {
  width: 58px;
  height: 58px;
}

.article-image-count {
  position: absolute;
  right: -5px;
  bottom: -5px;
  min-width: 20px;
  padding: 2px 5px;
  border: 1px solid var(--surface);
  border-radius: 999px;
  background: var(--accent);
  color: var(--accent-contrast);
  font-size: 0.62rem;
  font-weight: 900;
  line-height: 1;
}

.article-image-editor {
  display: grid;
  gap: 7px;
  min-width: min(100%, 560px);
}

.article-image-library {
  display: grid;
  gap: 7px;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--surface-2) 70%, var(--surface));
}

.article-library-main {
  display: grid;
  place-items: center;
  min-height: 140px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface);
}

.article-library-main figure {
  display: none;
  gap: 5px;
  justify-items: center;
  margin: 0;
  width: 100%;
}

.article-library-main figure.active {
  display: grid;
}

.article-library-preview {
  width: min(100%, 460px);
  min-height: 132px;
  padding: 0;
  display: grid;
  place-items: center;
  border: 0;
  background: transparent;
}

.article-library-preview img {
  max-width: 100%;
  max-height: 170px;
  border-radius: var(--radius-sm);
  object-fit: contain;
}

.article-library-main figcaption {
  width: 100%;
  padding: 0 8px 7px;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 800;
  text-align: center;
}

.article-library-thumbs,
.article-gallery-thumbs {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  justify-content: center;
}

.article-library-thumb {
  width: 34px;
  height: 34px;
  min-height: 34px;
  padding: 2px;
  border: 2px solid transparent;
  border-radius: 7px;
  background: var(--surface);
}

.article-library-thumb.active {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 18%, transparent);
}

.article-library-thumb img {
  width: 100%;
  height: 100%;
  border-radius: 4px;
  object-fit: cover;
}

.article-library-thumb.mini {
  width: 30px;
  height: 30px;
  min-height: 30px;
}

.article-caption-list {
  display: grid;
  gap: 5px;
}

.article-caption-row {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto 28px;
  gap: 6px;
  align-items: end;
}

.article-image-order-actions {
  display: flex;
  gap: 4px;
  align-items: center;
  padding-bottom: 1px;
}

.article-image-order-actions .icon {
  width: 24px;
  height: 24px;
  min-height: 24px;
  font-size: 0.72rem;
}

.article-image-thumb-preview {
  position: relative;
  display: inline-grid;
  width: max-content;
}

.article-image-thumb-preview > .icon {
  position: absolute;
  top: -7px;
  right: -7px;
  width: 22px;
  height: 22px;
  min-height: 22px;
  border-radius: 999px;
  background: var(--surface);
  box-shadow: var(--shadow);
}

.article-caption-field {
  display: grid;
  gap: 2px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 800;
}

.article-caption-field input {
  min-height: 28px;
  padding: 4px 7px;
  font-size: 0.78rem;
  width: 100%;
}

.article-image-upload {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 4px 7px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--surface);
  color: var(--ink);
  font-size: 0.74rem;
  font-weight: 750;
  cursor: pointer;
}

.article-image-upload input {
  position: absolute;
  inline-size: 1px;
  block-size: 1px;
  opacity: 0;
  pointer-events: none;
}

.article-pending-images {
  display: grid;
  gap: 6px;
  padding: 8px;
  border: 1px dashed color-mix(in srgb, var(--accent) 42%, var(--line));
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--accent) 7%, var(--surface));
}

.article-pending-images[hidden] {
  display: none;
}

.article-pending-images > strong {
  color: var(--accent);
  font-size: 0.84rem;
}

.article-pending-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(70px, 1fr));
  gap: 6px;
}

.article-pending-card {
  display: grid;
  gap: 5px;
  min-width: 0;
}

.article-pending-card img {
  width: 100%;
  aspect-ratio: 1 / 1;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: var(--surface);
  object-fit: cover;
}

.article-pending-card span {
  overflow: hidden;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 750;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.article-pending-card label {
  display: grid;
  gap: 3px;
  color: var(--muted);
  font-size: 0.7rem;
  font-weight: 800;
}

.article-pending-card input {
  width: 100%;
  min-height: 28px;
  padding: 4px 7px;
  font-size: 0.76rem;
}

.article-image-viewer {
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr) 36px;
  gap: 8px;
  place-items: center;
  max-height: min(64vh, 620px);
  overflow: hidden;
}

.article-image-stage {
  grid-column: 2;
  display: grid;
  place-items: center;
  min-width: min(64vw, 700px);
}

.article-image-viewer figure {
  display: none;
  gap: 5px;
  justify-items: center;
  margin: 0;
}

.article-image-viewer figure.active {
  display: grid;
}

.article-image-viewer img {
  max-width: min(100%, 900px);
  max-height: 48vh;
  border-radius: var(--radius);
  object-fit: contain;
}

.article-image-viewer figcaption {
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 800;
  text-align: center;
}

.article-gallery-arrow {
  width: 34px;
  height: 34px;
  min-height: 34px;
  border-radius: 999px;
  font-size: 1.55rem;
}

.article-gallery-arrow.prev {
  grid-column: 1;
}

.article-gallery-arrow.next {
  grid-column: 3;
}

.article-gallery-counter {
  grid-column: 1 / -1;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 900;
}

.article-gallery-thumbs {
  grid-column: 1 / -1;
  max-width: min(100%, 700px);
}

.size-grid.compact {
  margin-top: 0;
  grid-template-columns: repeat(auto-fit, minmax(68px, 1fr));
}

.size-grid.compact label {
  font-size: 0.72rem;
}

.payment-amount,
.payment-tax,
.payment-date,
.payment-state {
  min-height: 32px;
  padding: 4px 7px;
}

.payment-status {
  min-width: 0;
}

.payment-status .status {
  width: 100%;
  justify-content: center;
  white-space: nowrap;
}

.computed-payment-status {
  display: grid;
  gap: 6px;
  align-content: end;
}

.computed-payment-status span:first-child {
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 700;
}

.tariff-summary {
  background: #f6faf8;
  border-color: #cfe3db;
}

.tariff-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(110px, 1fr));
  gap: 10px;
}

.tariff-summary-grid div {
  display: grid;
  gap: 4px;
}

.tariff-summary-grid span {
  color: var(--muted);
  font-size: 0.75rem;
  font-weight: 700;
}

.tariff-summary-grid strong {
  font-size: 1rem;
}

.tariff-license-note {
  font-size: 0.72rem;
  color: var(--muted);
  font-weight: 400;
}

.tariff-license-note span {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--muted);
}

.registration-total-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(110px, 1fr));
  gap: 10px;
}

.registration-total-grid span {
  color: var(--muted);
  font-size: 0.75rem;
  font-weight: 700;
}

.registration-total-grid strong {
  font-size: 1rem;
}

.registration-total-grid div:last-child strong {
  color: var(--accent, #2a7a5b);
}

input[readonly] {
  background: #eef3f0;
  color: var(--ink);
  cursor: default;
}

input.locked-price {
  cursor: not-allowed;
  font-weight: 700;
  opacity: 0.92;
}

.menu-order-group-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.menu-order-group-head h4 {
  margin: 0;
}
.menu-order-group-actions {
  display: flex;
  gap: 4px;
}
.menu-order-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  opacity: 0.85;
}
.menu-order-icon svg {
  width: 18px;
  height: 18px;
}

.icon-picker-field {
  margin-top: 6px;
}
.icon-picker {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(48px, 1fr));
  gap: 6px;
  max-height: 248px;
  overflow-y: auto;
  padding: 4px;
}
.icon-picker-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  padding: 8px 4px;
  border: 1px solid var(--line, rgba(0,0,0,0.12));
  border-radius: 10px;
  background: var(--surface, #fff);
  cursor: pointer;
}
.icon-picker-btn .nav-icon {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.icon-picker-btn .nav-icon svg,
.icon-picker-btn svg {
  display: block;
  width: 32px;
  height: 32px;
}
.icon-picker-btn:hover {
  border-color: var(--terra, #9a5148);
}
.icon-picker-btn.selected {
  outline: 2px solid var(--terra, #9a5148);
  outline-offset: -1px;
}
.icon-picker-default-label {
  font-size: 0.6rem;
  font-weight: 700;
  opacity: 0.8;
}

.menu-target-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 8px;
}
.menu-target-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border: 1px solid var(--line, rgba(0,0,0,0.12));
  border-radius: 10px;
  background: var(--surface, #fff);
  cursor: pointer;
  font-weight: 600;
  text-align: left;
}
.menu-target-btn:hover {
  border-color: var(--terra, #9a5148);
}
.menu-target-btn svg {
  width: 20px;
  height: 20px;
}

/* ===== Modules sport : badges de statut (vert/orange/rouge/gris) ===== */
.doc-badge, .cap-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 9px;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 800;
  white-space: nowrap;
}
.doc-ok, .cap-available { background: rgba(58,125,68,0.16); color: #2f6b3a; }
.doc-soon, .cap-almost { background: rgba(196,122,44,0.18); color: #9a5a16; }
.doc-expired, .doc-missing, .cap-full { background: rgba(181,68,58,0.16); color: #a13b32; }
.doc-none { background: rgba(0,0,0,0.07); color: var(--slate, #6a6a6a); }
:root[data-theme$="-dark"] .doc-ok, :root[data-theme$="-dark"] .cap-available { color: #7fd08c; }
:root[data-theme$="-dark"] .doc-soon, :root[data-theme$="-dark"] .cap-almost { color: #e0a35a; }
:root[data-theme$="-dark"] .doc-expired, :root[data-theme$="-dark"] .doc-missing, :root[data-theme$="-dark"] .cap-full { color: #e98a7f; }

/* ===== Groupes ===== */
.group-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
}
.group-card {
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.05);
}
.group-card.group-archived { opacity: 0.6; }
.group-card-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.group-card-head h3 { margin: 0; display: flex; align-items: center; }
.group-color-dot { display: inline-block; width: 11px; height: 11px; border-radius: 50%; margin-right: 7px; flex: 0 0 auto; border: 1px solid rgba(0,0,0,0.15); }
.group-card-meta { margin-top: 6px; font-size: 0.85rem; opacity: 0.85; display: flex; flex-wrap: wrap; gap: 4px; }
.group-card-notes { margin: 8px 0 0; font-size: 0.85rem; }
.group-card-actions { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 12px; }

/* ===== Gestion des membres d'un groupe (dialogue) ===== */
.group-members-current,
.group-members-add { margin-bottom: 6px; }
.group-members-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 10px; flex-wrap: wrap; margin-bottom: 6px;
}
.group-members-head h3 { margin: 0; }
.group-members-head .small { flex: 0 0 auto; padding: 5px 10px; font-size: 0.82rem; }
.group-cap-warn {
  margin: 0 0 8px;
  padding: 6px 10px;
  font-size: 0.85rem;
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent) 28%, transparent);
}
.group-member-list { display: flex; flex-direction: column; gap: 6px; }
.group-member-row {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
}
.group-member-id { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.group-member-id .muted { font-size: 0.82rem; }
.group-member-row .danger.small { flex: 0 0 auto; padding: 5px 10px; font-size: 0.82rem; }
.group-member-search {
  width: 100%;
  margin: 4px 0 10px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  color: var(--ink);
}

/* Champ de recherche commun des listes de dialogue (Phase A) : input + compteur de résultats. */
.dialog-list-search {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 6px 0 10px;
}

.dialog-list-search input[type="search"] {
  flex: 1 1 auto;
  min-width: 0;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  color: var(--ink);
}

.dialog-list-search-count {
  flex: 0 0 auto;
  font-size: .82rem;
  white-space: nowrap;
}
.group-add-list {
  display: flex; flex-direction: column; gap: 4px;
  max-height: 320px; overflow-y: auto;
  border: 1px solid var(--line); border-radius: var(--radius); padding: 6px;
}
.group-add-row {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 8px; border-radius: var(--radius); cursor: pointer;
}
.group-add-row:hover { background: color-mix(in srgb, var(--ink) 6%, transparent); }
.group-add-row input[type="checkbox"] { flex: 0 0 auto; }
.group-add-name { flex: 1 1 auto; min-width: 0; }
.group-add-tags { display: flex; flex-wrap: wrap; gap: 4px; justify-content: flex-end; }
.group-add-tag {
  font-size: 0.74rem; padding: 2px 7px; border-radius: 999px; white-space: nowrap;
  border: 1px solid var(--line);
}
.group-add-tag.warn {
  color: #92400e;
  background: color-mix(in srgb, #f59e0b 18%, transparent);
  border-color: color-mix(in srgb, #f59e0b 38%, transparent);
}
.group-add-tag.move {
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  border-color: color-mix(in srgb, var(--accent) 30%, transparent);
}
.group-add-empty-search { padding: 8px 4px; }

/* ===== Documents sportifs ===== */
.doc-summary { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 12px; margin: 10px 16px 14px; }
/* Barre de filtres : pas de fond blanc, pastilles harmonisées avec le thème */
.doc-filters { display: flex; flex-wrap: wrap; gap: 6px; margin: 0 16px 12px; padding: 0; border: 0; background: transparent; }
/* Tableau Documents : défilement HORIZONTAL avec barre de défilement toujours visible */
.doc-table-scroll {
  margin: 0 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow-x: auto;
  overflow-y: auto;
  max-height: 60vh;
}
.doc-table-scroll .doc-table { margin: 0; }
.doc-table-scroll::-webkit-scrollbar { height: 14px; width: 12px; }
.doc-table-scroll::-webkit-scrollbar-track { background: var(--surface-2); border-radius: 7px; }
.doc-table-scroll::-webkit-scrollbar-thumb {
  background: color-mix(in srgb, var(--ink) 35%, transparent);
  border-radius: 7px;
  border: 3px solid var(--surface-2);
}
.doc-table-scroll::-webkit-scrollbar-thumb:hover { background: color-mix(in srgb, var(--ink) 55%, transparent); }
.doc-filters .seg { border: 1px solid var(--line); border-radius: 999px; background: var(--surface); color: var(--ink); padding: 5px 13px; min-height: 0; cursor: pointer; font-weight: 600; font: inherit; }
.doc-filters .seg:hover { border-color: var(--accent); }
.doc-filters .seg.active { background: var(--surface-2); color: var(--accent); border-color: var(--accent); font-weight: 750; }
.doc-table-wrap { padding: 0 16px; }
.kpi.kpi-alert strong { color: #a13b32; }
.kpi.kpi-warn strong { color: #9a5a16; }
.doc-table th, .doc-table td { white-space: nowrap; }

/* ===== Planning ===== */
/* Barre de navigation des semaines (Phase A) */
.planning-week-nav {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between;
  gap: 10px; margin: 4px 16px 14px; padding: 10px 12px;
  border: 1px solid var(--line, rgba(0,0,0,0.12)); border-radius: var(--radius, 10px);
  background: var(--surface, rgba(0,0,0,0.02));
}
.pwn-controls { display: flex; flex-wrap: wrap; gap: 6px; }
.pwn-controls button {
  padding: 6px 12px; border-radius: var(--radius, 8px);
  border: 1px solid var(--line, rgba(0,0,0,0.15)); background: transparent; color: inherit; cursor: pointer;
}
.pwn-controls button:hover { background: color-mix(in srgb, var(--ink, #222) 8%, transparent); }
.pwn-controls button.is-today {
  background: color-mix(in srgb, var(--accent, #4d5966) 16%, transparent);
  border-color: color-mix(in srgb, var(--accent, #4d5966) 36%, transparent);
  font-weight: 700;
}
.pwn-label { display: flex; flex-direction: column; align-items: flex-end; line-height: 1.25; }
.pwn-label strong { font-size: 1.02rem; }
.pwn-label span { font-size: 0.85rem; opacity: 0.8; }
.pwn-weeks { display: flex; align-items: center; gap: 8px; }
.pwn-weeks .muted { font-size: 0.85rem; }
.pwn-weeks .segmented { flex: 0 0 auto; }
.planning-week-head small { display: block; font-weight: 600; font-size: 0.72rem; opacity: 0.7; }
/* Blocs multi-semaines empilés verticalement (Phase B) */
.planning-week-block + .planning-week-block {
  margin-top: 14px; padding-top: 14px;
  border-top: 2px dashed var(--line, rgba(0,0,0,0.18));
}
.planning-week-block-head {
  display: flex; flex-wrap: wrap; align-items: baseline; gap: 10px;
  margin: 2px 16px 10px; padding: 6px 10px;
  border-radius: var(--radius, 8px);
  background: color-mix(in srgb, var(--accent, #4d5966) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent, #4d5966) 24%, transparent);
}
.planning-week-block-head strong { font-size: 1rem; }
.planning-week-block-head span { font-size: 0.85rem; opacity: 0.8; }
@media (max-width: 720px) {
  .planning-week-nav { flex-direction: column; align-items: stretch; }
  .pwn-controls { justify-content: space-between; }
  .pwn-weeks { justify-content: space-between; }
  .pwn-label { align-items: flex-start; }
}
.planning-filters { display: flex; flex-wrap: wrap; gap: 12px; margin: 8px 0 14px; padding: 8px 16px 0; }
.planning-day { margin-bottom: 16px; padding: 0 16px; }
.planning-day h3 { margin: 0 0 8px; border-bottom: 1px solid var(--line, rgba(0,0,0,0.12)); padding-bottom: 4px; }
.course-line { display: flex; align-items: center; flex-wrap: wrap; gap: 8px 12px; padding: 8px 10px; border-radius: 9px; background: var(--surface, rgba(0,0,0,0.02)); border: 1px solid var(--line, rgba(0,0,0,0.08)); margin-bottom: 7px; }
.course-line.course-conflict { outline: 2px solid rgba(181,68,58,0.5); }
.course-time { font-weight: 800; min-width: 92px; }
.course-info { flex: 1 1 220px; min-width: 0; display: flex; flex-direction: column; gap: 1px; }
.course-info span { font-size: 0.82rem; overflow-wrap: anywhere; }
.course-actions { display: flex; align-items: center; flex-wrap: wrap; gap: 6px; }
.planning-week { display: grid; grid-template-columns: repeat(7, 1fr); gap: 8px; padding: 0 16px 12px; align-items: start; }
.planning-week-col { min-width: 0; display: flex; flex-direction: column; gap: 7px; }
.planning-week-head { font-weight: 800; text-align: center; padding: 4px; border-bottom: 1px solid var(--line, rgba(0,0,0,0.12)); margin-bottom: 2px; }
/* Fichette légère par créneau : cadre fin discret, padding, lignes bien séparées, texte qui passe à la ligne */
.planning-week-slot {
  font-size: 0.74rem;
  padding: 7px 8px;
  border-radius: var(--radius, 8px);
  background: var(--surface, rgba(0,0,0,0.04));
  border: 1px solid var(--line, rgba(0,0,0,0.10));
  cursor: pointer;
  display: flex; flex-direction: column; gap: 4px;
  min-width: 0;
  overflow-wrap: anywhere; word-break: break-word;
}
.planning-week-slot.course-conflict { outline: 1.5px solid rgba(181,68,58,0.5); }
.pws-line { display: flex; align-items: flex-start; justify-content: space-between; gap: 5px; }
.pws-title { flex: 1 1 auto; min-width: 0; font-weight: 600; line-height: 1.3; }
.pws-meta { display: flex; flex-direction: column; gap: 1px; }
.pws-meta span { opacity: 0.74; line-height: 1.3; }
.pws-badges { display: flex; flex-wrap: wrap; gap: 4px; align-items: center; margin-top: 1px; }
.pws-note { font-style: italic; opacity: 0.8; line-height: 1.3; }
/* Exceptions par date (Phase C1) : séance annulée / note ce jour */
.course-line.course-cancelled .course-time,
.course-line.course-cancelled .course-info strong { text-decoration: line-through; }
.course-line.course-cancelled,
.planning-week-slot.course-cancelled { opacity: 0.62; }
.course-ex-badge { white-space: nowrap; }
.course-recurrence-badge { display: inline-block; margin-left: 6px; padding: 0 7px; border-radius: 999px; font-size: 0.66rem; font-weight: 700; vertical-align: middle; background: rgba(0,0,0,0.07); opacity: 0.78; white-space: nowrap; }
.course-ex-note { font-style: italic; }
.course-time-exception { color: var(--accent, #b5443a); }
/* Bouton « Modifier cette date » : explicite (libellé + icône), pas un simple pictogramme */
.course-date-btn { background: none; border: 1px solid var(--line, rgba(0,0,0,0.18)); border-radius: 7px; cursor: pointer; padding: 3px 9px; font-size: 0.78rem; display: inline-flex; align-items: center; gap: 5px; white-space: nowrap; }
.course-date-btn:hover { background: rgba(0,0,0,0.05); }
/* Bloc « habituel → cette date » : ce qui change est visible directement sur la séance */
.course-ex-diff { margin-top: 5px; padding: 4px 11px; border-radius: 8px; background: rgba(217,130,43,0.10); border: 1px solid rgba(217,130,43,0.38); display: flex; flex-direction: column; gap: 0; font-size: 0.8rem; line-height: 1.35; }
.course-ex-diff-cancelled { background: rgba(181,68,58,0.10); border-color: rgba(181,68,58,0.42); }
.course-ex-row { display: flex; flex-direction: column; gap: 1px; padding: 6px 0; }
.course-ex-row + .course-ex-row { border-top: 1px solid rgba(0,0,0,0.10); }
.course-ex-field { font-weight: 800; }
.course-ex-was { opacity: 0.72; text-decoration: line-through; text-decoration-color: rgba(0,0,0,0.3); }
.course-ex-now { font-weight: 800; color: var(--accent, #b5443a); }
.course-ex-arrow { opacity: 0.55; font-weight: 700; }
.course-ex-tag { display: inline-block; margin-right: 5px; padding: 0 5px; border-radius: 6px; font-size: 0.6rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.04em; text-decoration: none; background: rgba(0,0,0,0.10); opacity: 0.85; vertical-align: middle; }
.course-ex-tag-now { background: var(--accent, #b5443a); color: var(--on-accent); opacity: 1; }
.course-ex-note-row { font-style: italic; opacity: 0.9; }
/* Bannière « Modification exceptionnelle » en tête de la fiche de séance */
.course-ex-banner { background: rgba(217,130,43,0.12); border: 1px solid rgba(217,130,43,0.42); border-radius: 9px; padding: 10px 12px; display: flex; flex-direction: column; gap: 5px; }
.course-ex-banner-cancelled { background: rgba(181,68,58,0.12); border-color: rgba(181,68,58,0.45); }
.course-ex-banner-title { font-weight: 800; font-size: 0.98rem; }
/* Bloc d'information (discret, neutre) : explique le rôle de la fenêtre, distinct de l'encadré orange */
.course-ex-info { border: 1px solid var(--line, rgba(0,0,0,0.12)); background: var(--surface, rgba(0,0,0,0.02)); border-radius: 9px; padding: 9px 12px; display: flex; flex-direction: column; gap: 5px; }
.course-ex-info p { margin: 0; }
/* Encadré « option » regroupant une case à cocher et son explication (fiche coach) */
.coach-option-box { border: 1px solid var(--line, rgba(0,0,0,0.12)); background: var(--surface, rgba(0,0,0,0.02)); border-radius: 9px; padding: 9px 12px; display: flex; flex-direction: column; gap: 4px; margin: 4px 0 10px; }
.coach-option-box .form-check { margin: 0; font-weight: 600; }
/* Module « Donner mon avis » — bouton d'accès + dialogue collecteur de retours */
.feedback-cta { display: inline-flex; align-items: center; gap: 7px; margin-top: 12px; padding: 7px 14px; border: 1px solid var(--line); border-radius: 999px; background: var(--surface); color: var(--text); font: inherit; font-weight: 600; font-size: 0.9rem; cursor: pointer; transition: border-color .15s, background .15s, transform .05s; }
.feedback-cta:hover { border-color: var(--accent); background: color-mix(in srgb, var(--accent) 8%, var(--surface)); }
.feedback-cta:active { transform: translateY(1px); }
.feedback-cta-icon { font-size: 1.05em; line-height: 1; }
.feedback-form { display: flex; flex-direction: column; gap: 18px; max-width: 560px; }
.feedback-intro { margin: 0; color: var(--muted); font-size: 0.92rem; }
.feedback-group { display: flex; flex-direction: column; gap: 8px; }
.feedback-group-label { font-weight: 700; font-size: 0.78rem; letter-spacing: .03em; text-transform: uppercase; color: var(--muted); }
.feedback-group-label em { font-weight: 400; text-transform: none; letter-spacing: 0; font-style: normal; }
.feedback-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.feedback-chip { display: inline-flex; align-items: center; gap: 7px; padding: 7px 13px; border: 1px solid var(--line); border-radius: 999px; cursor: pointer; font-size: 0.9rem; user-select: none; transition: border-color .15s, background .15s; }
.feedback-chip:hover { border-color: var(--accent); }
.feedback-chip input { margin: 0; }
.feedback-chip:has(input:checked) { border-color: var(--accent); background: color-mix(in srgb, var(--accent) 14%, var(--surface)); font-weight: 600; }
.feedback-chip-soft { font-size: 0.85rem; padding: 5px 11px; }
.feedback-questions { display: flex; flex-direction: column; gap: 14px; }
.feedback-questions:empty { display: none; }
.feedback-qblock { display: flex; flex-direction: column; gap: 10px; padding: 14px 16px; border: 1px solid var(--line); border-left: 3px solid var(--accent); border-radius: 10px; background: color-mix(in srgb, var(--accent) 4%, var(--surface)); }
.feedback-qblock h4 { margin: 0; font-size: 0.95rem; }
.feedback-field { display: flex; flex-direction: column; gap: 5px; font-size: 0.9rem; }
.feedback-field > span { font-weight: 600; }
.feedback-field textarea, .feedback-field input { width: 100%; }
.feedback-tech-toggle { display: inline-flex; align-items: center; gap: 8px; font-size: 0.9rem; cursor: pointer; }
.feedback-tech-toggle input { margin: 0; }
.feedback-tech-list { margin: -8px 0 0; font-size: 0.78rem; line-height: 1.5; }
.feedback-actions { display: flex; gap: 10px; flex-wrap: wrap; padding-top: 14px; border-top: 1px solid var(--line); }
.coach-versatile-hint { margin: 0; font-size: 0.8rem; }
.course-date-time { margin-top: 4px; }
.pws-date-btn { flex: 0 0 auto; background: none; border: 0; cursor: pointer; padding: 0 2px; font-size: 0.82rem; line-height: 1; opacity: 0.65; }
.pws-date-btn:hover { opacity: 1; }
/* Conteneur commun d'alertes (Conflit / Coach à remplacer / Salle à remplacer) — Liste + Semaine */
.course-alerts { display: inline-flex; flex-wrap: wrap; gap: 4px; align-items: center; }
.planning-week-slot .course-alerts { display: flex; flex-wrap: wrap; }
.planning-week-slot .course-alerts .doc-badge { font-size: 0.68rem; }
/* Colonnes étroites : les badges passent à la ligne au lieu de déborder horizontalement */
.planning-week-slot .doc-badge { white-space: normal; line-height: 1.25; }
.course-alerts .replace-badge { cursor: pointer; }
.planning-week-empty { display: block; text-align: center; opacity: 0.4; }
.band-alert { outline: 2px solid rgba(181,68,58,0.4); }
.conflict-list { margin: 6px 16px 12px; padding-left: 22px; }
.conflict-list li { margin: 2px 0; }

/* ===== Centre des disponibilités (src/27) ===== */
.avail-band + .avail-band { margin-top: 14px; }
.avail-assistant { padding: 14px 16px 18px; display: flex; flex-direction: column; gap: 16px; }
.avail-lead { margin: 0; color: var(--muted); max-width: 72ch; }
.avail-type { align-self: flex-start; }
.avail-assistant-form { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 10px; }
.avail-field { display: grid; gap: 4px; font-weight: 600; font-size: 0.86rem; }
.avail-field select { width: 100%; }
/* --- Affinage de la recherche (jours / plage horaire / pas) --- */
.avail-assistant-refine { display: flex; flex-wrap: wrap; align-items: flex-end; gap: 14px; margin-top: 10px; }
.avail-field-lbl { font-weight: 600; font-size: 0.86rem; }
.avail-field-days, .avail-field-range { display: grid; gap: 4px; min-width: 0; }
.avail-days { display: flex; flex-wrap: wrap; gap: 4px; }
.avail-day-chip {
  min-width: 40px; padding: 5px 9px; cursor: pointer;
  border: 1px solid var(--line); border-radius: var(--radius);
  background: var(--surface-soft, var(--surface)); color: var(--muted, inherit);
  font: inherit; font-size: 0.82rem; font-weight: 600;
}
.avail-days .avail-day-chip.on { background: var(--accent); border-color: var(--accent); color: var(--on-accent); }
.avail-day-chip:focus-visible { outline: 2px solid var(--accent); outline-offset: 1px; }
.avail-range { display: flex; align-items: center; gap: 6px; }
.avail-range select { min-width: 90px; }
.avail-range-sep { color: var(--muted, inherit); font-weight: 600; }
/* --- Synthèse intelligente --- */
.avail-summary { display: flex; flex-direction: column; gap: 12px; }
.avail-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 10px; }
.avail-stat {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 14px; border: 1px solid var(--line); border-radius: var(--radius);
  background: var(--surface-soft, var(--surface));
}
.avail-stat-num { font-size: 1.6rem; font-weight: 900; line-height: 1; color: var(--accent); }
.avail-stat-ico { font-size: 1.3rem; }
.avail-stat-lbl { display: flex; flex-direction: column; font-size: 0.82rem; color: var(--muted); font-weight: 600; }
.avail-stat-lbl strong { font-size: 0.96rem; color: var(--ink); font-weight: 800; }
.avail-stat-empty .avail-stat-num { color: var(--muted); }
/* --- Recommandation fusionnée (une seule carte forte) --- */
.avail-reco {
  display: flex; flex-direction: column; gap: 5px;
  padding: 16px 18px; border-radius: var(--radius);
  border: 1.5px solid color-mix(in srgb, var(--success) 55%, var(--line));
  background: color-mix(in srgb, var(--success) 14%, var(--surface));
}
.avail-reco-head { display: flex; align-items: center; gap: 8px; }
.avail-reco-ico { font-size: 1.4rem; }
.avail-reco-head strong { font-size: 0.82rem; text-transform: uppercase; letter-spacing: 0.04em; color: color-mix(in srgb, var(--success) 50%, var(--ink)); }
.avail-reco-msg { margin: 2px 0 0; color: var(--muted); }
.avail-reco-slot { font-size: 1.5rem; font-weight: 900; line-height: 1.1; margin: 2px 0; }
.avail-reco-check { list-style: none; margin: 4px 0 2px; padding: 0; display: flex; flex-wrap: wrap; gap: 4px 18px; }
.avail-reco-check li { font-weight: 700; font-size: 0.9rem; color: color-mix(in srgb, var(--success) 45%, var(--ink)); }
.avail-reco-basis { margin: 5px 0 0; font-size: 0.8rem; color: var(--muted); font-style: italic; }
.avail-reco-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 10px; align-items: center; }
.avail-act-secondary { background: transparent; }
.avail-reco-warn { border-color: color-mix(in srgb, var(--accent-3) 45%, var(--line)); background: color-mix(in srgb, var(--accent-3) 10%, var(--surface)); }
.avail-reco-warn .avail-reco-head strong { color: var(--accent-3); }
/* --- Autres créneaux --- */
.avail-results { display: flex; flex-direction: column; gap: 12px; }
.avail-others { border: 1px solid var(--line); border-radius: var(--radius); padding: 4px 12px; }
.avail-others > summary { cursor: pointer; font-weight: 700; padding: 8px 2px; color: var(--muted); }
.avail-others[open] > summary { border-bottom: 1px solid var(--line); margin-bottom: 8px; }
.avail-result-row { display: flex; gap: 12px; align-items: baseline; flex-wrap: wrap; padding: 3px 0; }
.avail-result-day { min-width: 92px; font-weight: 800; }
.avail-result-chips { display: flex; flex-wrap: wrap; gap: 6px; flex: 1 1 auto; }
.avail-chip {
  display: inline-flex; align-items: baseline; gap: 4px;
  padding: 5px 10px; border-radius: 999px;
  border: 1px solid var(--line); background: var(--surface-2);
  font-weight: 700; font-size: 0.84rem; cursor: pointer;
}
.avail-chip small { font-weight: 600; opacity: 0.75; font-size: 0.74rem; }
.avail-chip:hover { transform: translateY(-1px); box-shadow: var(--shadow); }
.avail-chip.lvl-free { border-color: color-mix(in srgb, var(--avail-good) 62%, var(--line)) !important; background-color: color-mix(in srgb, var(--avail-good) 24%, var(--surface)) !important; color: color-mix(in srgb, var(--avail-good) 48%, var(--ink)) !important; background-image: none !important; }
.avail-chip.lvl-some { border-color: color-mix(in srgb, var(--avail-mid) 62%, var(--line)) !important; background-color: color-mix(in srgb, var(--avail-mid) 24%, var(--surface)) !important; color: color-mix(in srgb, var(--avail-mid) 50%, var(--ink)) !important; background-image: none !important; }
.avail-chip.lvl-tight { border-color: color-mix(in srgb, var(--avail-low) 62%, var(--line)) !important; background-color: color-mix(in srgb, var(--avail-low) 24%, var(--surface)) !important; color: color-mix(in srgb, var(--avail-low) 48%, var(--ink)) !important; background-image: none !important; }
.avail-noresult { color: var(--muted); font-style: italic; padding: 4px 0; }
/* --- Fiche d'analyse « Voir les détails » (présentation, variables de thème) --- */
.avail-detail { display: flex; flex-direction: column; gap: 12px; }
.avail-detail-status { display: flex; align-items: flex-start; gap: 10px; padding: 10px 12px; border: 1px solid var(--line); border-radius: var(--radius); }
.avail-detail-status.ok { background: color-mix(in srgb, var(--success) 14%, var(--surface)); border-color: color-mix(in srgb, var(--success) 45%, var(--line)); }
.avail-detail-status.ko { background: color-mix(in srgb, var(--danger) 12%, var(--surface)); border-color: color-mix(in srgb, var(--danger) 42%, var(--line)); }
.avail-detail-status strong { font-size: 0.95rem; color: var(--ink); }
.avail-detail-status-ico { font-weight: 900; line-height: 1.35; }
.avail-detail-status.ok .avail-detail-status-ico { color: var(--success); }
.avail-detail-status.ko .avail-detail-status-ico { color: var(--danger); }
.avail-detail-reasons { margin: 4px 0 0; padding-left: 16px; display: flex; flex-direction: column; gap: 2px; }
.avail-detail-reasons li { color: var(--muted); font-size: 0.85rem; }
.avail-detail-sec { display: flex; flex-direction: column; gap: 6px; }
.avail-detail-sec-title { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.05em; font-weight: 800; color: var(--muted); }
.avail-detail-res-list { display: flex; flex-direction: column; gap: 6px; }
.avail-detail-res { display: flex; align-items: baseline; gap: 8px; padding: 7px 10px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface-soft, var(--surface)); }
.avail-detail-res-ico { font-size: 0.9rem; }
/* Lot C — icônes MGC illustrées dans la zone Disponibilités */
.avail-reco-ico { display: inline-flex; align-items: center; }
.avail-reco-ico .mgc-icon { width: 24px; height: 24px; }
.avail-stat-ico { display: inline-flex; align-items: center; }
.avail-stat-ico .mgc-icon { width: 22px; height: 22px; }
.avail-detail-res-ico { display: inline-flex; align-items: center; align-self: center; }
.avail-detail-res-ico .mgc-icon { width: 20px; height: 20px; }
.avail-detail-res-label { font-size: 0.76rem; font-weight: 700; color: var(--muted); min-width: 52px; }
.avail-detail-res-val { font-weight: 700; color: var(--ink); }
.avail-detail-res.none .avail-detail-res-val { color: var(--muted); font-style: italic; font-weight: 600; }
.avail-detail-badge { display: inline-block; padding: 1px 8px; border-radius: 999px; font-size: 0.74rem; font-weight: 800; }
.avail-detail-badge.ok { background: color-mix(in srgb, var(--success) 22%, var(--surface)); color: color-mix(in srgb, var(--success) 52%, var(--ink)); }
.avail-detail-badge.bad { background: color-mix(in srgb, var(--danger) 20%, var(--surface)); color: color-mix(in srgb, var(--danger) 54%, var(--ink)); }
.avail-detail-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.avail-detail-tag { padding: 3px 10px; border-radius: 999px; font-size: 0.84rem; font-weight: 700; border: 1px solid var(--line); }
.avail-detail-tag.good { background: color-mix(in srgb, var(--avail-good) 18%, var(--surface)); border-color: color-mix(in srgb, var(--avail-good) 50%, var(--line)); color: color-mix(in srgb, var(--avail-good) 45%, var(--ink)); }
.avail-detail-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 5px; }
.avail-detail-rows { display: grid; grid-template-columns: auto 1fr; column-gap: 14px; }
.avail-detail-row { display: contents; }
.avail-detail-row-name { font-weight: 700; color: var(--ink); font-size: 0.88rem; padding: 7px 0; }
.avail-detail-row-reasons { display: flex; flex-wrap: wrap; gap: 5px; justify-content: flex-end; align-content: flex-start; padding: 6px 0; }
.avail-detail-row > * { border-bottom: 1px solid color-mix(in srgb, var(--line) 70%, transparent); }
.avail-detail-row:last-child > * { border-bottom: 0; }
.avail-detail-why { display: inline-block; padding: 2px 8px; border-radius: 999px; font-size: 0.76rem; font-weight: 600; background: color-mix(in srgb, var(--danger) 14%, var(--surface)); color: color-mix(in srgb, var(--danger) 58%, var(--ink)); border: 1px solid color-mix(in srgb, var(--danger) 30%, var(--line)); }
.avail-detail-note { padding: 10px 12px; border: 1px dashed var(--line-strong); border-radius: var(--radius); background: var(--surface-soft, var(--surface)); display: flex; flex-direction: column; gap: 6px; }
.avail-detail-list.note li { font-size: 0.88rem; color: var(--muted); padding-left: 18px; position: relative; }
.avail-detail-list.note li::before { content: "\2713"; position: absolute; left: 2px; color: var(--success); font-weight: 900; }
.avail-detail-basis { margin: 2px 0 0; font-size: 0.78rem; color: var(--muted); font-style: italic; }
/* Note d'information « intervenant en texte libre » (formulaire de stage) — discrète. */
.stage-freeform-note { margin: -2px 0 2px; padding: 8px 10px; font-size: 0.8rem; line-height: 1.35; color: var(--muted); background: var(--surface-soft, var(--surface)); border: 1px solid var(--line); border-left: 3px solid var(--accent); border-radius: var(--radius-sm, 7px); }
/* Mention « facture émise = montant figé » (snapshot) — discrète, non alarmante. */
.invoice-frozen-note { margin: 8px 0 0; padding: 7px 10px; font-size: 0.8rem; line-height: 1.35; color: var(--muted); background: var(--surface-soft, var(--surface)); border: 1px solid var(--line); border-radius: var(--radius-sm, 7px); }
/* --- Vue d'ensemble (repliable, compacte, secondaire) --- */
.avail-overview-hint { font-size: 0.82rem; }
.avail-overview { padding: 12px 16px 16px; display: flex; flex-direction: column; gap: 12px; }
.avail-legend { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }
.avail-legend-item { display: inline-flex; align-items: center; gap: 6px; font-size: 0.82rem; color: var(--muted); font-weight: 600; }
.avail-swatch { width: 14px; height: 14px; border-radius: 4px; }
.avail-grid { display: grid; grid-template-columns: auto repeat(7, minmax(30px, 1fr)); gap: 4px; align-items: stretch; }
.avail-grid-head { text-align: center; font-weight: 800; font-size: 0.76rem; color: var(--muted); padding: 2px 0; align-self: center; }
.avail-grid-corner { min-width: 38px; }
.avail-grid-hour { font-size: 0.72rem; font-weight: 700; color: var(--muted); display: flex; align-items: center; justify-content: flex-end; padding-right: 8px; white-space: nowrap; }
.avail-cell {
  position: relative;
  border: 1px solid transparent; border-radius: var(--radius-sm, 7px);
  min-height: 24px; cursor: pointer;
  display: flex; align-items: center; justify-content: center; padding: 0;
  transition: transform 0.08s ease, box-shadow 0.12s ease, filter 0.12s ease;
}
.avail-cell:hover { transform: translateY(-1px); box-shadow: var(--shadow); filter: brightness(1.05); }
.avail-cell:focus-visible { outline: 2px solid var(--accent); outline-offset: 1px; }
.avail-cell-dot { width: 6px; height: 6px; border-radius: 999px; background: currentColor; opacity: 0.85; }
.avail-legend-dot .avail-cell-dot { color: var(--muted); }
/* 4 niveaux : vert / jaune / orange / rouge — bien plus saturés qu'avant, tokens du thème */
.avail-cell.lvl-free, .avail-swatch.lvl-free { background-color: color-mix(in srgb, var(--avail-good) 50%, var(--surface)) !important; background-image: none !important; border-color: color-mix(in srgb, var(--avail-good) 64%, var(--line)) !important; color: color-mix(in srgb, var(--avail-good) 42%, var(--ink)) !important; }
.avail-cell.lvl-some, .avail-swatch.lvl-some { background-color: color-mix(in srgb, var(--avail-mid) 54%, var(--surface)) !important; background-image: none !important; border-color: color-mix(in srgb, var(--avail-mid) 66%, var(--line)) !important; color: color-mix(in srgb, var(--avail-mid) 40%, var(--ink)) !important; }
.avail-cell.lvl-tight, .avail-swatch.lvl-tight { background-color: color-mix(in srgb, var(--avail-low) 52%, var(--surface)) !important; background-image: none !important; border-color: color-mix(in srgb, var(--avail-low) 64%, var(--line)) !important; color: color-mix(in srgb, var(--avail-low) 40%, var(--ink)) !important; }
.avail-cell.lvl-full, .avail-swatch.lvl-full { background-color: color-mix(in srgb, var(--avail-full) 48%, var(--surface)) !important; background-image: none !important; border-color: color-mix(in srgb, var(--avail-full) 62%, var(--line)) !important; color: color-mix(in srgb, var(--avail-full) 42%, var(--ink)) !important; }
.assistant-empty-cta-row { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; }
@media (max-width: 640px) {
  .avail-grid { grid-template-columns: auto repeat(7, minmax(24px, 1fr)); gap: 3px; }
  .avail-grid-head { font-size: 0.66rem; }
  .avail-result-day { min-width: 0; }
  .avail-reco-actions > * { flex: 1 1 auto; }
}
.dialog-member-list { margin: 0; padding-left: 18px; }
.attendance-table td select { width: 100%; }
/* Feuille d'appel : le tableau est un enfant direct du .form-grid (2 colonnes), il restait donc
   tassé sur la moitié gauche. On le fait occuper toute la largeur disponible, avec la colonne Note
   la plus large (Adhérent lisible, Statut raisonnable). */
.attendance-table {
  grid-column: 1 / -1;
  width: 100%;
  table-layout: fixed;
}
.attendance-table th:nth-child(1),
.attendance-table td:nth-child(1) { width: 30%; }
.attendance-table th:nth-child(2),
.attendance-table td:nth-child(2) { width: 22%; }
.attendance-table th:nth-child(3),
.attendance-table td:nth-child(3) { width: 48%; }
.attendance-table input,
.attendance-table select { width: 100%; min-width: 0; }
.form-check-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 8px; margin: 8px 0; }
.form-check { display: flex; align-items: center; gap: 8px; font-weight: 600; }
.form-check input { width: auto; }
/* Dossier sportif : .form-grid/.form-check ont un display explicite qui prime sur [hidden] ;
   ces règles garantissent que les champs parental/responsable légal disparaissent vraiment
   quand l'adhérent est majeur (bascule enfant/adulte au changement de contact). */
[data-dossier-guardian][hidden],
[data-dossier-parental][hidden],
[data-dossier-adult-note][hidden] { display: none; }
/* Lien inline (ex. « Tarifs ») : toujours un vrai lien souligné, jamais un bouton encadré,
   quel que soit le thème (sinon le mot se retrouve serré dans une boîte de 36px sans marge). */
.link-button {
  background: none !important;
  border: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  min-height: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  font: inherit;
  font-weight: 700;
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 2px;
  cursor: pointer;
  vertical-align: baseline;
}
.link-button:hover { opacity: 0.8; transform: none !important; border: 0 !important; }
/* Bloc recherche + filtres (pages Coachs & Salles) : marge intérieure alignée sur le
   titre du bandeau (16px), champs espacés, labels alignés — le contenu ne touche plus les bords. */
.coach-toolbar { display: flex; flex-wrap: wrap; align-items: center; gap: 12px 16px; margin: 12px 16px 14px; }
.coach-toolbar input[type="text"] { flex: 1 1 260px; min-width: 200px; max-width: 460px; width: auto; }
.coach-toolbar label { display: inline-flex; align-items: center; gap: 8px; white-space: nowrap; }
.coach-toolbar select { min-width: 150px; }
/* Grille de cartes des pages "annuaire" (Coachs/Salles) : même retrait latéral que le bloc filtres. */
.directory-grid { margin: 0 16px 16px; }
/* Listes de disponibilités/indisponibilités (coachs & salles) : pleine largeur dans la modale */
.dialog-body .form-grid > [data-coach-avail-list],
.dialog-body .form-grid > [data-coach-unav-list],
.dialog-body .form-grid > [data-room-avail-list],
.dialog-body .form-grid > [data-room-unav-list] { grid-column: 1 / -1; }
.dialog-body .form-grid > [data-action^="add-coach-"],
.dialog-body .form-grid > [data-action^="add-room-"] { grid-column: 1 / -1; justify-self: start; margin-top: 2px; }
/* Une ligne = jour/dates + horaires + motif + retrait, alignés horizontalement */
.coach-row { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; margin-bottom: 8px; }
.coach-row > select { flex: 1 1 150px; min-width: 130px; width: auto; }
.coach-row input[type="time"] { flex: 0 0 auto; width: 116px; min-width: 0; }
.coach-row-unav input[type="date"] { flex: 0 0 auto; width: 152px; min-width: 0; }
.coach-row-unav input[type="text"] { flex: 1 1 180px; min-width: 150px; width: auto; }
.coach-row > button.icon { flex: 0 0 auto; }
.course-line.course-replace, .planning-week-slot.course-replace { box-shadow: inset 3px 0 0 #d9822b; }
/* Checklist des coachs sélectionnés : panneau propre, intro sur sa ligne */
.newsletter-picker { display: flex; flex-wrap: wrap; gap: 8px 18px; margin: 6px 0 12px; padding: 10px 12px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface); max-height: 200px; overflow-y: auto; }
.newsletter-picker > .muted { flex: 0 0 100%; margin: 0 0 2px; }
.newsletter-picker .form-check { margin: 0; }
.newsletter-missing { margin-top: 10px; padding-top: 8px; border-top: 1px dashed var(--line); font-size: 0.85em; line-height: 1.45; }
/* Boutons e-mail (cartes + pieds de dialogue) : icônes en trait monochromes, alignées au texte */
button[data-action="email-coach"], button[data-action="email-room"] { display: inline-flex; align-items: center; gap: 6px; }
button[data-action="email-coach"] .tool-icon, button[data-action="email-room"] .tool-icon { width: 14px; height: 14px; flex: 0 0 auto; }
/* Sur les cartes : actions secondaires, plus légères que Modifier/Archiver, même rayon que le reste */
.card-email-actions { display: flex; flex-wrap: wrap; gap: 6px; margin: 12px 0 2px; }
.card-email-actions button { font-size: 0.78rem; padding: 5px 11px; line-height: 1.2; border-radius: var(--radius); border: 1px solid var(--line); background: transparent; color: var(--muted); cursor: pointer; }
.card-email-actions button:hover { color: var(--ink); border-color: var(--muted); }
.dash-block { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 12px; margin: 10px 16px 14px; }
.kpi-clickable { cursor: pointer; text-align: left; border: 1px solid var(--line, rgba(0,0,0,0.1)); font: inherit; transition: transform 0.08s ease, border-color 0.12s ease; }
.kpi-clickable:hover { border-color: var(--terra, #9a5148); transform: translateY(-1px); }

.tarifs-locked {
  display: flex;
  justify-content: center;
  padding: 48px 16px;
}
.tarifs-locked-card {
  max-width: 460px;
  text-align: center;
  padding: 32px 28px;
  border-radius: 14px;
}
.tarifs-locked-icon {
  font-size: 2.4rem;
  margin-bottom: 8px;
}
.tarifs-locked-card h2 {
  margin: 0 0 8px;
}
.tarifs-locked-card .primary {
  margin-top: 18px;
}

:root[data-theme="dark"] input[readonly],
:root[data-theme="dark"] .tariff-summary {
  background: #333a37;
}

:root[data-theme$="-dark"] input[readonly],
:root[data-theme$="-dark"] .tariff-summary {
  background: var(--surface-2);
}

.clickable-row {
  cursor: pointer;
}

.clickable-row:hover td {
  background: var(--surface-2);
}

/* Graphite: clickable lists should look sketched, not raised or glossy. */
:root[data-theme="graphite"] .membership-card,
:root[data-theme="graphite-dark"] .membership-card,
:root[data-theme="graphite"] .contact-line,
:root[data-theme="graphite-dark"] .contact-line,
:root[data-theme="graphite"] .registration-line,
:root[data-theme="graphite-dark"] .registration-line {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  border: 0;
  border-left: 4px solid var(--accent);
  border-radius: 14px 9px 16px 11px;
  background:
    repeating-linear-gradient(98deg, color-mix(in srgb, var(--ink) 3%, transparent) 0 1px, transparent 1px 13px),
    color-mix(in srgb, var(--surface) 92%, var(--surface-2) 8%);
  box-shadow: none !important;
  transform: rotate(-0.08deg);
}

:root[data-theme="graphite-dark"] .membership-card,
:root[data-theme="graphite-dark"] .contact-line,
:root[data-theme="graphite-dark"] .registration-line {
  background:
    repeating-linear-gradient(98deg, color-mix(in srgb, white 4%, transparent) 0 1px, transparent 1px 13px),
    color-mix(in srgb, var(--surface) 90%, var(--surface-2) 10%);
}

:root[data-theme="graphite"] .membership-card:nth-child(even),
:root[data-theme="graphite-dark"] .membership-card:nth-child(even) {
  border-radius: 11px 15px 10px 14px;
  transform: rotate(0.07deg);
}

:root[data-theme="graphite"] .membership-card::before,
:root[data-theme="graphite-dark"] .membership-card::before,
:root[data-theme="graphite"] .membership-card::after,
:root[data-theme="graphite-dark"] .membership-card::after {
  content: "";
  position: absolute;
  pointer-events: none;
  z-index: 0;
}

:root[data-theme="graphite"] .membership-card::before,
:root[data-theme="graphite-dark"] .membership-card::before {
  inset: 1px 2px 2px 1px;
  border: 2px solid color-mix(in srgb, var(--line-strong) 88%, transparent);
  border-left: 0;
  border-radius: 13px 8px 15px 10px;
  opacity: 0.92;
  transform: rotate(0.22deg);
}

:root[data-theme="graphite"] .membership-card::after,
:root[data-theme="graphite-dark"] .membership-card::after {
  inset: 4px 5px 5px 6px;
  border-top: 1px solid color-mix(in srgb, var(--line-strong) 54%, transparent);
  border-bottom: 1px solid color-mix(in srgb, var(--line-strong) 38%, transparent);
  border-radius: 10px 13px 9px 12px;
  opacity: 0.42;
  transform: rotate(-0.18deg);
}

:root[data-theme="graphite"] .membership-card > *,
:root[data-theme="graphite-dark"] .membership-card > * {
  position: relative;
  z-index: 1;
}

:root[data-theme="graphite"] .membership-card[data-action]:hover,
:root[data-theme="graphite-dark"] .membership-card[data-action]:hover,
:root[data-theme="graphite"] .contact-line:hover,
:root[data-theme="graphite-dark"] .contact-line:hover {
  background:
    repeating-linear-gradient(98deg, color-mix(in srgb, var(--ink) 4%, transparent) 0 1px, transparent 1px 13px),
    color-mix(in srgb, var(--surface-2) 72%, var(--accent) 5%);
  box-shadow: none !important;
  transform: rotate(-0.04deg);
}

:root[data-theme="graphite"] .membership-card.payment-paid,
:root[data-theme="graphite-dark"] .membership-card.payment-paid {
  border-left-color: #20a464;
}

:root[data-theme="graphite"] .membership-card.payment-pending,
:root[data-theme="graphite-dark"] .membership-card.payment-pending {
  border-left-color: #f2a321;
}

:root[data-theme="graphite"] .membership-card.payment-due,
:root[data-theme="graphite-dark"] .membership-card.payment-due {
  border-left-color: #d8483e;
}

:root[data-theme="graphite"] .membership-card.payment-paid::before,
:root[data-theme="graphite-dark"] .membership-card.payment-paid::before {
  box-shadow: inset 4px 0 0 color-mix(in srgb, #20a464 72%, transparent);
}

:root[data-theme="graphite"] .membership-card.payment-pending::before,
:root[data-theme="graphite-dark"] .membership-card.payment-pending::before {
  box-shadow: inset 4px 0 0 color-mix(in srgb, #f2a321 76%, transparent);
}

:root[data-theme="graphite"] .membership-card.payment-due::before,
:root[data-theme="graphite-dark"] .membership-card.payment-due::before {
  box-shadow: inset 4px 0 0 color-mix(in srgb, #d8483e 76%, transparent);
}

:root[data-theme="graphite"] .clickable-row td,
:root[data-theme="graphite-dark"] .clickable-row td {
  background:
    repeating-linear-gradient(98deg, color-mix(in srgb, var(--ink) 3%, transparent) 0 1px, transparent 1px 13px),
    color-mix(in srgb, var(--surface) 92%, var(--surface-2) 8%);
  box-shadow: none !important;
}

:root[data-theme="graphite"] .clickable-row:hover td,
:root[data-theme="graphite-dark"] .clickable-row:hover td {
  background:
    repeating-linear-gradient(98deg, color-mix(in srgb, var(--ink) 4%, transparent) 0 1px, transparent 1px 13px),
    color-mix(in srgb, var(--surface-2) 72%, var(--accent) 5%);
}

:root[data-theme="graphite"] .clickable-row td:first-child,
:root[data-theme="graphite-dark"] .clickable-row td:first-child {
  border-left: 4px solid var(--accent);
}

:root[data-theme="graphite"] .discipline-binder .collapsible-title-row,
:root[data-theme="graphite-dark"] .discipline-binder .collapsible-title-row,
:root[data-theme="graphite"] .overview-band .collapsible-title-row,
:root[data-theme="graphite-dark"] .overview-band .collapsible-title-row {
  border: 0;
  border-radius: 14px 9px 15px 10px;
  background:
    repeating-linear-gradient(101deg, color-mix(in srgb, var(--ink) 4%, transparent) 0 1px, transparent 1px 12px),
    color-mix(in srgb, var(--surface) 88%, var(--surface-2) 12%);
  box-shadow:
    inset 0 0 0 2px color-mix(in srgb, var(--line-strong) 78%, transparent),
    inset 3px 1px 0 color-mix(in srgb, var(--line) 52%, transparent);
  transform: rotate(-0.06deg);
}

:root[data-theme="graphite"] .discipline-binder .collapsible-title-row:hover,
:root[data-theme="graphite-dark"] .discipline-binder .collapsible-title-row:hover,
:root[data-theme="graphite"] .overview-band .collapsible-title-row:hover,
:root[data-theme="graphite-dark"] .overview-band .collapsible-title-row:hover {
  background:
    repeating-linear-gradient(101deg, color-mix(in srgb, var(--ink) 5%, transparent) 0 1px, transparent 1px 12px),
    color-mix(in srgb, var(--surface-2) 76%, var(--accent) 6%);
}

.task-row.task-late td {
  border-left: 4px solid var(--danger);
}

.task-row.task-due td {
  border-left: 4px solid var(--accent-2);
}

.task-row.task-wait td {
  border-left: 4px solid var(--accent-3);
}

.task-row.task-ok td {
  border-left: 4px solid var(--success);
}

.search-page-form {
  padding: 16px;
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto;
  gap: 10px;
  border-bottom: 1px solid var(--line);
}

.search-page-form input {
  min-height: 40px;
  padding: 0 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface-2);
  color: var(--ink);
  font-weight: 800;
}

[data-search-results] {
  padding: 16px;
}

[data-search-results] > .muted:first-child {
  margin-top: 0;
}

[data-search-results] > :last-child {
  margin-bottom: 0;
}

.reminder-dialog textarea {
  min-height: 180px;
  resize: vertical;
}

.contact-dialog-actions {
  display: flex;
  justify-content: flex-start;
  padding-top: 6px;
}

.column-resizer {
  position: absolute;
  top: 0;
  right: -3px;
  width: 8px;
  height: 100%;
  cursor: col-resize;
  z-index: 2;
}

.column-resizer::after {
  content: "";
  position: absolute;
  top: 8px;
  right: 3px;
  width: 1px;
  height: calc(100% - 16px);
  background: var(--line-strong);
  opacity: 0.55;
}

.contact-card {
  display: grid;
  gap: 18px;
}

.contact-card-head {
  display: flex;
  align-items: center;
  gap: 12px;
}

.contact-card-photo {
  width: 58px;
  height: 74px;
  padding: 0;
  border: 2px solid var(--surface);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.2);
}

.contact-card-photo img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.contact-card-photo.default-avatar img,
.identity-photo-frame.default-avatar img {
  object-fit: contain;
  padding: 4px;
  background: transparent;
}

.contact-card-photo.default-avatar,
.identity-photo-frame.default-avatar {
  background:
    radial-gradient(circle at 50% 38%, color-mix(in srgb, var(--surface) 92%, transparent), transparent 62%),
    color-mix(in srgb, var(--surface-2) 80%, var(--surface) 20%);
}

.contact-documents {
  grid-column: 1 / -1;
}

.contact-doc-list {
  display: grid;
  gap: 7px;
  margin-bottom: 10px;
}

.contact-doc-list a {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 9px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface-2);
  color: var(--ink);
  font-weight: 800;
}

.contact-doc-list span {
  color: var(--muted);
  font-size: .82rem;
}

.contact-card dl {
  display: grid;
  gap: 10px;
  margin: 0;
}

.contact-card dl div {
  display: grid;
  grid-template-columns: 120px minmax(0, 1fr);
  gap: 10px;
}

.contact-card dt {
  color: var(--muted);
  font-weight: 750;
}

.contact-card dd {
  margin: 0;
}

.contact-action-link {
  width: fit-content;
  max-width: 100%;
  min-height: 34px;
  padding: 6px 10px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface-2);
  color: var(--ink);
  text-decoration: none;
  font-weight: 800;
}

.contact-action-link span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.contact-action-link strong {
  padding: 3px 7px;
  border-radius: 999px;
  background: var(--accent);
  color: var(--on-accent);
  font-size: 0.72rem;
  white-space: nowrap;
}

.contact-action-link:hover {
  border-color: var(--accent);
  transform: translateY(-1px);
}

.settings-panel {
  align-content: start;
}

.settings-panel h2 {
  margin: 0 0 10px;
}

.display-settings-panel {
  grid-column: 1 / -1;
}

.settings-check-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
  margin-top: 14px;
}

/* Menus affichés par mode (Paramètres > Affichage) : catégories. */
.display-modules-groups {
  display: grid;
  gap: 14px;
  margin-top: 10px;
}

.display-modules-group h5 {
  margin: 0 0 2px;
  font-size: 0.82rem;
  font-weight: 800;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.display-modules-group .settings-check-grid {
  margin-top: 6px;
}

.settings-check {
  display: grid;
  grid-template-columns: 20px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface-2);
}

.settings-check input {
  width: 18px;
  height: 18px;
  margin-top: 1px;
  accent-color: var(--accent);
}

.settings-check span {
  display: grid;
  gap: 3px;
}

.settings-check small {
  color: var(--muted);
  font-size: 0.78rem;
  line-height: 1.25;
}

.layout-mode-select { display: grid; gap: 6px; margin-bottom: 10px; }
.layout-mode-select span { display: grid; gap: 3px; }
.layout-mode-select small {
  color: var(--muted);
  font-size: 0.78rem;
  line-height: 1.25;
}
.layout-mode-select select { justify-self: start; min-width: 220px; }

.settings-logo-preview {
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
}

.settings-logo-preview img {
  width: 96px;
  height: 96px;
  object-fit: contain;
  border-radius: 0;
  background: transparent;
  padding: 0;
  box-shadow: none;
}

.stock-total-field small {
  display: block;
  margin-top: 5px;
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 600;
  line-height: 1.25;
}

.stock-total-field input[readonly],
.stock-total-field input.readonly {
  border-color: color-mix(in srgb, var(--accent) 24%, var(--line));
  background: color-mix(in srgb, var(--surface-2) 82%, var(--accent) 5%);
  color: var(--muted);
  cursor: not-allowed;
}

.inline-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-top: 12px;
}

.button-like {
  min-height: 36px;
  padding: 8px 12px;
  display: inline-grid;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface-2);
  color: var(--ink);
  font-size: 0.92rem;
  font-weight: 800;
  cursor: pointer;
}

.button-like:hover {
  border-color: var(--accent);
  transform: translateY(-1px);
}

.button-like.primary-link {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--on-accent);
}

.email-template-settings {
  grid-column: 1 / -1;
}

.email-template-list {
  display: grid;
  gap: 14px;
}

.email-template-card {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface-2) 70%, transparent);
}

.email-template-toolbar {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto;
  gap: 12px;
  align-items: end;
}

.email-template-toolbar label {
  min-width: 0;
}

.email-template-toolbar .inline-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.email-template-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: start;
}

.email-template-head strong {
  display: block;
  font-size: 1rem;
}

.email-template-head span,
.email-template-head small {
  color: var(--muted);
  font-size: 0.88rem;
}

.email-template-card textarea {
  min-height: 150px;
  resize: vertical;
}

.email-template-card .email-custom-variables textarea {
  min-height: 76px;
}

.email-template-card input[readonly],
.email-template-card textarea[readonly] {
  opacity: 0.82;
  cursor: default;
}

.email-mode-hint {
  display: flex;
  align-items: center;
  gap: 11px;
  margin: 12px 0 4px;
  padding: 12px 15px;
  border-radius: var(--radius-sm);
  font-size: 0.94rem;
  font-weight: 700;
  line-height: 1.45;
}

.email-mode-hint .email-mode-ico {
  font-size: 1.35rem;
  flex: none;
}

.email-mode-hint.locked {
  background: color-mix(in srgb, var(--accent-3) 16%, var(--surface));
  border: 2px solid color-mix(in srgb, var(--accent-3) 55%, var(--line));
  color: var(--ink);
}

.email-mode-hint.editing {
  background: color-mix(in srgb, var(--success) 14%, var(--surface));
  border: 2px solid color-mix(in srgb, var(--success) 50%, var(--line));
  color: var(--ink);
}

.email-model-legend {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.email-model-legend > div,
.email-model-help {
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  padding: 10px;
  background: var(--surface-2);
}

.email-model-legend .automatic {
  border-color: color-mix(in srgb, var(--accent-4) 38%, var(--line));
  background: color-mix(in srgb, var(--accent-4) 10%, var(--surface-2));
}

.email-model-legend span,
.email-model-help p {
  display: block;
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 0.84rem;
}

.email-custom-variables {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid color-mix(in srgb, var(--accent) 28%, var(--line));
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--accent) 6%, var(--surface-2));
}

.email-custom-variables.muted-panel {
  border-color: var(--line);
  background: var(--surface-2);
}

.email-custom-variables.muted-panel p {
  margin: 4px 0 0;
}

.email-custom-variable-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 10px;
}

.email-custom-variable-grid label {
  display: grid;
  gap: 5px;
}

.email-custom-variable-grid small {
  color: var(--muted);
  font-weight: 750;
}

.email-custom-variable-grid label > span {
  color: var(--muted);
  font-size: 0.8rem;
  line-height: 1.3;
}

@media (max-width: 760px) {
  .email-template-toolbar,
  .email-template-head,
  .email-model-legend {
    grid-template-columns: 1fr;
  }

  .email-template-toolbar .inline-actions {
    justify-content: flex-start;
  }
}

.required-star {
  color: var(--accent-2);
  font-weight: 900;
}

.form-warning {
  padding: 9px 11px;
  border: 1px solid color-mix(in srgb, var(--accent-3) 42%, var(--line));
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--accent-3) 12%, var(--surface));
  color: var(--ink);
  font-weight: 750;
}

.dialog-alert-list {
  display: grid;
  gap: 8px;
}

.payment-overpay-warning {
  margin-top: 8px;
  padding: 9px 11px;
  border: 1px solid color-mix(in srgb, var(--danger, #c0392b) 45%, var(--line));
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--danger, #c0392b) 12%, var(--surface));
  color: var(--ink);
  font-weight: 750;
  font-size: 0.85rem;
}

.payment-overpay-warning[hidden] {
  display: none;
}

.address-city-choice {
  position: absolute;
  z-index: 10000;
  min-height: 34px;
  font-size: 0.86rem;
  box-shadow: var(--shadow);
}

.typography-preview {
  margin-top: 14px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface-2);
}

.postit-style-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 12px;
}

.postit-style-card {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 10px;
  background: transparent;
}

.postit-style-card .task-postit {
  background: transparent;
}

.stock-alert-inline {
  width: 82px;
  min-width: 0;
}

.history-row {
  cursor: pointer;
}

.history-action-text {
  max-width: 520px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.history-row.expanded .history-action-text {
  white-space: normal;
  overflow: visible;
}

.email-variable-title {
  display: grid;
  gap: 3px;
  margin-bottom: 8px;
}

.email-variable-title span {
  color: var(--muted);
  font-size: 0.84rem;
}

.email-variable-group {
  display: grid;
  gap: 6px;
  margin-top: 10px;
}

.email-variable-group > strong {
  font-size: 0.86rem;
}

.email-variable-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.email-variable-grid span {
  display: inline-flex;
  gap: 6px;
  align-items: center;
  padding: 5px 8px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-2);
  color: var(--muted);
  font-size: 0.82rem;
}

.email-variable-grid strong {
  color: var(--text);
}

.email-variable-chip {
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s, transform 0.05s;
  user-select: none;
}

.email-variable-chip:hover {
  border-color: var(--accent);
  background: var(--surface-3);
}

.email-variable-chip:active {
  transform: scale(0.96);
}

small.email-variable-chip {
  display: inline-block;
  padding: 1px 7px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-2);
  font-family: var(--font-mono, monospace);
}

small.email-variable-chip:hover {
  border-color: var(--accent);
  background: var(--surface-3);
}

.settings-stack {
  display: grid;
  gap: 12px;
}

.settings-collapsible-band .collapsible-inner {
  padding: 16px;
}

.newsletter-page {
  display: grid;
  gap: 22px;
}

.newsletter-page .kpi-grid {
  margin-bottom: 2px;
}

.newsletter-page .grid.two {
  align-items: start;
}

.newsletter-composer,
.newsletter-recipients-panel {
  display: grid;
  gap: 12px;
}

.newsletter-composer textarea {
  min-height: 260px;
  resize: vertical;
}

.newsletter-variable-fields {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--line));
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface-2) 66%, var(--surface));
}

.newsletter-variable-fields textarea {
  min-height: 110px;
}

.newsletter-add-email {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: end;
}

.newsletter-paper {
  display: grid;
  gap: 10px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface-2);
}

.newsletter-paper span {
  color: var(--muted);
  font-size: 0.86rem;
}

.newsletter-paper strong {
  font-size: 1.04rem;
}

.newsletter-paper p {
  margin: 0;
  line-height: 1.45;
}

.newsletter-model-row {
  display: flex;
  align-items: flex-end;
  gap: 10px;
}

.newsletter-model-edit-btn {
  white-space: nowrap;
  flex-shrink: 0;
  margin-bottom: 0;
}

.newsletter-model-note {
  margin-top: 4px;
  font-size: 0.86rem;
}

.newsletter-preview-readonly {
  display: grid;
  gap: 10px;
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface-2);
}

.newsletter-preview-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  font-size: 0.86rem;
  color: var(--muted);
}

.newsletter-preview-subject {
  font-weight: 600;
  font-size: 1.02rem;
  color: var(--text);
}

.newsletter-preview-body {
  color: var(--text);
  font-size: 0.94rem;
  line-height: 1.55;
  white-space: pre-wrap;
  max-height: 260px;
  overflow: auto;
}

.newsletter-recipient-list {
  display: grid;
  gap: 8px;
  max-height: 560px;
  overflow: auto;
  padding-right: 4px;
}

.newsletter-recipient-list div {
  position: relative;
  display: grid;
  gap: 2px;
  padding: 10px 42px 10px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface-2);
}

.newsletter-recipient-list div.is-extra {
  border-color: color-mix(in srgb, var(--accent) 35%, var(--line));
}

.newsletter-recipient-list button {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
}

.newsletter-recipient-list span {
  color: var(--muted);
  font-size: 0.88rem;
}

/* ===== Filtres d'affichage de la page « À faire » ===== */
.task-filters { margin: 0 16px 12px; }
.task-filters-head { display: flex; flex-wrap: wrap; align-items: center; gap: 8px 12px; }
.task-filters-toggle {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 12px; border-radius: 999px;
  border: 1px solid var(--line, rgba(0,0,0,0.15)); background: var(--surface, transparent); color: inherit; cursor: pointer;
  font-weight: 600;
}
.task-filters-toggle:hover { background: color-mix(in srgb, var(--ink, #222) 8%, transparent); }
.task-filters-summary { font-size: 0.85rem; }
.task-filters-body { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
.task-filter-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px; border-radius: 999px; cursor: pointer;
  border: 1px solid var(--line, rgba(0,0,0,0.18)); background: transparent; color: inherit;
  font-size: 0.85rem;
}
.task-filter-chip.on { background: color-mix(in srgb, var(--accent, #4d5966) 14%, transparent); border-color: color-mix(in srgb, var(--accent, #4d5966) 32%, transparent); }
.task-filter-chip.off { opacity: 0.6; }
.task-filter-chip .tf-box { font-size: 0.95rem; line-height: 1; }
.task-filter-chip .tf-count { font-size: 0.74rem; opacity: 0.75; }
.task-filter-all {
  padding: 4px 12px; border-radius: 999px; cursor: pointer;
  border: 1px dashed var(--line, rgba(0,0,0,0.25)); background: transparent; color: inherit; font-size: 0.85rem;
}
.task-filter-all:disabled { opacity: 0.4; cursor: default; }
.link-like { background: none; border: 0; padding: 0; color: var(--accent, #3b6); cursor: pointer; text-decoration: underline; font: inherit; }
@media (max-width: 560px) {
  .task-filters-head { flex-direction: column; align-items: flex-start; gap: 4px; }
}
/* Post-it « Dossier incomplet » groupé : hauteur AUTO (bornée par le contenu, max 3 lignes + « +N »)
   pour ne jamais déborder ni couper le texte ; le fond suit la hauteur sans casser le visuel. */
.task-postit-grouped {
  aspect-ratio: auto;
  min-height: 184px;
}
.task-doc-body {
  display: grid;
  gap: 2px;
  min-width: 0;
}
.task-doc-count {
  font-weight: 800;
  font-size: 0.74rem;
}
/* Résumé compact des types de documents : UNE seule ligne, jamais de débordement
   sur le bouton « Voir le détail » (le détail complet reste dans la popup). */
.task-doc-summary {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 0.68rem;
  line-height: 1.25;
  opacity: 0.82;
}

/* Popup « Voir le détail » du dossier. */
.dossier-doc-list { list-style: none; margin: 8px 0 0; padding: 0; display: grid; gap: 8px; }
.dossier-doc-item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface-2);
}
.dossier-doc-rank { color: var(--muted); font-weight: 800; }
.dossier-doc-text { min-width: 0; }

.task-postit-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 210px), 240px));
  gap: 14px;
  justify-content: center;
  align-items: start;
  padding: 8px;
}

.task-postit {
  --postit-filter: none;
  --postit-color: #fff4a8;
  --postit-image: url("./assets/postits/postit-alert.png");
  position: relative;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr) auto;
  gap: 4px;
  aspect-ratio: 70 / 71;
  min-height: 0;
  width: 100%;
  max-width: 240px;
  padding: 64px 28px 42px 42px;
  border: 0;
  border-radius: 14px 18px 38px 14px;
  background: transparent;
  color: #2f2710;
  box-shadow: none;
  transform: rotate(-0.6deg);
  align-content: stretch;
  overflow: hidden;
  isolation: isolate;
  font-size: clamp(0.68rem, 0.63rem + 0.16vw, 0.78rem);
}

/* .task-postit a un display: grid explicite qui prime sur le display:none par défaut de [hidden] :
   sans cette règle, un post-it filtré (recherche À faire) resterait visible. */
.task-postit[hidden] {
  display: none;
}

/* Champ de recherche de la page À faire : un peu de marge horizontale pour ne pas coller au bord
   du panneau (classe dédiée → n'affecte pas les barres de recherche des dialogues). */
.task-search {
  margin-left: 8px;
  margin-right: 8px;
}

.task-postit::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  background: var(--postit-image) center / 100% 100% no-repeat;
  filter: var(--postit-filter);
  transform: translateZ(0);
  pointer-events: none;
}

.task-postit::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: var(--postit-color);
  -webkit-mask: var(--postit-image) center / 100% 100% no-repeat;
  mask: var(--postit-image) center / 100% 100% no-repeat;
  mix-blend-mode: multiply;
  opacity: 0.62;
  pointer-events: none;
}

.task-postit:nth-child(2n) {
  transform: rotate(0.7deg);
}

.task-postit.task-late { color: #4b1610; }
.task-postit.task-wait,
.task-postit.task-certificate,
.task-postit.task-insurance,
.task-postit.task-stock { color: #3d2408; }
.task-postit.task-ok,
.task-postit.task-birthday { color: #163916; }
.task-postit.task-due { color: #0c2d48; }

.task-postit-actions {
  display: flex;
  flex-wrap: wrap;
  align-self: end;
  gap: 5px;
  margin-top: 0;
  max-width: 100%;
}

.task-postit.mini-preview {
  min-height: 180px;
  padding: 48px 28px 34px 34px;
  transform: none;
}

.task-postit-pin {
  display: none;
}

.task-postit strong {
  display: -webkit-box;
  overflow: hidden;
  font-size: 1em;
  line-height: 1.12;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.task-postit p {
  margin: 0;
  display: -webkit-box;
  overflow: hidden;
  line-height: 1.18;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.task-postit button {
  justify-self: start;
  min-height: 0;
  padding: 4px 8px;
  font-size: 0.9em;
  line-height: 1.1;
  background: rgba(255, 255, 255, 0.62);
  color: inherit;
  border-color: rgba(0, 0, 0, 0.12);
}

.task-postit .status {
  width: fit-content;
  max-width: 100%;
  overflow: hidden;
  padding: 3px 7px;
  font-size: 0.72em;
  line-height: 1.05;
  text-overflow: ellipsis;
  white-space: nowrap;
  background: rgba(255, 255, 255, 0.58);
  color: inherit;
  border-color: rgba(0, 0, 0, 0.12);
}

.contact-doc-list {
  display: grid;
  gap: 8px;
}

.contact-doc-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 8px;
  align-items: center;
}

.contact-document-viewer {
  display: grid;
  gap: 12px;
}

.contact-document-frame {
  width: 100%;
  height: min(68vh, 720px);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface-2);
}

.contact-document-image {
  max-width: 100%;
  max-height: min(68vh, 720px);
  margin: 0 auto;
  display: block;
  object-fit: contain;
  border-radius: var(--radius);
  background: var(--surface-2);
}

.license-banner {
  margin: -4px 0 14px;
  padding: 9px 12px;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  border: 1px solid color-mix(in srgb, var(--accent) 38%, var(--line));
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--accent) 10%, var(--surface));
  font-weight: 850;
}

.license-banner.danger {
  border-color: color-mix(in srgb, var(--danger) 45%, var(--line));
  background: color-mix(in srgb, var(--danger) 12%, var(--surface));
}

.license-panel {
  width: 100%;
}

.license-panel.blocking {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 30px;
  background: var(--bg);
}

.license-card {
  width: min(520px, 100%);
  padding: 22px;
  display: grid;
  gap: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--shadow);
}

.license-card img {
  width: 110px;
  height: 110px;
  object-fit: contain;
  justify-self: center;
  border-radius: 22px;
  background: #101010;
  padding: 8px;
}

.license-card h2 {
  margin: 0;
  text-align: center;
}

.password-gate {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 30px;
  background:
    radial-gradient(circle at 18% 18%, color-mix(in srgb, var(--accent) 15%, transparent), transparent 32%),
    var(--bg);
}

.welcome-card {
  width: min(580px, 100%);
  padding: 28px;
  display: grid;
  gap: 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--shadow);
}

.welcome-card img {
  width: 90px;
  height: 90px;
  object-fit: contain;
  justify-self: center;
  border-radius: 20px;
  background: #101010;
  padding: 8px;
}

.welcome-card h2 {
  margin: 0;
  text-align: center;
}

.welcome-choice-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.welcome-choice {
  display: grid;
  gap: 7px;
  padding: 18px 14px;
  border: 2px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface-2);
  text-align: left;
  cursor: pointer;
  font-family: var(--font-button);
  transition: border-color 0.15s, background 0.15s;
}

.welcome-choice:hover,
.welcome-choice:focus-visible {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 8%, var(--surface-2));
}

.welcome-choice.welcome-choice-primary {
  border-color: color-mix(in srgb, var(--accent) 60%, var(--line));
  background: color-mix(in srgb, var(--accent) 9%, var(--surface-2));
}

.welcome-choice strong {
  font-size: 1rem;
  font-weight: 900;
  color: var(--ink);
}

.welcome-choice span {
  font-size: .85rem;
  color: var(--muted);
  font-weight: normal;
  line-height: 1.4;
}

@media (max-width: 500px) {
  .welcome-choice-grid {
    grid-template-columns: 1fr;
  }
}

.password-card label {
  display: grid;
  gap: 7px;
  font-weight: 850;
}

.password-card input {
  width: 100%;
}

.form-error {
  padding: 10px 12px;
  border: 1px solid color-mix(in srgb, var(--danger) 50%, var(--line));
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--danger) 12%, var(--surface));
  color: var(--danger);
  font-weight: 850;
}

.security-settings-panel {
  align-content: start;
}

.security-status {
  display: grid;
  gap: 4px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface-2);
}

.security-status.ok {
  border-color: color-mix(in srgb, var(--success) 38%, var(--line));
  background: color-mix(in srgb, var(--success) 11%, var(--surface));
}

.security-status.due {
  border-color: color-mix(in srgb, var(--accent-3) 42%, var(--line));
  background: color-mix(in srgb, var(--accent-3) 12%, var(--surface));
}

.security-status span {
  color: var(--muted);
  font-size: .88rem;
}

/* Code de récupération (Phase 1) : affichage unique du code + avertissement. */
.security-recovery {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.recovery-code-box {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin: 10px 0;
  padding: 12px 14px;
  border: 1px dashed color-mix(in srgb, var(--accent) 45%, var(--line));
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--accent) 8%, var(--surface));
}

.recovery-code-label {
  flex: 1 1 100%;
  font-size: .74rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--muted);
}

.recovery-code-value {
  flex: 1 1 auto;
  font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  font-size: 1.15rem;
  font-weight: 800;
  letter-spacing: .12em;
  user-select: all;
  word-break: break-all;
  color: var(--ink);
}

.recovery-code-copy {
  flex: 0 0 auto;
  min-height: 30px;
  padding: 2px 12px;
  border-radius: 999px;
}

.recovery-code-warn {
  font-size: .86rem;
  line-height: 1.4;
}

.recovery-card {
  text-align: left;
}

.recovery-backup-tip {
  font-size: .82rem;
}

.password-forgot {
  margin-top: 2px;
  font-size: .86rem;
}

.license-status-grid {
  display: grid;
  grid-template-columns: minmax(130px, max-content) minmax(0, 1fr);
  gap: 8px 12px;
  padding: 12px;
  border-radius: var(--radius-sm);
  background: var(--surface-2);
}

.license-status-grid span {
  color: var(--muted);
  font-weight: 800;
}

.license-status-grid strong {
  overflow-wrap: anywhere;
}

.license-badge {
  padding: 8px 14px;
  border-radius: var(--radius);
  font-weight: 900;
  text-align: center;
  font-size: .95rem;
}

.license-badge.ok {
  background: color-mix(in srgb, var(--success) 14%, var(--surface-2));
  color: color-mix(in srgb, var(--success) 80%, var(--ink));
  border: 1px solid color-mix(in srgb, var(--success) 38%, var(--line));
}

.license-badge.trial {
  background: color-mix(in srgb, var(--accent) 10%, var(--surface-2));
  color: var(--ink);
  border: 1px solid color-mix(in srgb, var(--accent) 28%, var(--line));
}

.license-badge.expired {
  background: color-mix(in srgb, var(--danger) 12%, var(--surface-2));
  color: var(--danger);
  border: 1px solid color-mix(in srgb, var(--danger) 38%, var(--line));
}

.license-steps {
  display: grid;
  gap: 6px;
}

.license-steps span {
  padding: 8px 12px;
  border-radius: var(--radius);
  background: var(--surface-2);
  font-size: .9rem;
  color: var(--muted);
  font-weight: 700;
}

.license-machine-id-row {
  display: flex;
  gap: 8px;
  align-items: center;
  padding: 10px 12px;
  border-radius: var(--radius);
  background: var(--surface-2);
  border: 1px solid var(--line);
}

.license-machine-id-row code {
  flex: 1;
  font-family: ui-monospace, "Cascadia Code", "Source Code Pro", monospace;
  font-size: .9rem;
  letter-spacing: .06em;
  overflow-wrap: anywhere;
}

.license-machine-id-row button {
  flex-shrink: 0;
  padding: 5px 11px;
  font-size: .85rem;
}

.danger-text {
  color: var(--danger);
  font-weight: 850;
}

.settings-themes {
  display: grid;
  grid-template-columns: repeat(4, minmax(150px, 1fr));
  gap: 12px;
}

.reset-scope-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(160px, 1fr));
  gap: 10px;
}

.settings-reset-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 12px;
}

.settings-reset-grid button {
  min-height: 38px;
  padding-inline: 10px;
  white-space: normal;
}

/* Vidage par module : groupes thématiques. */
.reset-scope-group {
  margin-top: 14px;
}

.reset-scope-group > h4 {
  margin: 0 0 2px;
  font-size: 0.86rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.reset-scope-group .settings-reset-grid {
  margin-top: 6px;
}

.theme-studio {
  grid-column: 1 / -1;
  overflow: hidden;
}

.theme-studio-head {
  padding: 18px;
  border-bottom: 1px solid var(--line);
  display: flex;
  gap: 14px;
  align-items: center;
  justify-content: space-between;
  background: color-mix(in srgb, var(--surface-2) 70%, var(--surface));
}

.theme-studio-head div {
  display: grid;
  gap: 4px;
}

.theme-studio-head span {
  color: var(--accent);
  font-size: 0.76rem;
  font-weight: 900;
  text-transform: uppercase;
}

.theme-studio-head h2,
.theme-color-section h3 {
  margin: 0;
}

.theme-studio-head p {
  margin: 0;
  color: var(--muted);
}

.theme-editor-help {
  padding: 12px;
  display: grid;
  gap: 5px;
  border: 1px solid color-mix(in srgb, var(--accent) 34%, var(--line));
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--accent) 9%, var(--surface));
}

.theme-editor-help strong {
  color: var(--accent);
}

.theme-editor-help span {
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 750;
}

.theme-studio-body {
  display: grid;
  grid-template-columns: minmax(420px, 1.25fr) minmax(280px, 0.75fr);
  gap: 0;
  min-height: 560px;
}

.theme-interface-preview {
  min-height: 560px;
  display: grid;
  grid-template-columns: 162px minmax(0, 1fr);
  border-right: 1px solid var(--line);
  background:
    radial-gradient(circle at 18% 18%, color-mix(in srgb, var(--accent) 16%, transparent), transparent 220px),
    linear-gradient(145deg, var(--bg), color-mix(in srgb, var(--surface-2) 55%, var(--bg)));
}

.preview-sidebar {
  padding: 14px;
  display: grid;
  align-content: start;
  gap: 8px;
  border-right: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 74%, var(--surface-2));
}

.preview-brand {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  margin-bottom: 8px;
}

.preview-brand img {
  width: 34px;
  height: 34px;
  object-fit: contain;
}

.preview-brand strong,
.preview-brand span {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.preview-brand span,
.preview-row small,
.preview-kpis span,
.preview-dialog label {
  color: var(--muted);
  font-size: 0.72rem;
}

.preview-sidebar > span {
  padding: 8px 10px;
  border: 1px solid transparent;
  border-radius: calc(var(--radius) - 2px);
  color: var(--ink);
  font-size: 0.78rem;
  font-weight: 850;
}

.preview-sidebar > span.active {
  border-color: color-mix(in srgb, var(--accent) 48%, var(--line));
  background: color-mix(in srgb, var(--accent) 13%, var(--surface-2));
  color: var(--accent);
}

.preview-main {
  min-width: 0;
  display: grid;
  grid-template-rows: auto 1fr;
}

.preview-topbar {
  padding: 12px 14px;
  border-bottom: 1px solid var(--line);
  display: flex;
  gap: 12px;
  align-items: center;
  justify-content: space-between;
  background: color-mix(in srgb, var(--surface) 86%, transparent);
}

.preview-topbar div,
.preview-actions {
  display: flex;
  gap: 7px;
}

.preview-topbar button,
.preview-actions button {
  min-height: 28px;
  padding: 5px 9px;
  font-size: 0.72rem;
}

.preview-content {
  padding: 14px;
  display: grid;
  gap: 12px;
  align-content: start;
}

.preview-kpis {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.preview-kpis div,
.preview-band,
.preview-dialog {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow: 0 12px 28px color-mix(in srgb, var(--ink) 8%, transparent);
}

.preview-kpis div {
  min-width: 0;
  padding: 10px;
  display: grid;
  gap: 4px;
}

.preview-kpis strong {
  font-size: 0.98rem;
  white-space: nowrap;
}

.preview-band {
  overflow: hidden;
}

.preview-band-title,
.preview-dialog-head {
  padding: 10px 12px;
  border-bottom: 1px solid var(--line);
  display: flex;
  justify-content: space-between;
  gap: 10px;
  background: var(--surface-2);
}

.preview-band-title span,
.preview-dialog-head span {
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 850;
}

.preview-row {
  display: grid;
  grid-template-columns: 10px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 9px 12px;
  border-top: 1px solid color-mix(in srgb, var(--line) 62%, transparent);
}

.preview-row:first-of-type {
  border-top: 0;
}

.preview-row div {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.preview-row strong,
.preview-row small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.preview-row em {
  padding: 3px 7px;
  border-radius: 999px;
  background: var(--surface-2);
  color: var(--muted);
  font-size: 0.68rem;
  font-style: normal;
  font-weight: 850;
}

.preview-dot {
  width: 9px;
  height: 34px;
  border-radius: 999px;
}

.preview-dot.ok {
  background: var(--accent);
}

.preview-dot.wait {
  background: var(--accent-3);
}

.preview-dot.due {
  background: var(--accent-2);
}

.preview-dialog {
  width: min(100%, 330px);
  justify-self: end;
  overflow: hidden;
}

.preview-dialog label {
  padding: 12px;
  display: grid;
  gap: 5px;
  font-weight: 800;
}

.preview-dialog input {
  height: 32px;
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) - 2px);
  background: var(--surface);
  color: var(--ink);
}

.preview-color-map {
  padding: 10px;
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
}

.preview-color-map > strong {
  font-size: 0.82rem;
}

.preview-color-map > div {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(96px, 1fr));
  gap: 7px;
}

.preview-color-token {
  min-width: 0;
  padding: 6px;
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr);
  gap: 6px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: var(--surface);
}

.preview-color-token i {
  width: 22px;
  height: 22px;
  border: 1px solid var(--line-strong);
  border-radius: 6px;
  background: var(--token-color);
}

.preview-color-token small {
  overflow: hidden;
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 850;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.preview-actions {
  justify-content: flex-end;
  padding: 0 12px 12px;
}

.theme-editor-panel {
  padding: 16px;
  display: grid;
  gap: 14px;
  align-content: start;
  background: color-mix(in srgb, var(--surface) 92%, var(--bg));
}

.theme-color-section {
  display: grid;
  gap: 10px;
}

.theme-color-section h3 {
  color: var(--ink);
  font-size: 0.9rem;
}

.theme-color-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}

.theme-color-control {
  min-height: 58px;
  padding: 9px 10px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 68px 72px;
  gap: 10px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  font-weight: 850;
}

.theme-color-control:hover {
  border-color: color-mix(in srgb, var(--accent) 45%, var(--line));
  background: color-mix(in srgb, var(--accent) 6%, var(--surface));
}

.theme-color-label {
  display: grid;
  gap: 3px;
}

.theme-color-label strong {
  min-width: 0;
  color: var(--ink);
  font-size: 0.84rem;
}

.theme-color-label small {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 700;
  line-height: 1.2;
}

.theme-color-picker {
  display: grid;
  gap: 3px;
  justify-items: center;
}

.theme-color-control input[type="color"] {
  width: 54px;
  height: 34px;
  padding: 2px;
  border: 2px solid var(--line-strong);
  border-radius: 10px;
  cursor: pointer;
}

.theme-color-picker span {
  color: var(--accent);
  font-size: 0.66rem;
  font-weight: 900;
  text-transform: uppercase;
}

.theme-color-reset {
  min-width: 0;
  min-height: 32px;
  padding: 5px 8px;
  border-color: var(--line);
  background: color-mix(in srgb, var(--surface-2) 72%, var(--surface));
  color: var(--muted);
  font-size: 0.7rem;
  white-space: nowrap;
}

.theme-color-reset:hover {
  color: var(--accent);
  border-color: color-mix(in srgb, var(--accent) 48%, var(--line));
}

.theme-card {
  min-height: 154px;
  padding: 14px;
  display: grid;
  gap: 8px;
  align-content: start;
  text-align: left;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
}

.theme-card.active {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 25%, transparent), var(--shadow);
}

.theme-icon {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: var(--radius);
  background: var(--surface-2);
  color: var(--accent);
  font-size: 1.45rem;
  font-weight: 900;
}

.theme-card strong {
  font-size: 1.08rem;
}

.theme-card small {
  color: var(--muted);
  line-height: 1.35;
}

.theme-card-actions {
  display: grid;
  grid-template-columns: 0.72fr 1.28fr;
  gap: 7px;
  margin-top: 4px;
}

.theme-card-actions button {
  min-height: 32px;
  padding: 6px 8px;
  font-size: 0.76rem;
  white-space: normal;
}

.theme-swatch {
  height: 8px;
  margin-top: 4px;
  border-radius: 999px;
}

.theme-swatch-classic {
  background: linear-gradient(90deg, #2563eb, #f8fafc, #172033);
}

.theme-swatch-classic-dark {
  background: linear-gradient(90deg, #60a5fa, #172033, #0f172a);
}


.theme-swatch-ubuntu {
  background: linear-gradient(90deg, #e95420, #77216f, #2c001e);
}

.theme-swatch-ubuntu-dark {
  background: linear-gradient(90deg, #ff7b42, #d76bd0, #13000d);
}

.theme-swatch-mac {
  background: linear-gradient(90deg, #007aff, #ff3b30, #ffcc00);
}

.theme-swatch-mac-dark {
  background: linear-gradient(90deg, #0a84ff, #bf5af2, #101114);
}

.theme-swatch-graphite {
  background: repeating-linear-gradient(112deg, #fbf7ea 0 5px, #c8c1b2 5px 7px, #4d5966 7px 11px);
}

.theme-swatch-graphite-dark {
  background: repeating-linear-gradient(112deg, #1f1f1d 0 5px, #5b564b 5px 7px, #b6c1c9 7px 11px);
}

.theme-swatch-windows {
  background:
    linear-gradient(rgba(255, 252, 242, 0.22), rgba(255, 252, 242, 0.22)),
    url("./assets/themes/sport-football.png") center / cover,
    #f3f0e3;
  background-blend-mode: normal, multiply, normal;
}

.theme-swatch-windows-dark {
  background:
    linear-gradient(rgba(17, 24, 22, 0.40), rgba(17, 24, 22, 0.40)),
    url("./assets/themes/sport-running.png") center / cover,
    #111816;
  background-blend-mode: multiply, screen, normal;
}

.theme-swatch-win11 {
  background: linear-gradient(90deg, #0067c0, #60cdff, #f9fbff);
}

.theme-swatch-win11-dark {
  background: linear-gradient(90deg, #10141c, #60cdff, #b69cff);
}

.help-page {
  display: grid;
  grid-template-rows: minmax(0, 1fr);
  height: 100%;
  min-height: 0;
  overflow: hidden;
}

/* Le bandeau d'intro vit désormais en tête de la colonne de contenu : il défile
   avec la page au lieu d'occuper en permanence le haut. Version compacte. */
.help-content > .help-hero {
  flex: 0 0 auto;
}

.help-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(200px, 280px);
  gap: 14px;
  align-items: center;
  padding: 12px 16px;
  border: 1px solid color-mix(in srgb, var(--accent) 22%, var(--line));
  border-radius: var(--radius);
  background: linear-gradient(115deg, color-mix(in srgb, var(--gold) 12%, var(--surface)), var(--surface) 58%);
  box-shadow: var(--shadow);
}

.help-hero span,
.help-version strong {
  color: var(--accent);
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
}

.help-hero h2 {
  margin: 2px 0 3px;
  font-size: clamp(1.15rem, 1.2vw + 0.7rem, 1.5rem);
  line-height: 1.12;
}

.help-hero p,
.help-version span {
  margin: 0;
  color: var(--muted);
  font-size: 0.82rem;
}

.help-version {
  display: grid;
  gap: 4px;
  padding: 9px 11px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
}

.help-layout {
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 18px;
  align-items: stretch;
  min-height: 0;
  overflow: hidden;
}

.help-toc {
  align-self: stretch;
  min-height: 0;
  max-height: 100%;
  overflow-y: auto;
  display: grid;
  gap: 4px;
  align-content: start;
}

.help-toc a {
  display: block;
  padding: 9px 11px;
  border-radius: 7px;
  color: var(--ink);
  font-size: 0.92rem;
  font-weight: 800;
  line-height: 1.2;
}

.help-toc a:hover {
  background: var(--surface-2);
  color: var(--accent);
}

.help-content {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 0;
  max-height: 100%;
  overflow-y: auto;
  padding-right: 6px;
  scroll-padding-top: 12px;
}

.help-content > .help-section {
  flex: 0 0 auto;
}

.help-section {
  scroll-margin-top: 112px;
  overflow: hidden;
}

.help-section-head {
  padding: 16px 18px;
  border-bottom: 1px solid var(--line);
  display: flex;
  gap: 12px;
  align-items: center;
  justify-content: space-between;
  background: color-mix(in srgb, var(--surface-2) 72%, var(--surface));
}

.help-section h3 {
  margin: 0;
  font-size: 1.08rem;
}

.help-section-head span {
  flex: 0 0 auto;
  padding: 4px 9px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  font-size: 0.75rem;
  font-weight: 850;
}

.help-point-list {
  padding: 12px;
  display: grid;
  gap: 8px;
}

.help-point {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  padding: 10px 12px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: calc(var(--radius) - 2px);
  background: color-mix(in srgb, var(--surface) 92%, var(--surface-2));
}

.help-point > span {
  width: 24px;
  height: 24px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 12%, var(--surface-2));
  color: var(--accent);
  font-size: 0.76rem;
  font-weight: 900;
}

.help-point p {
  margin: 0;
  color: var(--muted);
  line-height: 1.48;
}

.toggle-line {
  display: flex;
  gap: 10px;
  align-items: center;
}

.toggle-line input {
  width: auto;
}

.payment-ok {
  font-family: var(--font-button);
  font-weight: 850;
  letter-spacing: 0;
  color: var(--accent);
  border-color: #afd4c8;
}

.payment-ok.cancel-payment {
  color: #d8483e;
  border-color: color-mix(in srgb, #d8483e 45%, var(--line));
}

.payment-stack {
  display: grid;
  gap: 8px;
}

.payment-stack strong {
  color: var(--muted);
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0;
}

.reference-cell {
  display: grid;
  grid-template-columns: minmax(105px, 1fr) 34px;
  gap: 6px;
  align-items: center;
}

.bar-list {
  display: grid;
  gap: 10px;
  padding: 14px 16px 16px;
}

.bar-row {
  display: grid;
  grid-template-columns: minmax(120px, 0.8fr) minmax(120px, 2fr) 86px;
  gap: 10px;
  align-items: center;
}

.bar-label {
  overflow: hidden;
  text-overflow: ellipsis;
}

.bar-track {
  height: 12px;
  background: #edf1ef;
  border-radius: 999px;
  overflow: hidden;
}

.bar-fill {
  height: 100%;
  background: var(--accent);
}

.stats-pie-band {
  overflow: hidden;
}

.stats-pie-mode {
  margin-left: auto;
}

.stats-pie-mode button {
  min-height: 28px;
  padding: 3px 9px;
  font-size: 0.72rem;
}

.stats-pie-layout {
  padding: 16px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  align-items: center;
}

.stats-pie {
  width: min(230px, 100%);
  margin: 0 auto;
  aspect-ratio: 1;
  border-radius: 50%;
  display: grid;
  place-items: center;
  box-shadow: inset 0 0 0 1px var(--line), var(--shadow);
}

.stats-pie > div {
  width: 44%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: var(--surface);
  border: 1px solid var(--line);
  display: grid;
  place-items: center;
  align-content: center;
  gap: 2px;
  text-align: center;
  padding: 10px;
}

.stats-pie > div strong {
  font-size: clamp(0.95rem, 1.5vw, 1.22rem);
}

.stats-pie > div span {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 750;
  text-transform: uppercase;
}

.stats-pie-legend {
  display: grid;
  gap: 7px;
}

.stats-pie-legend-row {
  min-height: 34px;
  display: grid;
  grid-template-columns: 14px minmax(92px, 1fr) 64px 88px;
  gap: 7px;
  align-items: center;
  padding: 6px 8px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 84%, var(--surface-2));
}

.stats-pie-color {
  width: 12px;
  height: 12px;
  border-radius: 50%;
}

.stats-pie-legend-row strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.stats-pie-legend-row span {
  color: var(--muted);
}

.accounting-board {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 14px;
}

.accounting-group {
  border-left: 5px solid var(--accent);
}

.accounting-due {
  border-left-color: #dc2626;
}

.accounting-invest {
  border-left-color: #f59e0b;
}

.accounting-profit {
  border-left-color: #15803d;
}

.accounting-metrics {
  display: grid;
  gap: 10px;
  padding: 14px;
}

.accounting-module-card {
  min-width: 0;
}

.accounting-module-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  padding: 14px;
}

.accounting-tax-note {
  margin: 12px 14px 0;
  padding: 10px 12px;
  border: 1px solid color-mix(in srgb, #f59e0b 45%, var(--line));
  border-radius: 8px;
  background: color-mix(in srgb, #f59e0b 10%, var(--surface));
  color: var(--ink);
  font-size: 0.86rem;
  line-height: 1.45;
}

.accounting-metric {
  display: grid;
  gap: 4px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-2);
}

.accounting-metric span {
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 800;
  text-transform: uppercase;
}

.accounting-metric strong,
.accounting-mini strong {
  font-size: 1.08rem;
  font-variant-numeric: tabular-nums;
}

.accounting-metric small,
.accounting-mini span {
  color: var(--muted);
  font-size: 0.78rem;
}

.accounting-metric.is-due strong,
.accounting-metric.is-danger strong {
  color: #b91c1c;
}

.accounting-metric.is-paid strong {
  color: #15803d;
}

.accounting-mini {
  display: grid;
  gap: 6px;
}

.accounting-mini h3 {
  margin: 0;
}

.accounting-footnote p {
  margin: 0;
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

/* Chaque champ se cale en HAUT de sa rangée : un voisin plus haut (ex. « Salle / lieu » avec
   message + saisie libre) ne fait plus descendre le champ d'à côté (ex. « Places max »).
   Les labels (display:grid) ne s'étirent plus, donc l'input reste juste sous son intitulé.
   La grille spéciale de l'éditeur de club garde son propre alignement (règle plus spécifique). */
.dialog-body .form-grid {
  align-items: start;
}

.form-grid.stage-price-line {
  grid-template-columns: minmax(124px, 0.8fr) minmax(130px, 1fr) minmax(130px, 1fr) minmax(116px, 0.9fr);
}

.form-grid .wide,
.dialog-section {
  grid-column: 1 / -1;
}

.dialog {
  width: min(940px, calc(100vw - 24px));
  position: relative;
  overflow: visible;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 0;
  background: var(--surface);
  color: var(--ink);
  box-shadow: 0 18px 60px rgba(18, 28, 24, 0.24);
}

/* Dialogue ouvert en modal (showModal) : ancré au viewport, pas au document,
   pour ne pas faire défiler la page en haut à l'ouverture. Le scroll interne
   reste géré par .dialog-body ; overflow visible conservé pour la photo
   d'identité qui déborde du cadre. */
.dialog:modal {
  position: fixed;
  inset: 0;
  margin: auto;
  max-height: calc(100vh - 24px);
}

.dialog.has-identity-photo .dialog-header h2 {
  padding-left: 88px;
}

.identity-photo-corner {
  position: absolute;
  top: -52px;
  left: -14px;
  z-index: 3;
  display: grid;
  justify-items: center;
}

.identity-photo-frame {
  width: 86px;
  height: 110px;
  padding: 0;
  display: grid;
  place-items: center;
  border: 7px solid var(--surface);
  border-radius: 16px;
  overflow: hidden;
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 18%, var(--surface)), var(--surface-2));
  box-shadow: none;
}

.identity-photo-frame img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.identity-photo-frame.empty span {
  color: var(--muted);
  font-size: 1.35rem;
  font-weight: 950;
}

.identity-avatar-choice {
  align-self: start;
}

.identity-avatar-choice small {
  line-height: 1.35;
}

/* Option secondaire repliable dans un formulaire : une ligne discrète, le contenu apparaît au clic. */
.field-secondary {
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--surface) 92%, var(--surface-2));
}

.field-secondary > summary {
  cursor: pointer;
  list-style: none;
  padding: 8px 11px;
  font-size: 0.8rem;
  font-weight: 650;
  color: var(--muted);
  display: flex;
  align-items: center;
  gap: 7px;
}

.field-secondary > summary::-webkit-details-marker {
  display: none;
}

.field-secondary > summary::before {
  content: "▸";
  font-size: 0.7rem;
  color: var(--muted);
  transition: transform 0.15s ease;
}

.field-secondary[open] > summary::before {
  transform: rotate(90deg);
}

.field-secondary[open] > summary {
  border-bottom: 1px solid var(--line);
}

.field-secondary > label,
.field-secondary > .identity-avatar-choice {
  padding: 10px 11px;
}

.identity-photo-viewer {
  display: grid;
  place-items: center;
}

.identity-photo-viewer img {
  max-width: min(360px, 86vw);
  max-height: 70vh;
  border-radius: 18px;
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.28);
}

.identity-photo-lightbox {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: grid;
  place-items: center;
  padding: 28px;
  background: rgba(0, 0, 0, 0.52);
}

.identity-photo-lightbox-panel {
  position: relative;
  display: grid;
  gap: 14px;
  justify-items: center;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) + 8px);
  background: var(--surface);
  color: var(--ink);
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.34);
}

.identity-photo-lightbox-close {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 1;
}

.identity-photo-lightbox-image {
  width: min(360px, 78vw);
  min-height: 280px;
  display: grid;
  place-items: center;
  border-radius: 18px;
  overflow: hidden;
  background: var(--surface-2);
}

.identity-photo-lightbox-image img {
  width: 100%;
  max-height: 72vh;
  display: block;
  object-fit: contain;
}

.identity-photo-lightbox-image span {
  color: var(--muted);
  font-size: 3rem;
  font-weight: 950;
}

.identity-photo-lightbox-actions {
  display: flex;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
}

.dialog::backdrop {
  background: rgba(18, 28, 24, 0.34);
}

.dialog.stacked-dialog::backdrop {
  background: rgba(18, 28, 24, 0.18);
}

.dialog-header,
.dialog-footer {
  padding: 12px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid var(--line);
}

.dialog-header {
  cursor: grab;
  user-select: none;
  touch-action: none;
  border-top-left-radius: calc(var(--radius) - 1px);
  border-top-right-radius: calc(var(--radius) - 1px);
  background-clip: padding-box;
}

.dialog-header button,
.dialog-header input,
.dialog-header select,
.dialog-header textarea,
.dialog-header a,
.dialog-header label {
  cursor: auto;
}

.dialog.is-dragging .dialog-header {
  cursor: grabbing;
}

.dialog.is-collapsed {
  overflow: hidden;
}

.dialog.is-collapsed .dialog-header {
  border-bottom: 0;
}

.dialog.is-collapsed .dialog-header h2 {
  padding-left: 0;
}

.dialog.is-collapsed .dialog-body,
.dialog.is-collapsed .dialog-footer,
.dialog.is-collapsed .identity-photo-corner {
  display: none;
}

.dialog-footer {
  border-top: 1px solid var(--line);
  border-bottom: 0;
  justify-content: space-between;
  border-bottom-left-radius: calc(var(--radius) - 1px);
  border-bottom-right-radius: calc(var(--radius) - 1px);
  background-clip: padding-box;
}

.dialog-footer-left,
.dialog-footer-actions,
.contact-module-links {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.dialog-footer-actions {
  margin-left: auto;
}

.contact-module-links button {
  padding-inline: 10px;
  min-height: 34px;
}

.contact-module-links button.is-paid {
  background: #15803d;
  border-color: #15803d;
  color: #fff;
}

.contact-module-links button.is-due {
  background: #b91c1c;
  border-color: #b91c1c;
  color: #fff;
}

.contact-module-links button.is-pending {
  background: #d97706;
  border-color: #d97706;
  color: #fff;
}

.contact-module-links button.is-empty {
  opacity: 0.72;
}

.contact-recap {
  display: grid;
  gap: 12px;
  padding: 14px;
  border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--line));
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface-2) 58%, var(--surface));
}

.contact-recap-head {
  display: flex;
  gap: 12px;
  align-items: start;
  justify-content: space-between;
}

.contact-recap-head h3,
.contact-recap-head p,
.contact-recap-section h4 {
  margin: 0;
}

.contact-recap-head p {
  margin-top: 3px;
  color: var(--muted);
  font-size: 0.86rem;
}

.contact-recap-total {
  min-width: 118px;
  padding: 8px 10px;
  display: grid;
  gap: 2px;
  justify-items: end;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
}

.contact-recap-total.has-due {
  border-color: color-mix(in srgb, var(--accent-2) 45%, var(--line));
}

.contact-recap-total span,
.contact-recap-kpis span,
.contact-recap-amounts span {
  color: var(--muted);
  font-size: 0.75rem;
  font-weight: 850;
}

.contact-recap-total.has-due strong,
.contact-recap-amounts .due strong {
  color: var(--accent-2);
}

.contact-recap-kpis {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.contact-recap-kpis div {
  min-width: 0;
  padding: 9px 10px;
  display: grid;
  gap: 3px;
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) - 2px);
  background: var(--surface);
}

.contact-recap-section {
  display: grid;
  gap: 7px;
}

.contact-recap-section h4 {
  color: var(--ink);
  font-size: 0.88rem;
}

.contact-recap-list {
  display: grid;
  gap: 7px;
}

.contact-recap-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(210px, auto);
  gap: 10px;
  align-items: center;
  padding: 9px 10px;
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) - 2px);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
}

.contact-recap-main {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.contact-recap-main strong,
.contact-recap-main span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.contact-recap-main span {
  color: var(--muted);
  font-size: 0.8rem;
}

.contact-recap-amounts {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.contact-recap-empty {
  padding: 12px;
  border: 1px dashed var(--line);
  border-radius: calc(var(--radius) - 2px);
  color: var(--muted);
  background: var(--surface);
}

.dialog-body {
  padding: 14px;
  max-height: min(74vh, 780px);
  overflow: auto;
}

.agenda-dialog {
  display: grid;
  gap: 14px;
}

.dialog h2,
.dialog h3 {
  margin: 0;
}

.dialog-section {
  border-top: 1px solid var(--line);
  padding-top: 12px;
  margin-top: 4px;
}

.context-menu {
  position: fixed;
  z-index: 1000;
  min-width: 178px;
  padding: 6px;
  display: grid;
  gap: 2px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  color: var(--ink);
  box-shadow: 0 18px 44px rgba(18, 28, 24, 0.24);
}

.context-menu[hidden] {
  display: none;
}

.context-menu button {
  min-height: 32px;
  padding: 0 10px;
  justify-content: flex-start;
  text-align: left;
  border-color: transparent;
  background: transparent;
  border-radius: 6px;
}

.context-menu button:hover:not(:disabled) {
  background: var(--surface-2);
  transform: none;
}

.context-menu button:disabled {
  cursor: not-allowed;
  opacity: 0.45;
}

.context-menu span {
  height: 1px;
  margin: 4px 2px;
  background: var(--line);
}

.inline-fields {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

details {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 10px;
  background: #fff;
}

summary {
  cursor: pointer;
  font-weight: 750;
}

.size-grid {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(76px, 1fr));
  gap: 8px;
}

.editable-table input,
.editable-table select {
  min-width: 90px;
}

.tariff-vat-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(150px, 220px);
  gap: 14px;
  align-items: end;
}

.tariff-vat-panel h2,
.tariff-vat-panel p {
  margin: 0;
}

.memo-table textarea {
  min-width: 320px;
  min-height: 44px;
  resize: vertical;
}

.memo-row td {
  vertical-align: top;
}

.memo-row.editing td {
  background: color-mix(in srgb, var(--accent) 6%, var(--surface));
}

.tariff-row td {
  vertical-align: middle;
}

.tariff-table-wrap {
  overflow-x: hidden;
}

.table-wrap .tariff-table {
  min-width: 0;
}

.tariff-table {
  table-layout: fixed;
  width: 100%;
}

.tariff-table th,
.tariff-table td {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.tariff-table th:last-child,
.tariff-table td:last-child {
  width: 64px;
}

.tariff-table .tariff-tax-cell {
  width: 72px;
}

.tariff-table .money {
  text-align: left;
}

.tariff-row[data-action] {
  cursor: pointer;
}

.tariff-row[data-action]:hover td {
  background: var(--surface-2);
}

.tariff-row.editing td {
  background: color-mix(in srgb, var(--accent) 6%, var(--surface));
}

.tariff-row.editing input {
  min-width: 0;
  width: 100%;
  max-width: 100%;
  min-height: 30px;
  height: 30px;
  padding: 0 8px;
  border-radius: 6px;
  box-sizing: border-box;
}

/* Ligne de tarif en édition : les champs numériques sont enrichis de boutons +/- (.number-stepper,
   min-width 96px). En table-layout: fixed, ces steppers ne tenaient pas dans les colonnes étroites
   (ex. Stages, 8 colonnes) et se chevauchaient. Tant qu'au moins une ligne est éditée, on rend la
   table à sa largeur naturelle avec un scroll horizontal propre ; chaque champ garde une taille
   lisible, les boutons restent groupés, l'alignement des colonnes est conservé. */
.tariff-table-wrap:has(.tariff-row.editing) {
  overflow-x: auto;
}
.tariff-table:has(.tariff-row.editing) {
  table-layout: auto;
  min-width: max-content;
}
.tariff-table:has(.tariff-row.editing) th,
.tariff-table:has(.tariff-row.editing) td {
  overflow: visible;
  white-space: nowrap;
}
.tariff-row.editing td {
  padding-right: 10px;
}
.tariff-row.editing input:not([type="number"]) {
  width: 100%;
  min-width: 160px;
}
.tariff-row.editing .number-stepper {
  width: 118px;
  min-width: 118px;
  gap: 5px;
}
.tariff-row.editing .number-stepper input[type="number"] {
  width: 100%;
  min-width: 0;
}
.tariff-table:has(.tariff-row.editing) td:last-child {
  width: auto;
  min-width: 76px;
}

.tariff-row .actions {
  min-width: 0;
  gap: 4px;
  white-space: nowrap;
}

.tariff-check {
  color: #15803d;
  border-color: color-mix(in srgb, #15803d 45%, var(--line));
}

.memo-note {
  min-width: 280px;
  max-width: 520px;
  white-space: normal;
  line-height: 1.35;
}

.memo-table td:nth-child(4) input {
  min-width: 120px;
}

.notes-page {
  display: grid;
  gap: 14px;
}

.note-tabs {
  padding: 10px;
  display: flex;
  gap: 8px;
  overflow-x: auto;
}

.note-tab {
  max-width: 220px;
  flex: 0 0 auto;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.note-tab.active {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--on-accent);
}

:root[data-theme="graphite"] .note-tab.active,
:root[data-theme="graphite-dark"] .note-tab.active,
:root[data-theme="graphite"] .segmented button.active,
:root[data-theme="graphite-dark"] .segmented button.active {
  border-color: var(--line-strong);
  background:
    repeating-linear-gradient(110deg, color-mix(in srgb, var(--accent) 24%, transparent) 0 2px, transparent 2px 9px),
    color-mix(in srgb, var(--accent) 14%, var(--surface));
  color: var(--ink);
}

.note-title-row {
  grid-template-columns: minmax(0, 1fr) auto;
}

.note-title-input {
  max-width: 520px;
  font-size: 1.05rem;
  font-weight: 800;
}

.note-toolbar {
  padding: 10px;
  border-bottom: 1px solid var(--line);
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
  background: var(--surface-2);
}

.note-toolbar select {
  width: auto;
  min-width: 110px;
}

.note-toolbar input[type="color"] {
  width: 38px;
  min-width: 38px;
  padding: 3px;
}

.note-editor {
  min-height: 430px;
  padding: 18px;
  background: var(--surface);
  color: var(--ink);
  line-height: 1.55;
  outline: 0;
  overflow: auto;
}

.note-editor:empty::before {
  content: "Écris ta note ici...";
  color: var(--muted);
}

.empty {
  padding: 22px;
  color: var(--muted);
}

/* Assistant MonGestaClub — états vides pédagogiques (Phase 1). */
.assistant-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 10px;
  padding: 40px 28px;
  margin: 4px auto;
  max-width: 560px;
  color: var(--ink);
}
.assistant-empty-icon {
  font-size: 40px;
  line-height: 1;
  opacity: 0.92;
}
/* Lot E — icônes MGC illustrées des états vides de modules */
.assistant-empty-icon .mgc-icon { width: 56px; height: 56px; margin: 0 auto; }
.assistant-empty-title {
  margin: 0;
  font-size: 18px;
  font-weight: 600;
}
.assistant-empty-why {
  margin: 0;
  max-width: 46ch;
  color: var(--muted);
  line-height: 1.5;
}
.assistant-empty .assistant-empty-cta {
  margin-top: 6px;
}
/* Bouton « Pourquoi ? » — révélation inline (lieu calme, jamais de pop-up). */
.assistant-why {
  margin-top: 4px;
  max-width: 46ch;
}
.assistant-why > summary {
  cursor: pointer;
  color: var(--accent);
  font-size: 13px;
  list-style: none;
  user-select: none;
}
.assistant-why > summary::-webkit-details-marker {
  display: none;
}
.assistant-why > summary::before {
  content: "› ";
}
.assistant-why[open] > summary::before {
  content: "⌄ ";
}
.assistant-why > p {
  margin: 8px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
  text-align: left;
}
/* Média d'accompagnement (architecture prête ; non utilisé pour l'instant). */
.assistant-media {
  max-width: 100%;
  border-radius: 10px;
  border: 1px solid var(--line);
}

/* Centre d'accompagnement (intégré à l'Aide). */
.assistant-center .assistant-center-intro {
  margin: 0 0 14px;
  color: var(--muted);
}
.assistant-center-group {
  margin-top: 16px;
}
.assistant-center-group h4 {
  margin: 0 0 8px;
  font-size: 14px;
}
.assistant-center-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.assistant-center-tours {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.assistant-center-tour {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  text-align: left;
}
.assistant-center-tour small {
  color: var(--muted);
  font-weight: normal;
}

/* ============================================================
   Centre d'accompagnement — composition produit (passe design).
   En-tête léger + grille 2 colonnes (contenu principal / colonne latérale)
   pour casser l'effet « pile de rectangles » et varier le rythme.
   ============================================================ */
.assistant-page { display: flex; flex-direction: column; gap: 20px; }

/* Hero : en-tête léger (pas une carte), progression globale intégrée à droite. */
.assistant-hero { display: flex; align-items: flex-end; justify-content: space-between; gap: 28px; flex-wrap: wrap; padding: 6px 4px 2px; }
.assistant-hero-main { min-width: 0; }
.assistant-hero-kicker { display: inline-block; font-size: 0.72rem; font-weight: 800; letter-spacing: 0.05em; text-transform: uppercase; color: var(--accent); }
.assistant-hero h2 { margin: 6px 0; font-size: 1.45rem; line-height: 1.15; }
.assistant-hero p { margin: 0; max-width: 60ch; color: var(--muted); }
.assistant-hero-stat { flex: none; width: 220px; max-width: 100%; }
.assistant-hero-stat-head { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; margin-bottom: 8px; }
.assistant-hero-stat-head span { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); }
.assistant-hero-stat-head strong { font-size: 1.5rem; line-height: 1; font-variant-numeric: tabular-nums; }

/* Grille 2 colonnes : contenu principal large + colonne latérale d'appui. */
.assistant-grid { display: grid; grid-template-columns: minmax(0, 1fr); gap: 16px; align-items: start; }
.assistant-main, .assistant-aside { display: flex; flex-direction: column; gap: 16px; min-width: 0; }
@media (min-width: 1080px) {
  .assistant-grid { grid-template-columns: minmax(0, 1.9fr) minmax(264px, 1fr); }
}

/* Corps de section : padding homogène. */
.assistant-section-body { padding: 16px 18px; }
.assistant-section .band-title span { font-weight: 400; color: var(--muted); font-size: 0.8rem; }

/* Progression : une ligne compacte par domaine (libellé · piste · valeur). */
.assistant-progress-bars { display: flex; flex-direction: column; gap: 11px; }
.assistant-progress-row { display: grid; grid-template-columns: minmax(92px, auto) minmax(0, 1fr) 38px; align-items: center; column-gap: 12px; }
.assistant-progress-head { display: contents; }
.assistant-progress-head span { grid-column: 1; font-size: 0.85rem; color: var(--ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.assistant-progress-head strong { grid-column: 3; text-align: right; font-size: 0.8rem; font-variant-numeric: tabular-nums; font-weight: 700; color: var(--muted); }
.assistant-progress-track { grid-column: 2; height: 6px; border-radius: 999px; background: var(--surface-2); overflow: hidden; border: 1px solid var(--line); }
.assistant-progress-fill { height: 100%; background: var(--accent); border-radius: 999px; transition: width 0.3s ease; }

/* Reprendre : bannière légère (liseré accent), pas un gros bloc. */
.assistant-resume { display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap; padding: 12px 14px; border: 1px solid var(--line); border-left: 3px solid var(--accent); border-radius: var(--radius); background: var(--surface-2); }
.assistant-resume-text { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.assistant-resume-kicker { font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); }
.assistant-resume-text strong { font-size: 0.98rem; }
.assistant-resume-why { font-size: 0.8rem; color: var(--muted); line-height: 1.4; }
.assistant-resume .assistant-tour-duration { margin-top: 2px; }
.assistant-resume .primary { flex: none; }

/* Groupe d'actions : ensemble cohérent (mêmes hauteurs et espaces). */
.assistant-center-actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }
.assistant-center-actions button { margin: 0; }
.assistant-empty-note { margin: 0; color: var(--muted); }
.assistant-note { margin: 12px 0 0; font-size: 0.8rem; }

/* Catalogue de visites guidées. */
.assistant-tours-body { display: flex; flex-direction: column; gap: 20px; }
.assistant-tour-group { margin: 0; }
.assistant-tour-group h4 { margin: 0 0 10px; font-size: 0.78rem; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; color: var(--muted); }
.assistant-tour-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(248px, 1fr)); gap: 12px; align-items: stretch; }
.assistant-tour-card { position: relative; display: flex; border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface); overflow: hidden; transition: border-color 0.15s ease, box-shadow 0.15s ease; }
.assistant-tour-card:hover { border-color: var(--line-strong); box-shadow: var(--shadow); }
.assistant-tour-card.is-done { border-color: color-mix(in srgb, var(--accent) 45%, var(--line)); }
.assistant-tour-fav { position: absolute; top: 8px; right: 8px; z-index: 2; background: transparent; border: none; font-size: 1.15rem; line-height: 1; color: var(--muted); cursor: pointer; padding: 6px; border-radius: 6px; pointer-events: auto; transition: color 0.12s ease, background 0.12s ease; }
.assistant-tour-fav:hover, .assistant-tour-fav:focus-visible, .assistant-tour-fav.is-fav { color: var(--gold, #d4af37); }
.assistant-tour-fav:hover, .assistant-tour-fav:focus-visible { background: color-mix(in srgb, var(--gold, #d4af37) 16%, transparent); }
.assistant-tour-open { display: flex; flex-direction: column; align-items: flex-start; gap: 6px; text-align: left; width: 100%; min-height: 100px; padding: 13px 38px 13px 15px; background: transparent; border: none; cursor: pointer; }
.assistant-tour-name { font-weight: 600; line-height: 1.25; }
.assistant-tour-done { display: inline-block; color: var(--accent); font-weight: 500; font-size: 0.72rem; }
.assistant-tour-summary { color: var(--muted); font-size: 0.82rem; line-height: 1.45; font-weight: 400; flex: 1; }
.assistant-tour-duration { color: var(--muted); font-size: 0.75rem; font-variant-numeric: tabular-nums; }

/* Préférences : réglages espacés (réutilise .settings-check pour la cohérence). */
.assistant-prefs { display: flex; flex-direction: column; gap: 10px; }

/* Responsive : compacité maîtrisée sur petites largeurs. */
@media (max-width: 720px) {
  .assistant-page { gap: 16px; }
  .assistant-hero { gap: 14px; align-items: flex-start; }
  .assistant-hero-stat { width: 100%; }
  .assistant-section-body { padding: 14px 16px; }
  .assistant-tour-list { grid-template-columns: 1fr; }
  .assistant-resume { align-items: stretch; }
  .assistant-resume .primary { width: 100%; }
}
/* Dialogue de visite (présentation + suite proposée). */
.assistant-tour-dialog-duration { color: var(--muted); margin: 0 0 6px; }
.assistant-tour-dialog-actions { display: flex; flex-wrap: wrap; gap: 8px; margin: 12px 0; }
.assistant-tour-next { margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--line); }
.assistant-tour-next-title { font-weight: 600; margin: 0 0 8px; }
.assistant-tour-next-list { display: flex; flex-wrap: wrap; gap: 8px; }
/* En savoir plus (lien vers l'aide). */
.assistant-learn-more { display: inline-block; margin-top: 8px; background: transparent; border: none; color: var(--accent); cursor: pointer; padding: 0; font-size: 13px; text-decoration: underline; }
.assistant-why-actions { margin-top: 4px; }

/* Carte « Aujourd'hui » (accueil). */
.assistant-today .band-title { display: flex; align-items: center; justify-content: space-between; }
.assistant-today-link { background: transparent; border: none; color: var(--accent); cursor: pointer; font-size: 13px; }
.assistant-today-headline { display: flex; gap: 12px; align-items: flex-start; padding: 12px; border: 1px solid var(--line); border-radius: 10px; background: var(--surface-2); margin: 12px; }
.assistant-today-icon { font-size: 22px; line-height: 1.2; flex: none; }
/* Lot D — icônes MGC du Centre d'accompagnement */
.assistant-hero-kicker { display: inline-flex; align-items: center; gap: 6px; }
.assistant-hero-ico { display: inline-flex; align-items: center; }
.assistant-hero-ico .mgc-icon { width: 25px; height: 25px; }
.feedback-cta-icon .mgc-icon { width: 22px; height: 22px; vertical-align: middle; }
.assistant-cat-ico { display: inline-flex; align-items: center; vertical-align: middle; margin-right: 6px; }
.assistant-cat-ico .mgc-icon { width: 22px; height: 22px; }
.assistant-today-icon .mgc-icon { width: 38px; height: 38px; }
.feedback-cat-ico { display: inline-flex; align-items: center; vertical-align: middle; margin-right: 6px; }
.feedback-cat-ico .mgc-icon { width: 18px; height: 18px; }
.feedback-dialog-title-icon { display: inline-flex; align-items: center; vertical-align: middle; margin-right: 8px; }
.feedback-dialog-title-icon .mgc-icon { width: 26px; height: 26px; }
.assistant-today-text strong { display: block; font-size: 15px; }
.assistant-today-text p { margin: 2px 0 0; color: var(--muted); font-size: 13px; }
.assistant-today-meta { display: inline-block; margin-top: 4px; font-size: 12px; color: var(--muted); }
.assistant-today-note { margin: 10px 0 0; font-size: 0.78rem; line-height: 1.4; color: var(--muted); opacity: 0.9; }
.assistant-today-actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }
.assistant-today-items { list-style: none; margin: 12px; padding: 0; display: flex; flex-wrap: wrap; gap: 8px; }
.assistant-today-items button { background: var(--surface); border: 1px solid var(--line); border-radius: 999px; padding: 5px 12px; cursor: pointer; font-size: 13px; }
.assistant-today-items button:hover { border-color: var(--accent); }

/* Visite interactive : overlay, halo, bulle. */
.assistant-tour-overlay { position: fixed; inset: 0; z-index: 4000; pointer-events: none; }
.assistant-tour-overlay.is-centered { background: rgba(0, 0, 0, 0.45); }
.assistant-halo { position: fixed; border-radius: 10px; box-shadow: 0 0 0 9999px rgba(0, 0, 0, 0.45); pointer-events: none; transition: all 0.2s ease; }
.assistant-bubble { position: fixed; max-width: 330px; background: var(--surface); color: var(--ink); border: 1px solid var(--line-strong); border-radius: 12px; padding: 14px 16px; box-shadow: 0 14px 44px rgba(0, 0, 0, 0.28); pointer-events: auto; z-index: 4001; }
.assistant-bubble::before { content: ""; position: absolute; width: 12px; height: 12px; background: var(--surface); border-left: 1px solid var(--line-strong); border-top: 1px solid var(--line-strong); left: 24px; }
.assistant-bubble[data-placement="below"]::before { top: -7px; transform: rotate(45deg); }
.assistant-bubble[data-placement="above"]::before { bottom: -7px; transform: rotate(225deg); }
.assistant-bubble-step { font-size: 12px; color: var(--muted); }
.assistant-bubble-title { margin: 4px 0 6px; font-size: 16px; }
.assistant-bubble-body { margin: 0 0 12px; line-height: 1.45; font-size: 14px; }
.assistant-bubble-actions { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.assistant-bubble-nav { display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.assistant-bubble-skip { background: transparent; border: none; color: var(--muted); cursor: pointer; font-size: 13px; }
/* Contenu riche de la bulle (exemple avant/après, variables, note, action). */
.assistant-bubble { max-height: calc(100vh - 24px); overflow: auto; }
.assistant-bubble-example { margin: 0 0 12px; display: flex; flex-direction: column; gap: 6px; }
.assistant-bubble-example .abx-row { background: var(--surface-2); border: 1px solid var(--line); border-radius: 8px; padding: 8px 10px; font-size: 13px; line-height: 1.45; white-space: pre-wrap; }
.assistant-bubble-example .abx-after { border-color: color-mix(in srgb, var(--accent) 45%, var(--line)); }
.assistant-bubble-example .abx-tag { display: block; font-size: 11px; text-transform: uppercase; letter-spacing: 0.03em; color: var(--muted); margin-bottom: 3px; }
.assistant-bubble-example .abx-arrow { text-align: center; color: var(--muted); font-size: 14px; line-height: 1; }
.assistant-bubble-vars { list-style: none; margin: 0 0 12px; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.assistant-bubble-vars li { display: flex; align-items: baseline; gap: 8px; font-size: 13px; }
.assistant-bubble-vars code { background: var(--surface-2); border: 1px solid var(--line); border-radius: 6px; padding: 1px 6px; font-size: 12px; color: var(--accent); white-space: nowrap; }
.assistant-bubble-vars span { color: var(--muted); }
.assistant-bubble-note { margin: 0 0 12px; font-size: 13px; line-height: 1.45; color: var(--muted); background: var(--surface-2); border: 1px solid var(--line); border-radius: 8px; padding: 8px 10px; }
.assistant-bubble-do { margin: 0 0 12px; }
.assistant-bubble-action { width: 100%; }

/* Célébration discrète (petite réussite). */
.assistant-celebrate { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%); display: flex; align-items: center; gap: 8px; background: var(--surface); border: 1px solid var(--accent); border-radius: 999px; padding: 9px 18px; box-shadow: 0 10px 30px rgba(0, 0, 0, 0.18); z-index: 4002; animation: assistantPop 0.3s ease; }
.assistant-celebrate.is-leaving { opacity: 0; transition: opacity 0.4s ease; }
.assistant-celebrate-check { display: inline-flex; align-items: center; justify-content: center; width: 20px; height: 20px; border-radius: 50%; background: var(--accent); color: var(--on-accent); font-size: 13px; }
@keyframes assistantPop { from { opacity: 0; transform: translateX(-50%) translateY(12px); } to { opacity: 1; transform: translateX(-50%) translateY(0); } }

/* Aide intelligente passive (carte discrète en bas). */
.assistant-idle-hint { position: fixed; bottom: 18px; right: 18px; max-width: 300px; background: var(--surface); border: 1px solid var(--line-strong); border-radius: 12px; padding: 14px 16px 14px; box-shadow: 0 12px 34px rgba(0, 0, 0, 0.2); z-index: 3500; animation: assistantPop 0.3s ease; }
.assistant-idle-hint strong { display: block; }
.assistant-idle-hint p { margin: 4px 0 10px; color: var(--muted); font-size: 13px; }
.assistant-idle-close { position: absolute; top: 6px; right: 8px; background: transparent; border: none; font-size: 18px; line-height: 1; color: var(--muted); cursor: pointer; }
.assistant-whatsnew ul { margin: 8px 0 0; padding-left: 18px; }
.assistant-whatsnew li { margin-bottom: 4px; }

@media (prefers-reduced-motion: reduce) {
  .assistant-celebrate, .assistant-idle-hint { animation: none; }
  .assistant-halo, .assistant-progress-fill { transition: none; }
}

@media (max-width: 1240px) {
  .shell {
    grid-template-columns: 218px minmax(0, 1fr);
  }

  .view {
    padding: 16px;
    gap: 14px;
  }

  .sidebar {
    padding: 14px;
  }

  .band-title {
    padding: 11px 13px;
  }

  th,
  td {
    padding: 6px 7px;
  }

  th {
    font-size: 0.68rem;
  }

  td {
    font-size: 0.8rem;
  }

  input,
  select,
  textarea,
  button {
    min-height: 32px;
  }

  button.icon {
    width: 30px;
    min-height: 30px;
    font-size: 16px;
  }

  .person-cell {
    min-width: 96px;
  }

  .person-cell span {
    font-size: 0.78rem;
  }

  .status {
    min-height: 22px;
    padding: 1px 7px;
    font-size: 0.72rem;
  }

  .payment-drawer {
    width: min(460px, 100%);
  }

  .dialog {
    width: min(900px, calc(100vw - 18px));
  }

  .theme-studio-body {
    grid-template-columns: 1fr;
  }

  .theme-interface-preview {
    min-height: 520px;
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .theme-editor-panel {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  .shell {
    grid-template-columns: 1fr;
  }

  .sidebar {
    position: static;
    height: auto;
    grid-template-rows: auto auto auto auto;
    overflow: visible;
  }

  .nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    overflow: visible;
  }

  .topbar {
    grid-template-columns: 1fr;
  }

  .app-toolbar,
  .tool-group {
    justify-content: flex-start;
  }

  .cockpit-hero,
  .help-hero,
  .help-layout,
  .theme-interface-preview,
  .theme-editor-panel,
  .membership-binder,
  .tariff-vat-panel,
  .settings-themes,
  .grid.two,
  .grid.three,
  .grid.four,
  .grid.dynamic-grid,
  .shop-overview,
  .form-grid {
    grid-template-columns: 1fr;
  }

  .theme-studio-head,
  .preview-topbar {
    align-items: stretch;
    flex-direction: column;
  }

  .preview-sidebar {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .preview-dialog {
    justify-self: stretch;
  }

  .payment-drawer {
    min-width: 0;
  }

  .payment-mini-row {
    grid-template-columns: 1fr;
  }

  .form-grid.stage-price-line {
    grid-template-columns: repeat(2, minmax(124px, 1fr));
  }

  .accounting-module-grid {
    grid-template-columns: 1fr;
  }

  .bar-row {
    grid-template-columns: 1fr;
  }

  .shop-follow-row,
  .signal-row,
  .shop-order-summary,
  .shop-order-head,
  .shop-item-line,
  .shop-total-grid,
  .shop-order-actions {
    grid-template-columns: 1fr;
  }

  .stock-signal-row {
    grid-template-columns: minmax(0, 1fr) auto auto;
  }

  .membership-card {
    grid-template-columns: 1fr;
  }

  .membership-alpha-tabs {
    position: static;
    order: -1;
    grid-template-columns: repeat(auto-fit, minmax(28px, 1fr));
    border-radius: var(--radius);
  }

  .membership-alpha-tabs button,
  .membership-alpha-tabs span {
    width: auto;
  }

  .membership-card-totals {
    grid-template-columns: 1fr;
  }

  .shop-order-summary {
    align-items: start;
  }

  .shop-order-amount,
  .shop-order-summary .status {
    justify-items: start;
    justify-self: start;
  }

  .shop-order-status {
    justify-items: start;
  }

  .contact-recap-head,
  .contact-recap-row {
    grid-template-columns: 1fr;
  }

  .contact-recap-head {
    display: grid;
  }

  .contact-recap-total {
    justify-items: start;
  }

  .contact-recap-kpis {
    grid-template-columns: 1fr;
  }

  .contact-recap-amounts {
    justify-content: flex-start;
  }

  .payment-signal-list .signal-row {
    grid-template-columns: 1fr;
  }

  .payment-signal-list .signal-row > span:first-child {
    padding-right: 0;
    border-right: 0;
  }

  .stats-pie-layout,
  .stats-pie-legend-row {
    grid-template-columns: 1fr;
  }

  .stats-pie {
    margin: 0 auto;
  }

  .quick-actions {
    grid-template-columns: 1fr;
  }

  .help-toc {
    position: static;
  }
}

.brand img,
:root[data-theme] .brand img {
  object-fit: contain;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.club-switcher {
  display: grid;
  gap: 6px;
  margin: 10px 18px 14px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 84%, transparent);
}

.club-switcher span {
  font-size: 0.72rem;
  color: var(--muted);
  font-weight: 700;
  text-transform: uppercase;
}

.club-switcher select,
.club-switcher button {
  width: 100%;
  min-width: 0;
}

.club-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 14px;
  padding: 16px;
}

.club-card {
  display: grid;
  gap: 12px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
}

.club-card.active {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 20%, transparent);
}

.club-card.archived {
  opacity: 0.68;
}

.club-card-head {
  display: grid;
  grid-template-columns: 52px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
}

.club-card-head img,
.club-logo-preview img {
  width: 52px;
  height: 52px;
  object-fit: contain;
  background: transparent;
}

.club-card-head strong,
.club-card-head span {
  display: block;
  min-width: 0;
}

.club-card-head span,
.club-card-meta {
  color: var(--muted);
}

.club-card-head em,
.club-active-badge,
.archived-badge {
  padding: 5px 9px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 16%, var(--surface));
  color: var(--accent);
  font-size: 0.78rem;
  font-style: normal;
  font-weight: 800;
}

.archived-badge {
  background: color-mix(in srgb, var(--muted) 18%, var(--surface));
  color: var(--muted);
}

.club-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 0.9rem;
}

.club-card-meta span {
  padding: 5px 8px;
  border: 1px solid var(--line);
  border-radius: 999px;
}

.club-form-section .band-title,
.club-settings-form > .band .band-title {
  align-items: center;
}

.club-settings-form {
  gap: 18px;
  max-width: 1480px;
  margin-inline: auto;
}

.club-settings-form > .band:first-child > p {
  margin: 0;
  padding: 16px 22px 18px;
  line-height: 1.45;
}

.club-form-section {
  overflow: hidden;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 96%, var(--surface-2)), var(--surface));
}

.club-form-section .band-title {
  min-height: 48px;
  padding: 14px 20px;
}

.club-form-section .band-title span {
  padding-left: 10px;
  color: var(--muted);
  text-align: right;
  line-height: 1.2;
}

.club-form-section > .form-grid,
.club-form-section > .settings-check-grid {
  padding: 20px 22px 22px;
}

.club-form-section > .settings-check-grid {
  margin-top: 0;
}

.club-form-section > .form-grid.compact {
  grid-template-columns: repeat(4, minmax(150px, 1fr));
  gap: 16px 18px;
  align-items: end;
}

.club-form-section > .form-grid label,
.dialog-body .club-form-section > .form-grid label,
.club-manager-card label {
  display: grid;
  gap: 6px;
  min-width: 0;
  line-height: 1.2;
  font-size: 0.78rem;
}

.club-form-section input,
.club-form-section select,
.club-form-section textarea {
  min-height: 32px;
  padding: 6px 9px;
  font-size: 0.88rem;
}

.club-form-section textarea {
  min-height: 66px;
}

.club-form-section input[type="color"] {
  min-height: 34px;
  padding: 4px 7px;
}

.club-form-section label:has(input[name="clubName"]),
.club-form-section label:has(input[name="subtitle"]),
.club-form-section label:has(input[name="disciplines"]),
.club-form-section label:has(input[name="vatMention"]),
.club-form-section label:has(input[name="address"]),
.club-form-section label:has(input[name="address2"]),
.club-form-section label:has(input[name="checkOrder"]),
.club-form-section label:has(input[name="iban"]),
.club-form-section label:has(input[name="numberingFormat"]) {
  grid-column: span 2;
}

.club-form-section label.wide {
  grid-column: 1 / -1;
}

.dialog-body > .form-grid > .club-form-section {
  grid-column: 1 / -1;
}

.dialog-body > .form-grid:has(.club-form-section) {
  display: block;
}

.club-editor-dialog {
  width: min(1120px, calc(100vw - 32px));
}

.club-editor-dialog .dialog-body {
  padding: 18px;
  max-height: min(78vh, 820px);
}

.club-wizard {
  display: grid;
  gap: 14px;
}

.club-wizard-intro {
  display: grid;
  gap: 4px;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: color-mix(in srgb, var(--surface) 86%, transparent);
}

.club-wizard-intro strong {
  font-family: var(--font-title);
  font-size: 1.08rem;
}

.club-wizard-intro span,
.club-wizard-actions span {
  color: var(--muted);
  font-size: 0.9rem;
}

.club-wizard-steps {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;
}

.club-wizard-steps button {
  min-height: 36px;
  padding: 7px 8px;
  white-space: normal;
  line-height: 1.15;
  text-align: center;
}

.club-wizard-steps button.active {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--accent-contrast);
}

.club-wizard-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding-top: 4px;
}

.club-editor-dialog .dialog-footer {
  padding: 12px 16px;
}

.dialog-body .club-form-section {
  margin-bottom: 14px;
  box-shadow: none;
}

.dialog-body .club-form-section > .form-grid.compact {
  grid-template-columns: repeat(3, minmax(130px, 1fr));
  padding: 18px;
  gap: 14px 16px;
}

.dialog-body .club-form-section label:has(input[name="clubName"]),
.dialog-body .club-form-section label:has(input[name="subtitle"]),
.dialog-body .club-form-section label:has(input[name="disciplines"]),
.dialog-body .club-form-section label:has(input[name="vatMention"]),
.dialog-body .club-form-section label:has(input[name="address"]),
.dialog-body .club-form-section label:has(input[name="address2"]),
.dialog-body .club-form-section label:has(input[name="checkOrder"]),
.dialog-body .club-form-section label:has(input[name="iban"]),
.dialog-body .club-form-section label:has(input[name="numberingFormat"]) {
  grid-column: span 2;
}

.club-logo-preview {
  align-self: end;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 58px;
  max-height: 72px;
  padding: 8px;
  border: 1px dashed var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface-2) 50%, transparent);
}

.club-logo-preview img {
  width: auto;
  max-width: 96px;
  max-height: 54px;
  display: block;
  object-fit: contain;
}

.club-manager-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
  padding: 16px;
}

.club-manager-card {
  display: grid;
  gap: 7px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 88%, var(--surface-2));
}

.club-manager-card input,
.club-manager-card textarea {
  min-height: 32px;
  padding: 6px 9px;
}

.club-manager-card textarea {
  min-height: 58px;
}

.club-manager-card h3 {
  margin: 0;
  padding-bottom: 2px;
  font-size: 0.95rem;
}

.compact-check {
  display: inline-flex;
  width: auto;
  margin: 0;
}

.form-actions-sticky {
  position: sticky;
  bottom: 0;
  z-index: 4;
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 94%, transparent);
  backdrop-filter: blur(12px);
}

.club-settings-form .form-actions-sticky {
  margin-top: 6px;
  padding: 14px 18px;
}

.dialog-body .club-manager-grid {
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  padding: 14px;
  gap: 10px;
}

.dialog-body .settings-check-grid {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  padding: 14px;
}

input[type="checkbox"],
:root[data-theme] input[type="checkbox"],
:root[data-theme$="-dark"] input[type="checkbox"],
:root[data-theme="graphite"] input[type="checkbox"],
:root[data-theme="graphite-dark"] input[type="checkbox"],
:root[data-theme="windows"] input[type="checkbox"],
:root[data-theme="windows-dark"] input[type="checkbox"],
:root[data-theme="win11"] input[type="checkbox"],
:root[data-theme="win11-dark"] input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 16px !important;
  min-width: 16px !important;
  max-width: 16px !important;
  height: 16px !important;
  min-height: 16px !important;
  max-height: 16px !important;
  padding: 0 !important;
  margin: 0;
  display: inline-grid;
  place-content: center;
  flex: 0 0 16px;
  border: 1.5px solid var(--line-strong) !important;
  border-radius: 3px !important;
  background: var(--surface) !important;
  box-shadow: none !important;
  cursor: pointer;
  vertical-align: middle;
}

input[type="checkbox"]::before {
  content: "";
  width: 8px;
  height: 8px;
  transform: scale(0);
  transition: transform 0.12s ease;
  clip-path: polygon(14% 44%, 0 58%, 38% 96%, 100% 18%, 84% 4%, 36% 66%);
  background: var(--accent);
}

input[type="checkbox"]:checked::before {
  transform: scale(1);
}

input[type="checkbox"]:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent) 32%, transparent);
  outline-offset: 2px;
}

.settings-check input[type="checkbox"] {
  margin-top: 2px;
}

@media (max-width: 1180px) {
  .club-form-section > .form-grid.compact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .club-form-section label:has(input[name="clubName"]),
  .club-form-section label:has(input[name="subtitle"]),
  .club-form-section label:has(input[name="address2"]),
  .club-form-section label:has(input[name="checkOrder"]),
  .club-form-section label:has(input[name="iban"]),
  .club-form-section label:has(input[name="numberingFormat"]) {
    grid-column: span 1;
  }
}

@media (max-width: 760px) {
  .club-wizard-steps {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .club-form-section > .form-grid.compact,
  .dialog-body .club-form-section > .form-grid.compact {
    grid-template-columns: 1fr;
  }

  .club-form-section label,
  .dialog-body .club-form-section label {
    grid-column: 1 / -1 !important;
  }

  .club-form-section .band-title {
    align-items: flex-start;
    flex-direction: column;
    gap: 4px;
  }

  .club-form-section .band-title span {
    padding-left: 0;
    text-align: left;
  }
}

.invoice-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  padding: 4px 9px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 800;
  background: color-mix(in srgb, var(--surface-2) 72%, var(--accent));
  color: var(--text);
}

.invoice-status.draft {
  background: color-mix(in srgb, var(--surface-2) 82%, #64748b);
}

.invoice-status.issued,
.invoice-status.partial {
  background: color-mix(in srgb, #facc15 28%, var(--surface));
}

.invoice-status.paid {
  background: color-mix(in srgb, #22c55e 24%, var(--surface));
}

.invoice-status.late,
.invoice-status.cancelled {
  background: color-mix(in srgb, #ef4444 24%, var(--surface));
}

.invoice-editor {
  grid-column: 1 / -1;
}

/* Liste « Factures du contact » dans l'éditeur de facture : raccourci voir/réimprimer. */
.contact-invoice-list {
  display: grid;
  gap: 6px;
}
.contact-invoice-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 12px;
  align-items: center;
  padding: 7px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface-2);
}
.contact-invoice-num {
  display: grid;
  line-height: 1.15;
  flex: 1 1 130px;
  min-width: 0;
}
.contact-invoice-num small {
  color: var(--muted);
  font-size: 0.72rem;
}
.contact-invoice-amounts {
  display: inline-flex;
  gap: 12px;
  align-items: baseline;
}
.contact-invoice-row .money {
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  font-weight: 700;
}
.contact-invoice-row .money.due {
  color: var(--accent-3);
}
.contact-invoice-row button {
  margin-left: auto;
}

.invoice-editor-head,
.invoice-summary,
.invoice-payment-list > div {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
}

.invoice-editor-head h3,
.invoice-editor-head p {
  margin: 0;
}

.invoice-editor-head > div:last-child {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.invoice-summary {
  grid-template-columns: repeat(auto-fit, minmax(145px, 1fr));
  margin-top: 12px;
}

.invoice-summary > div {
  display: grid;
  gap: 4px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface-2) 55%, transparent);
}

.invoice-summary span,
.invoice-source-row small,
.invoice-payment-list span {
  color: var(--muted);
}

.invoice-payment-lines {
  display: grid;
  gap: 6px;
}

.invoice-pay-line {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 7px 10px;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: color-mix(in srgb, var(--surface-2) 55%, transparent);
  font-size: 0.88rem;
  cursor: pointer;
}

.invoice-pay-line input {
  width: 18px;
  min-height: 18px;
}

.invoice-pay-line strong {
  font-variant-numeric: tabular-nums;
}

/* Colonne gauche : libellé + détail (Total · déjà réglé). */
.invoice-pay-line-info {
  display: grid;
  gap: 1px;
  min-width: 0;
}
.invoice-pay-line-label {
  font-weight: 650;
  line-height: 1.15;
}
.invoice-pay-line-detail {
  color: var(--muted);
  font-size: 0.76rem;
  line-height: 1.15;
}
/* Colonne droite : « reste à régler » mis en avant. */
.invoice-pay-line-due {
  display: grid;
  justify-items: end;
  gap: 0;
  text-align: right;
  white-space: nowrap;
}
.invoice-pay-line-due small {
  color: var(--muted);
  font-size: 0.64rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.invoice-pay-line-due strong {
  font-variant-numeric: tabular-nums;
  font-size: 1.02rem;
}

/* Ligne déjà entièrement réglée : non sélectionnable, grisée. */
.invoice-pay-line.settled {
  cursor: default;
  opacity: 0.6;
}
.invoice-pay-line.settled .invoice-pay-line-due strong {
  color: var(--ok, #20a464);
  font-weight: 700;
}

.invoice-source-list {
  display: grid;
  gap: 8px;
}

.invoice-source-row {
  display: grid;
  grid-template-columns: auto minmax(82px, auto) minmax(0, 1fr) auto auto;
  gap: 10px;
  align-items: center;
  padding: 9px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 86%, var(--surface-2));
}

.invoice-source-row.already-billed {
  opacity: 0.66;
  background: color-mix(in srgb, var(--surface-2) 72%, #64748b);
}

.invoice-source-type {
  padding: 4px 7px;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 800;
  background: color-mix(in srgb, var(--accent) 16%, var(--surface));
}

.invoice-source-row span:nth-child(3),
.invoice-source-row label {
  min-width: 0;
}

.invoice-source-row small {
  display: block;
  margin-top: 2px;
}

.invoice-custom-head,
.invoice-custom-row {
  display: grid;
  /* 6 colonnes : Libellé · Qté · Prix U · TVA % · Catégorie · supprimer. La 5e colonne (Catégorie)
     manquait, si bien que le select tombait dans la colonne 36px du bouton × (fin de ligne coupée).
     Les colonnes numériques sont assez larges pour les boutons +/- (.number-stepper). */
  grid-template-columns: minmax(150px, 1fr) minmax(96px, 110px) minmax(104px, 130px) minmax(80px, 98px) minmax(124px, 152px) 36px;
  gap: 8px;
  align-items: center;
}

/* Les champs (et leurs steppers +/-) remplissent leur colonne sans la faire déborder. */
.invoice-custom-row > input,
.invoice-custom-row > select,
.invoice-custom-row .number-stepper {
  width: 100%;
  min-width: 0;
}

.invoice-custom-head {
  margin-bottom: 6px;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 800;
}

.invoice-custom-row + .invoice-custom-row {
  margin-top: 8px;
}

.invoice-payment-list {
  display: grid;
  gap: 6px;
}

.invoice-payment-list > div {
  grid-template-columns: minmax(80px, 1fr) auto auto auto;
  padding: 7px 9px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.invoice-payment-actions {
  margin-top: 10px;
  justify-content: flex-start;
}

.invoice-payment-form {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 12px;
}
.invoice-payment-form-head {
  grid-column: 1 / -1;
}
.invoice-payment-form-head h4 {
  margin: 0;
}
/* Option « chèque à encaisser plus tard » : case à cocher horizontale, sur toute la largeur. */
.invoice-cheque-later {
  grid-column: 1 / -1;
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 8px;
  font-weight: 500;
  cursor: pointer;
}
.invoice-cheque-later input {
  width: 18px;
  min-height: 18px;
}

td.due,
.due {
  color: var(--danger);
}

@media (max-width: 760px) {
  .club-cards,
  .club-manager-grid {
    grid-template-columns: 1fr;
  }

  .club-card-head {
    grid-template-columns: 44px minmax(0, 1fr);
  }

  .invoice-source-row,
  .invoice-custom-head,
  .invoice-custom-row,
  .invoice-payment-list > div {
    grid-template-columns: 1fr;
  }
}

/* =====================================================================
   DISPOSITION CLASSIQUE (Phase 0 prototype) — mode sobre / professionnel.
   Axe indépendant du thème : s'active uniquement sous :root[data-layout="classic"].
   Le mode "modern" (défaut) n'est jamais affecté : tout est additif.
   ===================================================================== */
:root[data-layout="classic"] {
  --radius: 3px;
  --shadow: none;
}
/* Police de titre sobre en classique. !important pour battre le style inline posé
   par applyTypographySettings() sur :root (sinon le Lobster décoratif resterait). */
:root[data-layout="classic"] .band-title h2,
:root[data-layout="classic"] .ct-title,
:root[data-layout="classic"] h1,
:root[data-layout="classic"] h2,
:root[data-layout="classic"] h3 {
  font-family: var(--font-body) !important;
}

/* Neutralise les textures décoratives des thèmes (cuir, inox, croquis...) */
:root[data-layout="classic"] body,
:root[data-layout="classic"] .shell,
:root[data-layout="classic"] .sidebar,
:root[data-layout="classic"] .topbar,
:root[data-layout="classic"] .band,
:root[data-layout="classic"] .kpi,
:root[data-layout="classic"] button,
:root[data-layout="classic"] button.primary {
  background-image: none !important;
}

/* Menu de gauche plus sobre */
:root[data-layout="classic"] .sidebar {
  background: var(--surface);
  border-right: 1px solid var(--line-strong);
}
:root[data-layout="classic"] .nav-submenu,
:root[data-layout="classic"] .sidebar a,
:root[data-layout="classic"] .sidebar button {
  border-radius: 3px;
  box-shadow: none;
}

/* Barre du haut plus sobre (pas de flou translucide) */
:root[data-layout="classic"] .topbar {
  background: var(--surface);
  backdrop-filter: none;
  border-bottom: 1px solid var(--line-strong);
}

/* Cartes / panneaux aplatis */
:root[data-layout="classic"] .band,
:root[data-layout="classic"] .kpi {
  box-shadow: none;
  border-radius: 3px;
}
:root[data-layout="classic"] .kpi {
  padding: 10px 12px;
}
:root[data-layout="classic"] .kpi strong {
  font-size: 1.3rem;
}

/* Boutons plus standards */
:root[data-layout="classic"] button {
  border-radius: 3px;
  min-height: 32px;
  box-shadow: none;
}
:root[data-layout="classic"] button:hover {
  transform: none;
}
:root[data-layout="classic"] button.primary {
  background: var(--accent);
  color: var(--on-accent);
  border-color: var(--accent);
}

/* Tableaux classiques : bordures complètes, en-têtes sobres, lignes alternées, plus denses */
:root[data-layout="classic"] table {
  border-collapse: collapse;
  border-spacing: 0;
}
:root[data-layout="classic"] th,
:root[data-layout="classic"] td {
  border: 1px solid var(--line);
  padding: 5px 8px;
}
:root[data-layout="classic"] th {
  background: var(--surface-2);
  color: var(--ink);
  text-transform: none;
  letter-spacing: 0;
  font-size: 0.8rem;
  font-weight: 700;
}
:root[data-layout="classic"] tbody tr:nth-child(even) td {
  background: color-mix(in srgb, var(--surface) 93%, var(--ink) 4%);
}

/* Titres un cran plus sobres */
:root[data-layout="classic"] .band-title h2,
:root[data-layout="classic"] h1,
:root[data-layout="classic"] h2 {
  letter-spacing: 0;
}


/* =====================================================================
   MODE CLASSIQUE — le menu de gauche devient une barre de menus EN HAUT,
   avec sous-menus déroulants. N'apparaît qu'en data-layout="classic".
   ===================================================================== */
.shell-classic-top {
  min-height: 100vh;
  background: var(--bg);
}
.shell-classic-top .content { min-width: 0; }
/* Le menu est intégré DANS la barre du haut rétractable : il se cache/affiche
   avec elle (toggle-topbar). Pleine largeur, posé en tête de la barre. */
.topbar-with-menu { padding-top: 0; }
.topbar-with-menu > .topmenu {
  margin: 0 -22px 4px;
  border-bottom: 1px solid var(--line-strong);
}

.topmenu {
  display: flex;
  align-items: stretch;
  gap: 0;
  min-height: 38px;
  background: var(--surface);
  border-bottom: 1px solid var(--line-strong);
  padding: 0 6px;
  font-family: var(--font-body);
}
.topmenu-brand {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 12px 0 2px;
  margin-right: 4px;
  border-right: 1px solid var(--line);
  font-size: 0.9rem;
  white-space: nowrap;
}
.topmenu-brand img { width: 22px; height: 22px; object-fit: contain; }
.topmenu-items { display: flex; align-items: stretch; flex-wrap: wrap; }

/* Boutons directs (pages simples : Accueil, À faire, Recherche…) */
.topmenu-items > button {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--ink);
  border-radius: 0;
  min-height: 38px;
  padding: 0 12px;
  font-size: 0.88rem;
  cursor: default;
  white-space: nowrap;
}
.topmenu-items > button:hover { background: color-mix(in srgb, var(--accent) 12%, var(--surface)); }
.topmenu-items > button.active { background: color-mix(in srgb, var(--accent) 18%, var(--surface)); font-weight: 600; }
.topmenu .nav-icon { display: inline-flex; }
.topmenu .nav-icon svg { width: 16px; height: 16px; }

/* Groupes déroulants (Adhérents, Activités, Finances…) */
.topmenu-group { position: relative; display: flex; }
.topmenu-group > summary {
  list-style: none;
  cursor: default;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 38px;
  padding: 0 12px;
  font-size: 0.88rem;
  white-space: nowrap;
  border: 1px solid transparent;
}
.topmenu-group > summary::-webkit-details-marker { display: none; }
.topmenu-group > summary::marker { content: ""; }
.topmenu-group > summary:hover { background: color-mix(in srgb, var(--accent) 12%, var(--surface)); }
.topmenu-group[open] > summary {
  background: var(--surface);
  border-color: var(--line-strong);
  border-bottom-color: var(--surface);
  position: relative;
  z-index: 61;
}
.topmenu-caret { font-size: 0.7rem; color: var(--muted); margin-left: 2px; }
.topmenu-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: -1px;
  min-width: 230px;
  background: var(--surface);
  border: 1px solid var(--line-strong);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.18);
  z-index: 60;
  padding: 3px;
  display: flex;
  flex-direction: column;
}
.topmenu-dropdown button {
  display: flex;
  align-items: center;
  gap: 9px;
  text-align: left;
  width: 100%;
  border: 0;
  background: transparent;
  color: var(--ink);
  border-radius: 0;
  min-height: auto;
  padding: 6px 14px;
  font-size: 0.86rem;
  cursor: default;
  white-space: nowrap;
}
.topmenu-dropdown button:hover { background: var(--accent); color: var(--on-accent); }
.topmenu-dropdown button.active { font-weight: 600; }

/* Surcharge la règle générique des boutons classiques (Phase 0, spécificité (0,2,1))
   pour des onglets de menu vraiment plats. */
:root[data-layout="classic"] .topmenu-items > button,
:root[data-layout="classic"] .topmenu-group > summary {
  border: 1px solid transparent;
  border-radius: 0;
  min-height: 38px;
  box-shadow: none;
}
:root[data-layout="classic"] .topmenu-group[open] > summary {
  border-color: var(--line-strong);
  border-bottom-color: var(--surface);
}
:root[data-layout="classic"] .topmenu-dropdown button {
  border: 0;
  border-radius: 0;
  min-height: auto;
  box-shadow: none;
}

/* Barre de menus CONDENSÉE : tient sur une seule ligne à la largeur par défaut.
   Texte seul dans la barre (les icônes restent dans les déroulés). */
.topmenu { min-height: 30px; flex-wrap: nowrap; }
.topmenu-items { flex: 1 1 auto; min-width: 0; flex-wrap: nowrap; }
.topmenu-brand { flex: 0 1 auto; min-width: 0; font-size: 0.8rem; padding: 0 9px 0 2px; margin-right: 2px; }
.topmenu-brand img { width: 18px; height: 18px; }
.topmenu-brand strong { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.topmenu-items > button .nav-icon,
.topmenu-group > summary .nav-icon { display: none; }
.topmenu-caret { margin-left: 1px; }
:root[data-layout="classic"] .topmenu-items > button,
:root[data-layout="classic"] .topmenu-group > summary {
  min-height: 30px;
  padding: 0 9px;
  font-size: 0.82rem;
}

/* Les groupes du menu sont des <details> : neutraliser le style "encadré" générique
   (border + padding 10px + fond blanc) qui gonflait la barre et créait des cadres. */
.topmenu-group {
  border: 0;
  border-radius: 0;
  padding: 0;
  background: transparent;
}
.topmenu-group > summary { font-weight: 500; }
.topmenu-items > button { font-weight: 500; }

/* Onglet de groupe actif (on est sur une de ses pages) */
.topmenu-group > summary.active {
  background: color-mix(in srgb, var(--accent) 18%, var(--surface));
  font-weight: 600;
}

/* Le déroulé du menu doit pouvoir dépasser SOUS la barre du haut : un overflow:hidden
   sur .topbar coupait la partie basse des menus -> le contenu passait devant. */
:root[data-layout="classic"] .topbar-with-menu { overflow: visible; }

/* Badge "séance à remplacer" cliquable (accès direct au traitement coach/salle) */
.replace-badge { cursor: pointer; }
.replace-badge:hover { filter: brightness(0.92); text-decoration: underline; }
.replace-badge:focus-visible { outline: 2px solid var(--accent); outline-offset: 1px; }

/* =====================================================================
   PANNEAU D'AIDE LATÉRAL — consultable sans quitter la page courante.
   Réutilise renderHelp() (aucune duplication de texte d'aide).
   ===================================================================== */
.help-panel {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: min(440px, 92vw);
  background: var(--surface);
  color: var(--ink);
  border-left: 1px solid var(--line);
  box-shadow: -10px 0 30px rgba(0, 0, 0, 0.14);
  z-index: 200;
  display: flex;
  flex-direction: column;
}
.help-panel-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-bottom: 1px solid var(--line);
  background: var(--surface-2);
}
.help-panel-head strong { flex: 1 1 auto; font-size: 1rem; }
.help-panel-link { min-height: 30px; padding: 0 10px; font-size: 0.82rem; border-radius: var(--radius); }
.help-panel-close { min-height: 30px; }
.help-panel-body {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  padding: 14px 16px;
}
/* Version compacte de renderHelp() dans le panneau : pas de héros ni de sommaire 2 colonnes */
.help-panel .help-hero,
.help-panel .help-toc { display: none; }
/* Neutralise le scroll/clip INTERNE de l'aide (page pleine) : c'est le PANNEAU qui défile. */
.help-panel .help-page {
  display: block;
  height: auto;
  overflow: visible;
}
.help-panel .help-layout {
  display: block;
  overflow: visible;
  height: auto;
  max-height: none;
}
.help-panel .help-content {
  display: grid;
  gap: 12px;
  overflow: visible;
  height: auto;
  max-height: none;
  min-height: 0;
  padding-right: 0;
}
.help-panel .help-section { margin: 0; }

/* Grand écran : on pousse le contenu pour ne rien cacher derrière le panneau */
@media (min-width: 1000px) {
  html[data-help-panel="open"] #app .shell,
  html[data-help-panel="open"] #app .shell-classic-top {
    padding-right: min(440px, 92vw);
  }
}

/* ===== Impression (Cmd+P direct) — filet de sécurité, ne s'applique qu'à l'impression =====
   L'impression « propre » du planning passe par le bouton Imprimer (fenêtre dédiée, tableau
   par semaine). Ce bloc rend une impression directe au moins lisible : chrome masqué, fond
   blanc, texte noir, sans ombres ni textures. N'affecte jamais l'affichage écran. */
@media print {
  body, #app, .shell, .shell-classic-top, .content, .view, .band {
    background: #fff !important;
    color: #000 !important;
  }
  .sidebar, .topbar, .topbar-actions, .app-toolbar, .help-panel, .topbar-show-btn,
  .planning-week-nav, .planning-filters, .pwn-controls, .pwn-weeks, .segmented,
  .course-actions, .pws-date-btn, .toolbar, .save-banner, .context-menu, .band-title button {
    display: none !important;
  }
  #app .shell, .shell-classic-top { padding: 0 !important; }
  html[data-help-panel="open"] #app .shell,
  html[data-help-panel="open"] .shell-classic-top { padding-right: 0 !important; }
  * { box-shadow: none !important; text-shadow: none !important; }
  .band { border: 0 !important; margin: 0 0 10px !important; }
  .planning-week-block + .planning-week-block { border-top: 2px solid #000; }
  .course-line, .planning-week-slot { background: #fff !important; border: 1px solid #999 !important; }
}

/* ===== Réduction des grandes fenêtres : bouton — dans l'en-tête + barre des fenêtres réduites ===== */
.dialog-header-actions { display: flex; align-items: center; gap: 4px; }
.dialog-header-actions button.icon { line-height: 1; }

.mgc-min-bar {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 50;
  display: none;
  gap: 8px;
  align-items: center;
  padding: 6px 10px;
  background: var(--surface, #fff);
  border-top: 1px solid var(--line, #d9e2ec);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.mgc-min-bar.is-visible { display: flex; }
.mgc-min-chip {
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
  max-width: 260px;
  background: var(--surface-2, #eef2f6);
  border: 1px solid var(--line, #d9e2ec);
  border-radius: 999px;
  padding: 2px 4px 2px 6px;
}
.mgc-min-open {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  max-width: 220px;
  border: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  font-size: 13px;
  cursor: pointer;
  padding: 4px 6px;
  border-radius: 999px;
}
.mgc-min-open:hover { background: var(--line, #e4e4e4); }
.mgc-min-emoji { flex: 0 0 auto; }
.mgc-min-label { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 180px; }
.mgc-min-close {
  flex: 0 0 auto;
  border: 0;
  background: transparent;
  color: inherit;
  cursor: pointer;
  font-size: 12px;
  line-height: 1;
  padding: 4px 7px;
  border-radius: 999px;
}
.mgc-min-close:hover { background: var(--line, #e4e4e4); }
.mgc-min-open:focus-visible, .mgc-min-close:focus-visible { outline: 2px solid var(--accent, #2563eb); outline-offset: 1px; }
@media (max-width: 640px) {
  .mgc-min-chip { max-width: 180px; }
  .mgc-min-label { max-width: 110px; }
}
@media print { .mgc-min-bar { display: none !important; } }

/* =====================================================================
   GRAPHITE en disposition CLASSIQUE : conserver l'arrondi du mode moderne.
   Ciblé STRICTEMENT sur graphite / graphite-dark + data-layout="classic".
   N'affecte ni les autres thèmes, ni le mode moderne. --shadow:none conservé.
   ===================================================================== */
:root[data-layout="classic"][data-theme="graphite"],
:root[data-layout="classic"][data-theme="graphite-dark"] {
  --radius: 11px;
}
/* Cartes / panneaux / KPI : arrondi moderne (annule le 3px en dur du classique) */
:root[data-layout="classic"][data-theme="graphite"] .band,
:root[data-layout="classic"][data-theme="graphite"] .kpi,
:root[data-layout="classic"][data-theme="graphite-dark"] .band,
:root[data-layout="classic"][data-theme="graphite-dark"] .kpi {
  border-radius: var(--radius);
}
/* Boutons : radius bouton moderne (7px) */
:root[data-layout="classic"][data-theme="graphite"] button,
:root[data-layout="classic"][data-theme="graphite-dark"] button {
  border-radius: 7px;
}
/* Barre latérale + sous-menus arrondis */
:root[data-layout="classic"][data-theme="graphite"] .nav-submenu,
:root[data-layout="classic"][data-theme="graphite"] .sidebar a,
:root[data-layout="classic"][data-theme="graphite"] .sidebar button,
:root[data-layout="classic"][data-theme="graphite-dark"] .nav-submenu,
:root[data-layout="classic"][data-theme="graphite-dark"] .sidebar a,
:root[data-layout="classic"][data-theme="graphite-dark"] .sidebar button {
  border-radius: 7px;
}
/* La barre de menu du haut reste plate (inchangée) : on ré-affirme 0 pour qu'elle
   ne soit pas arrondie par le sélecteur "button" ci-dessus (spécificité supérieure). */
:root[data-layout="classic"][data-theme="graphite"] .topmenu-items > button,
:root[data-layout="classic"][data-theme="graphite"] .topmenu-group > summary,
:root[data-layout="classic"][data-theme="graphite"] .topmenu-dropdown button,
:root[data-layout="classic"][data-theme="graphite-dark"] .topmenu-items > button,
:root[data-layout="classic"][data-theme="graphite-dark"] .topmenu-group > summary,
:root[data-layout="classic"][data-theme="graphite-dark"] .topmenu-dropdown button {
  border-radius: 0;
}

/* ===== Classique : garder le menu fin du haut visible quand la barre d'outils est repliée =====
   La règle générique « .content.topbar-hidden > .topbar { display:none } » masque tout le header
   (y compris le .topmenu en classique). On la surcharge UNIQUEMENT en classique (.shell-classic-top)
   pour ne masquer que le titre + la barre d'outils, et garder le menu fin affiché. */
.shell-classic-top .content.topbar-hidden > .topbar {
  display: block;
  padding: 0;
  background: none;
  backdrop-filter: none;
  border-bottom: 0;
}
.shell-classic-top .content.topbar-hidden > .topbar > :not(.topmenu) {
  display: none;
}
.shell-classic-top .content.topbar-hidden > .topbar > .topmenu {
  margin: 0;
}

/* ===== Variante B — Barre du haut compacte (lot UX menu du haut) =====
   Override visuel : barre plus fine, titre + actions sur une ligne (wrap responsive),
   groupes sans cadre (regroupement par l'espacement), recherche/Enregistrer allégés.
   Aucune logique modifiée ; toutes les actions/cibles conservées (>=32px). */
.topbar {
  padding: 8px 16px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 14px;
}
.topbar-with-menu > .topmenu { margin: 0 -16px 4px; }   /* aligner le bleed sur le nouveau padding */
.topbar > .topmenu { flex: 1 1 100%; }                  /* menu classique : sa propre ligne */
.topbar-title-row { flex: 0 1 auto; gap: 8px; }
.topbar h1 { font-size: 1.2rem; }
.topbar-actions { flex: 1 1 auto; width: auto; justify-content: flex-end; gap: 6px; }
.app-toolbar { gap: 6px 12px; justify-content: flex-end; }   /* col-gap 12 => groupes lisibles sans cadre */
.app-toolbar .tool-group { gap: 2px; }
/* Groupes sans cadre : neutralise aussi les cadres dessinés par certains thèmes
   (graphite/win11) -> spécificité [data-theme] pour gagner sur ces règles. */
:root[data-theme] .app-toolbar .tool-group {
  border: none;
  background: none;
  box-shadow: none;
  border-radius: 0;
  padding: 0;
}
.tool-button {
  min-width: 32px;
  min-height: 32px;
  padding: 0 7px;
  border-radius: 8px;
}
.sidebar-toggle { width: 32px; min-height: 32px; font-size: 1rem; border-radius: 8px; }
.global-search-input { height: 32px; min-width: 120px; max-width: 190px; }
.search-tool-group { min-width: auto; }
.save-button { min-height: 32px; padding: 0 12px; }
.save-state {
  font-size: 0.72rem;
  max-width: 160px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
/* Mode « texte sous les icônes » conservé, en version plus compacte. */
.app-toolbar.show-labels .tool-button { min-width: 52px; min-height: 44px; }
/* Repli responsive : actions alignées à gauche quand elles passent sous le titre. */
@media (max-width: 1024px) {
  .topbar-actions, .app-toolbar { justify-content: flex-start; }
}
@media (max-width: 560px) {
  .save-state { display: none; }
  .global-search-input { max-width: 140px; }
}
/* ===== fin Variante B ===== */

/* ===== Boutons sauvegarde JSON en icônes discrètes (lot UX) ===== */
.backup-io { display: flex; gap: 8px; }
.backup-io-btn {
  flex: 1 1 auto;
  min-height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}
.backup-io-btn .tool-icon { width: 18px; height: 18px; }
/* Libellé conservé pour l'accessibilité/recherche, masqué visuellement (rendu icône). */
.backup-io-label {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}
/* ===== fin sauvegarde JSON icônes ===== */

/* ===== Enregistrer sur la ligne du titre (gain de hauteur) ===== */
/* Mode classique : titre + barre d'outils sur la même ligne (comme le mode moderne). */
.shell-classic-top .topbar-title-row { flex: 0 1 auto; }
.topbar-title-row h1 { flex: 0 1 auto; }
.topbar-title-row .save-group { margin-left: auto; flex: 0 0 auto; }
/* Mode moderne : Enregistrer déplacé dans la barre latérale (sous Exporter/Importer). */
.backup-save-btn { width: 100%; justify-content: center; }
.backup-save-state { font-size: 0.72rem; color: var(--muted); text-align: center; max-width: none; white-space: normal; }
/* Le groupe save n'est plus dans .app-toolbar : on le rend borderless comme les autres,
   y compris quand un thème (graphite/win11) encadre les .tool-group. */
:root[data-theme] .topbar-title-row .save-group {
  border: none;
  background: none;
  box-shadow: none;
  border-radius: 0;
  padding: 0;
}
/* ===== fin Enregistrer sur la ligne du titre ===== */

/* ===== Boutons d'action de la barre : plats (sans cadre) sur tous les thèmes ===== */
:root[data-theme] .app-toolbar .tool-button {
  border-color: transparent;
  background: transparent;
  box-shadow: none;
}
:root[data-theme] .app-toolbar .tool-button:hover {
  background: var(--surface-2);
}
/* ===== fin boutons plats ===== */

/* ===== Enregistrement : petit bouton disquette dans la barre d'outils (les 2 modes) =====
   Le statut d'enregistrement devient un message accessible (aria-live) masqué visuellement,
   pour garder la barre discrète. ===== */
.save-state {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}
/* ===== fin ===== */

/* ===== États vides : occuper toute la largeur quand placés dans une grille de cartes
   (sinon l'état vide tombe dans la 1re colonne et apparaît collé à gauche). ===== */
.assistant-empty { grid-column: 1 / -1; }
/* ===== fin ===== */

/* ===== Fichette « Le reste est en ordre » — présentation soignée ===== */
.vigilance-green-ico { display: inline-flex; vertical-align: -4px; margin-right: 7px; color: var(--success); }
.vigilance-green-ico svg { width: 20px; height: 20px; }
.vigilance-green {
  list-style: none; margin: 0; padding: 14px 18px 18px;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(248px, 1fr)); gap: 10px 24px;
}
.vigilance-green li {
  display: flex; align-items: flex-start; gap: 9px;
  font-weight: 700; line-height: 1.4;
  color: color-mix(in srgb, var(--success) 45%, var(--ink));
}
.vigilance-green li::before {
  content: ""; flex: none; width: 18px; height: 18px; margin-top: 1px;
  background: var(--success);
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><path d='M5 13l4 4L19 7'/></svg>") center / 15px no-repeat;
  mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><path d='M5 13l4 4L19 7'/></svg>") center / 15px no-repeat;
}
/* ===== fin fichette verte ===== */

/* ===== Corps de bande : marge interne (sinon le texte est collé au bord, ex. « Paiements dus » vide) ===== */
.band-body { padding: 14px 16px; }
/* ===== fin ===== */
