/* ── Google Fonts ────────────────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=Manrope:wght@600;700;800&display=swap');

/* ── Variables ──────────────────────────────────────────────────────────────── */
:root {
  --bg:          #F5F5F5;
  --rouge:       #B9003A;
  --rouge-dark:  #8e002c;
  --rouge-light: #fce8ee;
  --accent2:     #033c73;
  --text:        #1F1F1F;
  --text-muted:  #545454;
  --border:      #EBEBEB;
  --white:       #ffffff;
  --shadow:      0 1px 4px rgba(0,0,0,.10);
  --radius:      8px;
  --col-nouveau:    #B9003A;
  --col-en_cours:   #c87000;
  --col-cloture:    #1a7a45;
}

/* ── Reset ──────────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 15px; }
body {
  font-family: 'Inter', system-ui, sans-serif;
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
  overflow-x: hidden;
}
h1, h2, h3, h4 { font-family: 'Manrope', system-ui, sans-serif; }
a { color: var(--rouge); text-decoration: none; }
a:hover { text-decoration: underline; }
button { cursor: pointer; font: inherit; }
input, select, textarea { font: inherit; }

/* ── Topbar ─────────────────────────────────────────────────────────────────── */
.topbar {
  background: var(--rouge);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 1.5rem;
  height: 56px;
  box-shadow: 0 2px 8px rgba(185,0,58,.35);
  position: sticky;
  top: 0;
  z-index: 100;
}
.topbar__brand {
  display: flex;
  align-items: center;
  gap: .65rem;
  font-family: 'Manrope', sans-serif;
  font-weight: 800;
  font-size: 1.05rem;
  letter-spacing: .01em;
}
.topbar__brand img {
  height: 34px;
  width: 34px;
  object-fit: contain;
  border-radius: 6px;
  background: #fff;
  padding: 2px;
}
.topbar__user { font-size: .83rem; opacity: .92; display: flex; align-items: center; gap: .75rem; }
.topbar__user a { color: #fff; }
.btn-logout {
  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.35);
  color: #fff;
  border-radius: 5px;
  padding: .25rem .8rem;
  font-size: .8rem;
  font-weight: 600;
  transition: background .15s;
}
.btn-logout:hover { background: rgba(255,255,255,.28); }

/* ── Intranet : navigation simple ───────────────────────────────────────────── */
.intranet-subnav {
  background: var(--white);
  border-bottom: 1px solid var(--border);
  padding: .6rem 1.5rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .35rem .15rem;
}
.intranet-subnav__link {
  color: var(--text);
  font-size: .88rem;
  font-weight: 600;
  padding: .4rem .75rem;
  border-radius: 5px;
  text-decoration: none !important;
}
.intranet-subnav__link:hover {
  background: var(--bg);
  color: var(--rouge);
}
.intranet-subnav__link.is-current {
  background: var(--rouge-light);
  color: var(--rouge);
}
.intranet-subnav__link--disabled {
  color: #8a8a8a;
  background: #f7f7f7;
  cursor: not-allowed;
}
.intranet-subnav__link--disabled:hover {
  color: #8a8a8a;
  background: #f7f7f7;
}
.intranet-subnav__sep {
  color: var(--border);
  font-weight: 300;
  user-select: none;
  padding: 0 .15rem;
  font-size: .95rem;
}
@media (max-width: 520px) {
  .topbar {
    height: auto;
    min-height: 58px;
    padding: .65rem 1rem;
    align-items: flex-start;
    gap: .65rem;
  }
  .topbar__brand {
    flex: 1 1 140px;
    min-width: 0;
    font-size: 1rem;
    line-height: 1.15;
  }
  .topbar__user {
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: .35rem .55rem;
    max-width: 48%;
    line-height: 1.2;
  }
  #topbarUserName { max-width: 5.4rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .btn-logout { padding: .32rem .65rem; }
  .intranet-subnav__sep { display: none; }
  .intranet-subnav { gap: .25rem; }
}

/* ── Login ──────────────────────────────────────────────────────────────────── */
.login-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  background: var(--bg);
}
.login-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 2.5rem 2rem;
  width: 100%;
  max-width: 390px;
  box-shadow: 0 4px 24px rgba(0,0,0,.09);
}
.login-card__logo {
  text-align: center;
  margin-bottom: 1.5rem;
}
.login-card__logo img {
  height: 72px;
  width: 72px;
  object-fit: contain;
}
.login-card__name {
  font-family: 'Manrope', sans-serif;
  font-weight: 800;
  font-size: 1rem;
  color: var(--rouge);
  text-align: center;
  margin-top: .4rem;
  letter-spacing: .02em;
  text-transform: uppercase;
}
.login-card h1 {
  font-family: 'Manrope', sans-serif;
  font-size: 1.35rem;
  font-weight: 800;
  margin-bottom: .35rem;
  text-align: center;
  color: var(--text);
}
.login-card__subtitle {
  font-size: .88rem;
  color: var(--text-muted);
  text-align: center;
  margin-bottom: 1.35rem;
  line-height: 1.45;
}
.form-group { margin-bottom: 1rem; }
.form-group label {
  display: block;
  font-size: .78rem;
  font-weight: 600;
  margin-bottom: .3rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .05em;
}
.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: .55rem .8rem;
  border: 1px solid var(--border);
  border-radius: 5px;
  background: var(--white);
  color: var(--text);
  transition: border-color .15s;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline: none;
  border-color: var(--rouge);
  box-shadow: 0 0 0 3px rgba(185,0,58,.10);
}
.form-error { color: #c0392b; font-size: .83rem; margin-top: .4rem; display: none; }
.form-error.show { display: block; }

/* ── Buttons ────────────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .5rem 1.1rem;
  border-radius: 5px;
  font-size: .88rem;
  font-weight: 600;
  border: none;
  transition: background .15s, opacity .15s;
}
.btn-primary { background: var(--rouge); color: #fff; }
.btn-primary:hover { background: var(--rouge-dark); }
.btn-secondary { background: var(--white); color: var(--rouge); border: 1px solid var(--rouge); }
.btn-secondary:hover { background: var(--rouge-light); }
.btn-danger { background: #b22020; color: #fff; }
.btn-danger:hover { background: #8e1a1a; }
.btn-sm { padding: .3rem .75rem; font-size: .8rem; }
.btn-full { width: 100%; justify-content: center; }
.btn:disabled { opacity: .5; cursor: not-allowed; }

/* ── Kanban toolbar ──────────────────────────────────────────────────────────── */
.kanban-toolbar {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) auto;
  align-items: end;
  gap: .85rem 1.25rem;
  padding: 1.05rem 1.5rem;
  border-bottom: 1px solid var(--border);
  background: var(--white);
  margin-bottom: 1.25rem;
}
.kanban-toolbar__main {
  display: flex;
  align-items: end;
  gap: 1.25rem;
  min-width: 0;
}
.kanban-toolbar__title {
  font-family: 'Manrope', sans-serif;
  font-weight: 800;
  font-size: 1.1rem;
  color: var(--text);
  line-height: 1.2;
  padding-bottom: .35rem;
  white-space: nowrap;
}
.kanban-toolbar__actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: .45rem;
}
.filter-assignee {
  display: inline-flex;
  flex-direction: column;
  gap: .25rem;
  min-width: 170px;
}
.filter-assignee label {
  font-size: .72rem;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.filter-assignee select {
  width: 100%;
  min-height: 36px;
  padding: .45rem 2rem .45rem .65rem;
  border: 1px solid var(--border);
  border-radius: 5px;
  background: var(--white);
  font-size: .88rem;
}
.filter-assignee select:focus {
  outline: none;
  border-color: var(--rouge);
  box-shadow: 0 0 0 3px rgba(185,0,58,.1);
}

/* ── Kanban board ────────────────────────────────────────────────────────────── */
.kanban-board {
  display: grid;
  grid-template-columns: minmax(340px, 1.2fr) minmax(320px, 1fr) minmax(340px, .95fr);
  gap: 1rem;
  padding: 0 1.5rem 2rem;
  align-items: start;
}
@media (max-width: 1180px) {
  .kanban-toolbar { grid-template-columns: 1fr; }
  .kanban-toolbar__actions { justify-content: flex-start; }
  .kanban-board { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); }
  .kanban-col--cloture { grid-column: 1 / -1; }
  .kanban-col__body--cloture {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    align-items: start;
  }
  .archives-panel { grid-column: 1 / -1; }
}
@media (max-width: 640px) {
  .kanban-toolbar {
    padding: 1rem;
    gap: .9rem;
  }
  .kanban-toolbar__main {
    flex-direction: column;
    align-items: stretch;
    gap: .7rem;
  }
  .kanban-toolbar__title {
    padding-bottom: 0;
    white-space: normal;
  }
  .kanban-toolbar__actions,
  #mailOpsToolbar {
    display: grid;
    grid-template-columns: 1fr 1fr;
    width: 100%;
    gap: .45rem;
  }
  .kanban-toolbar__actions .btn,
  #mailOpsToolbar .btn {
    justify-content: center;
    min-height: 36px;
    padding-left: .55rem;
    padding-right: .55rem;
  }
  .kanban-toolbar__actions {
    display: flex;
    flex-direction: column;
    align-items: stretch;
  }
  .btn-refresh { grid-column: 1 / -1; }
  .kanban-board {
    grid-template-columns: 1fr;
    padding: 0 1rem 1.5rem;
  }
  .kanban-col--cloture { grid-column: auto; }
  .kanban-col__body--cloture { display: flex; }
}

.kanban-col {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  min-height: 200px;
  box-shadow: var(--shadow);
}
.kanban-col.drag-over { box-shadow: 0 0 0 2px var(--rouge); }

.kanban-col__header {
  padding: .65rem 1rem;
  font-family: 'Manrope', sans-serif;
  font-weight: 700;
  font-size: .82rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: #fff;
}
.kanban-col__header.nouveau    { background: var(--col-nouveau); }
.kanban-col__header.en_cours   { background: var(--col-en_cours); }
.kanban-col__header.cloture    { background: var(--col-cloture); }
.sidebar-junk__hint { font-size: .78rem; color: var(--text-muted); margin: 0 0 .5rem; line-height: 1.35; }
.kanban-col__count {
  background: rgba(255,255,255,.22);
  border-radius: 12px;
  padding: .1rem .5rem;
  font-size: .78rem;
}
.kanban-col__body {
  padding: .65rem;
  display: flex;
  flex-direction: column;
  gap: .6rem;
  min-height: 100px;
}
.kanban-col__body--cloture {
  max-height: min(72vh, 920px);
  overflow-y: auto;
  gap: .65rem;
}
.cloture-fold {
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--bg);
  overflow: hidden;
}
.cloture-fold__summary {
  cursor: pointer;
  padding: .55rem .75rem;
  font-size: .8rem;
  font-weight: 700;
  font-family: 'Manrope', sans-serif;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: var(--text);
}
.cloture-fold__summary::-webkit-details-marker { display: none; }
.cloture-fold__summary::after {
  content: '▾';
  font-size: .7rem;
  opacity: .55;
}
.cloture-fold[open] .cloture-fold__summary::after { content: '▴'; }
.cloture-fold__badge {
  background: rgba(185,0,58,.12);
  color: var(--rouge);
  border-radius: 10px;
  padding: .05rem .45rem;
  font-size: .75rem;
}
.cloture-fold__cards {
  padding: 0 .35rem .5rem;
  display: flex;
  flex-direction: column;
  gap: .45rem;
}
.encours-mine { min-height: .5rem; }
.encours-fold {
  margin-top: .65rem;
  border-top: 1px dashed var(--border);
  padding-top: .45rem;
}
.encours-fold__summary {
  cursor: pointer;
  font-size: .82rem;
  font-weight: 700;
  color: var(--text-muted);
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .35rem .15rem;
  user-select: none;
}
.encours-fold__summary::-webkit-details-marker { display: none; }
.encours-fold__summary::after { content: '▾'; font-size: .75rem; opacity: .7; }
.encours-fold[open] .encours-fold__summary::after { content: '▴'; }
.encours-fold__badge {
  background: #eee;
  color: var(--text-muted);
  border-radius: 10px;
  padding: .05rem .45rem;
  font-size: .72rem;
  font-weight: 700;
}
.encours-fold__cards {
  padding: .35rem .15rem .25rem;
  display: flex;
  flex-direction: column;
  gap: .45rem;
}
#mailOpsToolbar { display: inline-flex; flex-wrap: wrap; gap: .35rem; align-items: center; }
@media (max-width: 640px) {
  #mailOpsToolbar {
    display: grid;
    grid-template-columns: 1fr 1fr;
    width: 100%;
    gap: .45rem;
  }
}
.ticket-card__closed {
  font-size: .74rem;
  color: var(--col-cloture);
  font-weight: 600;
}

.archives-panel {
  margin-top: .15rem;
  padding: 1rem 1.1rem 1.1rem;
  background: linear-gradient(165deg, #faf8f9 0%, var(--white) 45%);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: 0 2px 12px rgba(0,0,0,.06);
}
.archives-panel__head { margin-bottom: .85rem; }
.archives-panel__title {
  font-family: 'Manrope', sans-serif;
  font-size: .95rem;
  font-weight: 800;
  color: var(--text);
  margin: 0 0 .2rem;
}
.archives-panel__hint {
  font-size: .8rem;
  color: var(--text-muted);
  line-height: 1.4;
  margin: 0;
}
.archives-panel__micro {
  font-size: .72rem;
  color: var(--text-muted);
  margin: .65rem 0 0;
  line-height: 1.35;
}
.archives-panel__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .65rem .75rem;
  align-items: end;
}
.archives-field--grow { grid-column: 1 / -1; }
.archives-submit {
  grid-column: 1 / -1;
  justify-content: center;
}
.archives-field {
  display: flex;
  flex-direction: column;
  gap: .25rem;
  min-width: 0;
}
.archives-field__label {
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-muted);
}
.archives-input {
  padding: .5rem .65rem;
  border: 1px solid var(--border);
  border-radius: 5px;
  font-size: .86rem;
  background: var(--white);
}
.archives-input:focus {
  outline: none;
  border-color: var(--rouge);
  box-shadow: 0 0 0 3px rgba(185,0,58,.1);
}
.archives-submit { padding: .5rem 1.2rem; }
.archives-results {
  margin-top: 1rem;
  border-top: 1px solid var(--border);
  padding-top: .75rem;
}
.archives-results__bar {
  font-size: .82rem;
  color: var(--text-muted);
  margin-bottom: .5rem;
}
.archives-results__scroll {
  max-height: 340px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: .45rem;
  padding-right: .15rem;
}
.archives-empty {
  text-align: center;
  padding: 1.25rem;
  color: var(--text-muted);
  font-size: .88rem;
}
.ticket-card--compact {
  border-left-width: 2px;
}

/* ── Ticket card ─────────────────────────────────────────────────────────────── */
.ticket-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-left: 3px solid var(--rouge);
  border-radius: 6px;
  padding: .8rem .85rem;
  cursor: grab;
  transition: box-shadow .15s, transform .1s;
  user-select: none;
}
.ticket-card:hover {
  box-shadow: 0 3px 12px rgba(0,0,0,.12);
  transform: translateY(-1px);
}
.ticket-card.dragging { opacity: .4; }
.ticket-card__subject {
  font-weight: 600;
  font-size: .88rem;
  line-height: 1.35;
  margin-bottom: .45rem;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  color: var(--text);
}
.ticket-card__meta {
  font-size: .76rem;
  color: var(--text-muted);
  display: flex;
  flex-direction: column;
  gap: .18rem;
}
.ticket-card__meta span {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}
.ticket-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .6rem;
  margin-top: .5rem;
}
.badge-assign {
  background: var(--rouge-light);
  color: var(--rouge);
  border-radius: 12px;
  padding: .1rem .55rem;
  font-size: .72rem;
  font-weight: 700;
  min-width: 1.8rem;
  max-width: calc(100% - 3.5rem);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.badge-msg {
  background: #F0F0F0;
  color: var(--text-muted);
  border-radius: 12px;
  padding: .1rem .5rem;
  font-size: .72rem;
  font-weight: 600;
  flex: 0 0 auto;
}

/* ── Ticket detail layout ─────────────────────────────────────────────────────── */
.ticket-layout {
  display: grid;
  grid-template-columns: 1fr 290px;
  gap: 1.25rem;
  padding: 1.25rem 1.5rem 2rem;
  max-width: 1200px;
}
@media (max-width: 768px) { .ticket-layout { grid-template-columns: 1fr; } }

.ticket-header {
  padding: 1rem 1.5rem .5rem;
  border-bottom: 1px solid var(--border);
  background: var(--white);
  margin-bottom: 0;
}
.ticket-header h2 {
  font-family: 'Manrope', sans-serif;
  font-size: 1.1rem;
  font-weight: 800;
  margin-bottom: .4rem;
}
.ticket-header__meta {
  font-size: .82rem;
  color: var(--text-muted);
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  padding-bottom: .75rem;
}

/* ── Panel ───────────────────────────────────────────────────────────────────── */
.panel {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
}
.panel__title {
  padding: .6rem 1rem;
  font-family: 'Manrope', sans-serif;
  font-weight: 700;
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
  color: var(--text-muted);
}
.panel__body { padding: 1rem; }

/* ── Messages fil ─────────────────────────────────────────────────────────────── */
.messages-list { display: flex; flex-direction: column; gap: .75rem; margin-bottom: 1rem; }
.msg {
  border-radius: 6px;
  padding: .75rem 1rem;
  font-size: .88rem;
  line-height: 1.6;
}
.msg.entrant  { background: var(--bg); border: 1px solid var(--border); }
.msg.sortant  { background: var(--rouge-light); border: 1px solid #f0b8c8; }
.msg.interne  { background: #fffbe6; border: 1px solid #f0d97a; }
.msg__header  { display: flex; align-items: baseline; gap: .6rem; margin-bottom: .35rem; flex-wrap: wrap; }
.msg__author  { font-weight: 700; font-size: .82rem; }
.msg__date    { font-size: .75rem; color: var(--text-muted); }
.msg__type    { font-size: .68rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; padding: .1rem .45rem; border-radius: 10px; }
.msg__type.entrant  { background: var(--rouge); color: #fff; }
.msg__type.sortant  { background: var(--accent2); color: #fff; }
.msg__type.interne  { background: #e8c20a; color: #333; }
.msg__body { white-space: pre-wrap; word-break: break-word; }
.msg__body--html {
  white-space: normal;
  line-height: 1.55;
}
.msg__body--html p { margin: 0 0 .65rem; }
.msg__body--html p:last-child { margin-bottom: 0; }
.msg__body--html ul,
.msg__body--html ol { margin: .35rem 0 .65rem 1.25rem; }
.msg__body--html a { color: var(--rouge); text-decoration: underline; }
.msg__body--html blockquote {
  margin: .5rem 0;
  padding-left: .75rem;
  border-left: 3px solid var(--border);
  color: var(--text-muted);
}

/* ── Messages membres ─────────────────────────────────────────────────────── */
.member-mail {
  padding: 1.25rem 1.5rem 2rem;
  max-width: 1440px;
}
.member-mail__header {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}
.member-mail__header h1 {
  font-family: 'Manrope', sans-serif;
  font-size: 1.45rem;
  line-height: 1.15;
  margin: .15rem 0 0;
}
.member-mail__grid {
  display: grid;
  grid-template-columns: minmax(300px, 390px) minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}
.member-mail__filters,
.member-mail__compose {
  display: flex;
  flex-direction: column;
  gap: .85rem;
}
.member-mail-field {
  display: flex;
  flex-direction: column;
  gap: .28rem;
}
.member-mail-field > span,
.member-mail-fieldset legend {
  font-size: .72rem;
  font-weight: 800;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.member-mail-field input,
.member-mail-field select {
  min-height: 38px;
  border: 1px solid var(--border);
  border-radius: 5px;
  background: var(--white);
  padding: .5rem .65rem;
  font-size: .9rem;
}
.member-mail-field input:focus,
.member-mail-field select:focus {
  outline: none;
  border-color: var(--rouge);
  box-shadow: 0 0 0 3px rgba(185,0,58,.1);
}
.member-mail-field small {
  color: var(--text-muted);
  font-size: .78rem;
  line-height: 1.3;
}
.member-mail-template-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .65rem;
  align-items: end;
}
.member-mail-fieldset {
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: .75rem;
  display: flex;
  flex-direction: column;
  gap: .55rem;
}
.member-mail-checks {
  display: flex;
  flex-direction: column;
  gap: .4rem;
  max-height: 180px;
  overflow: auto;
  padding-right: .15rem;
}
.member-mail-check {
  display: flex;
  align-items: flex-start;
  gap: .45rem;
  font-size: .86rem;
  line-height: 1.25;
}
.member-mail-check input { margin-top: .12rem; }
.member-mail-check small { color: var(--text-muted); }
.member-mail-check--warn {
  padding: .5rem;
  border-radius: 5px;
  background: #fff7df;
  border: 1px solid #efd27a;
}
.member-mail-newsletter {
  display: grid;
  grid-template-columns: minmax(150px, .3fr) minmax(240px, 1fr);
  gap: .65rem;
  align-items: end;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: #fbfbfb;
  padding: .65rem;
}
.member-mail-newsletter .member-mail-actions {
  grid-column: 1 / -1;
  justify-content: flex-start;
}
.member-mail-split {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: .65rem;
}
.member-mail-count {
  border: 1px solid rgba(185,0,58,.25);
  background: var(--rouge-light);
  border-radius: 7px;
  padding: .85rem;
  text-align: left;
  cursor: pointer;
}
.member-mail-count span {
  display: block;
  font-family: 'Manrope', sans-serif;
  font-size: 2rem;
  line-height: 1;
  font-weight: 800;
  color: var(--rouge);
}
.member-mail-count strong {
  display: block;
  margin-top: .2rem;
  font-size: .95rem;
}
.member-mail-count small,
.member-mail-muted {
  color: var(--text-muted);
  font-size: .78rem;
}
.member-mail-files {
  min-height: 1.2rem;
  white-space: pre-line;
  color: var(--text-muted);
  font-size: .82rem;
}
.member-mail-actions {
  display: flex;
  justify-content: flex-end;
  gap: .55rem;
  flex-wrap: wrap;
}
.member-mail__history {
  margin-top: 1rem;
}
.member-mail-history-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto auto;
  gap: .8rem;
  align-items: center;
  padding: .6rem 0;
  border-bottom: 1px solid var(--border);
  font-size: .88rem;
}
.member-mail-history-row:last-child { border-bottom: 0; }
.member-mail-history-row strong,
.member-mail-history-row span {
  display: block;
}
.member-mail-history-row div span,
.member-mail-history-row em {
  color: var(--text-muted);
  font-style: normal;
  font-size: .78rem;
}
.member-mail-history-actions {
  display: flex;
  gap: .35rem;
  justify-content: flex-end;
  flex-wrap: wrap;
}
.member-mail-modal {
  max-width: 760px;
}
.member-mail-recipients {
  display: grid;
  gap: .45rem;
  max-height: 64vh;
  overflow: auto;
}
.member-mail-recipient {
  width: 100%;
  text-align: left;
  border: 1px solid var(--border);
  background: var(--white);
  border-radius: 6px;
  padding: .65rem .75rem;
  cursor: pointer;
}
.member-mail-recipient:hover {
  border-color: var(--rouge);
  background: var(--rouge-light);
}
.member-mail-recipient strong,
.member-mail-recipient span,
.member-mail-recipient small {
  display: block;
}
.member-mail-recipient span,
.member-mail-recipient small {
  color: var(--text-muted);
  font-size: .8rem;
  margin-top: .12rem;
}
@media (max-width: 980px) {
  .member-mail__grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .member-mail { padding: 1rem; }
  .member-mail__header,
  .member-mail-history-row {
    display: flex;
    flex-direction: column;
    align-items: stretch;
  }
  .member-mail-template-row,
  .member-mail-split { grid-template-columns: 1fr; }
}

/* ── Formations ───────────────────────────────────────────────────────────── */
.formation-app {
  padding: 1.25rem 1.5rem 2rem;
  max-width: 1480px;
}
.formation-header {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}
.formation-header h1 {
  font-family: 'Manrope', sans-serif;
  font-size: 1.45rem;
  line-height: 1.15;
  margin: .15rem 0 0;
}
.formation-header__actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: .5rem;
  flex-wrap: wrap;
}
.formation-header__actions input,
.formation-header__actions select {
  min-height: 34px;
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: .42rem .6rem;
  background: var(--white);
}
.formation-layout {
  display: grid;
  grid-template-columns: minmax(320px, 430px) minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}
.formation-list-panel {
  position: sticky;
  top: .75rem;
}
.formation-list {
  display: grid;
  gap: .45rem;
  padding: .75rem;
  max-height: calc(100vh - 190px);
  overflow: auto;
}
.formation-item {
  text-align: left;
  border: 1px solid var(--border);
  background: var(--white);
  border-radius: 7px;
  padding: .7rem .75rem;
  cursor: pointer;
}
.formation-item--past {
  background: #f2f2f2;
  border-color: #d8d8d8;
}
.formation-item--past strong {
  color: #555;
}
.formation-item--today {
  background: #fff8df;
  border-color: #e2c76e;
}
.formation-item--undated {
  background: #f8f8fb;
  border-style: dashed;
}
.formation-item:hover,
.formation-item.is-current {
  border-color: var(--rouge);
  background: var(--rouge-light);
}
.formation-item strong,
.formation-item span,
.formation-item small {
  display: block;
}
.formation-item span,
.formation-item small {
  color: var(--text-muted);
  font-size: .8rem;
  margin-top: .15rem;
}
.formation-detail {
  display: grid;
  gap: 1rem;
}
.formation-empty {
  border: 1px dashed var(--border);
  border-radius: 7px;
  padding: 2rem;
  color: var(--text-muted);
  background: var(--white);
}
.formation-titlebar {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  padding: 1rem;
  border-bottom: 1px solid var(--border);
}
.formation-titlebar h2 {
  font-family: 'Manrope', sans-serif;
  font-size: 1.15rem;
  margin: .15rem 0 .35rem;
}
.formation-titlebar p {
  color: var(--text-muted);
  font-size: .88rem;
}
.formation-titlebar__actions,
.formation-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .5rem;
  flex-wrap: wrap;
}
.formation-stats {
  display: grid;
  grid-template-columns: repeat(6, minmax(110px, 1fr));
  gap: .65rem;
  padding: 1rem;
  border-bottom: 1px solid var(--border);
}
.formation-stat {
  border: 1px solid var(--border);
  border-radius: 7px;
  padding: .65rem .75rem;
  background: var(--bg);
}
.formation-stat span,
.formation-table span {
  color: var(--text-muted);
  font-size: .78rem;
}
.formation-stat strong {
  display: block;
  font-family: 'Manrope', sans-serif;
  font-size: 1.35rem;
  color: var(--rouge);
  margin-top: .15rem;
}
.formation-description {
  padding: 1rem;
  font-size: .9rem;
  line-height: 1.55;
}
.formation-section-head .panel__title {
  border-bottom: 0;
}
.formation-section-head {
  border-bottom: 1px solid var(--border);
  background: var(--bg);
  padding-right: .75rem;
}
.formation-attendees,
.formation-invoices {
  overflow: auto;
}
.formation-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .88rem;
}
.formation-table th,
.formation-table td {
  border-bottom: 1px solid var(--border);
  padding: .65rem .75rem;
  text-align: left;
  vertical-align: middle;
}
.formation-table th {
  font-size: .72rem;
  text-transform: uppercase;
  color: var(--text-muted);
  letter-spacing: .04em;
  background: var(--bg);
}
.formation-table select {
  min-height: 32px;
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: .35rem .5rem;
  background: var(--white);
}
.formation-ok { color: #26733d; }
.formation-due { color: #a22; }
.formation-modal {
  max-width: 720px;
}
.pdf-template-backdrop {
  align-items: flex-start;
  overflow-y: auto;
  padding: 1rem;
}
.pdf-template-modal {
  width: min(100%, 860px);
  max-width: 860px;
  max-height: calc(100vh - 2rem);
  overflow-y: auto;
  padding: 1.15rem;
}
.pdf-template-modal h3 {
  margin-bottom: .75rem;
}
.pdf-template-modal .actu-cejc-banner {
  margin-bottom: .85rem;
  font-size: .82rem;
  line-height: 1.35;
}
.pdf-template-modal .formation-form {
  gap: .55rem;
}
.pdf-template-modal .formation-form input,
.pdf-template-modal .formation-form select,
.pdf-template-modal .formation-form textarea {
  min-height: 38px;
  font-size: .92rem;
  padding: .42rem .55rem;
}
.pdf-template-modal .formation-form textarea {
  resize: vertical;
}
.pdf-template-modal #pdfIntro,
.pdf-template-modal #pdfFooter {
  min-height: 82px;
}
.pdf-template-modal #pdfBody {
  min-height: 110px;
}
.pdf-template-modal .modal__actions {
  position: sticky;
  bottom: -1.15rem;
  background: var(--white);
  border-top: 1px solid var(--border);
  padding-top: .75rem;
  padding-bottom: .2rem;
}
.formation-form {
  display: grid;
  gap: .75rem;
}
.formation-form label,
.formation-member-search {
  display: flex;
  flex-direction: column;
  gap: .25rem;
}
.formation-form span,
.formation-member-search span {
  font-size: .72rem;
  font-weight: 800;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.formation-form input,
.formation-form select,
.formation-form textarea,
.formation-member-search input {
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: .5rem .65rem;
  font: inherit;
}
.formation-form__split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .65rem;
}
.formation-form__checks {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  font-size: .88rem;
}
.formation-form__checks label {
  flex-direction: row;
  align-items: center;
}
.formation-member-results {
  display: grid;
  gap: .45rem;
  max-height: 52vh;
  overflow: auto;
  margin-top: .75rem;
}
.formation-member-result {
  text-align: left;
  border: 1px solid var(--border);
  background: var(--white);
  border-radius: 6px;
  padding: .6rem .75rem;
  cursor: pointer;
}
.formation-member-result:hover {
  border-color: var(--rouge);
  background: var(--rouge-light);
}
.formation-member-result strong,
.formation-member-result span {
  display: block;
}
.formation-member-result span {
  color: var(--text-muted);
  font-size: .8rem;
  margin-top: .12rem;
}
.formation-eligibility-groups {
  display: grid;
  gap: .5rem;
  max-height: 52vh;
  overflow: auto;
  margin-top: .75rem;
}
.formation-eligibility-option {
  display: flex;
  align-items: flex-start;
  gap: .65rem;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: .65rem .75rem;
  background: var(--white);
  cursor: pointer;
}
.formation-eligibility-option:hover {
  border-color: var(--rouge);
  background: var(--rouge-light);
}
.formation-eligibility-option input {
  margin-top: .2rem;
}
.formation-eligibility-option strong,
.formation-eligibility-option small {
  display: block;
}
.formation-eligibility-option small {
  color: var(--text-muted);
  font-size: .8rem;
  margin-top: .15rem;
}
.formation-eligibility-subtitle {
  margin: 1rem 0 .55rem;
  font-size: .88rem;
  font-weight: 800;
}
.formation-eligibility-subtitle:first-child {
  margin-top: 0;
}
@media (max-width: 1180px) {
  .formation-layout { grid-template-columns: 1fr; }
  .formation-list-panel { position: static; }
  .formation-list { max-height: 360px; }
  .formation-stats { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 700px) {
  .formation-app { padding: 1rem; }
  .formation-header,
  .formation-titlebar {
    display: flex;
    flex-direction: column;
    align-items: stretch;
  }
  .formation-header__actions { justify-content: flex-start; }
  .formation-stats,
  .formation-form__split {
    grid-template-columns: 1fr;
  }
}

/* ── Éditeur mail (réponse / nouveau mail) ──────────────────────────────────── */
.mail-editor {
  border: 1px solid var(--border);
  border-radius: 5px;
  overflow: hidden;
  background: #fff;
}
.mail-editor__toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .2rem;
  padding: .35rem .45rem;
  border-bottom: 1px solid var(--border);
  background: #fafafa;
}
.mail-editor__btn {
  min-width: 2rem;
  height: 2rem;
  padding: 0 .45rem;
  border: 1px solid transparent;
  border-radius: 4px;
  background: transparent;
  cursor: pointer;
  font-size: .82rem;
  color: var(--text);
}
.mail-editor__btn:hover,
.mail-editor__btn:focus-visible {
  border-color: var(--border);
  background: #fff;
}
.mail-editor__sep {
  width: 1px;
  height: 1.25rem;
  background: var(--border);
  margin: 0 .15rem;
}
.mail-editor__area {
  min-height: 7rem;
  max-height: 18rem;
  overflow-y: auto;
  padding: .6rem .8rem;
  outline: none;
  line-height: 1.5;
  word-break: break-word;
}
.mail-editor__area:empty::before {
  content: attr(data-placeholder);
  color: var(--text-muted);
  pointer-events: none;
}

/* ── Sidebar ──────────────────────────────────────────────────────────────────── */
.sidebar-section { margin-bottom: 1.25rem; }
.sidebar-section label {
  display: block;
  font-size: .76rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-muted);
  margin-bottom: .35rem;
}
.sidebar-section select,
.sidebar-section input { width: 100%; }
.sidebar-notify-label {
  display: flex;
  align-items: flex-start;
  gap: .45rem;
  font-size: .88rem;
  font-weight: 600;
  cursor: pointer;
  margin-bottom: .25rem;
}
.sidebar-notify-label input { width: auto; margin-top: .15rem; flex-shrink: 0; }

.statut-badge {
  display: inline-block;
  padding: .2rem .7rem;
  border-radius: 12px;
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.statut-badge.nouveau    { background: #fce8ee; color: var(--col-nouveau); }
.statut-badge.en_cours   { background: #fef0e0; color: var(--col-en_cours); }
.statut-badge.cloture    { background: #e4f5ec; color: var(--col-cloture); }

/* ── Admin users ──────────────────────────────────────────────────────────────── */
.admin-wrap { padding: 1.25rem 1.5rem 2rem; max-width: none; }
.admin-wrap h2 {
  font-family: 'Manrope', sans-serif;
  font-size: 1.1rem;
  font-weight: 800;
  margin-bottom: 1rem;
}
.admin-tools-panel {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  border: 1px solid var(--border);
  border-radius: 7px;
  background: #fbfbfb;
  padding: .85rem 1rem;
  margin-bottom: 1rem;
}
.admin-tools-panel h2 {
  margin: 0 0 .2rem;
}
.admin-tools-panel p {
  margin: 0;
  color: var(--text-muted);
  font-size: .86rem;
}
.admin-tools-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: .5rem;
}
.admin-signatory-panel {
  flex-direction: column;
  align-items: stretch;
}
.admin-signatory-form {
  display: grid;
  gap: .75rem;
  margin-top: .75rem;
}
.admin-signatory-form label {
  display: flex;
  flex-direction: column;
  gap: .35rem;
  font-size: .86rem;
}
.admin-signatory-form input[type="text"],
.admin-signatory-form input[type="file"] {
  max-width: 28rem;
}
.admin-signatory-preview img {
  display: block;
  max-width: 220px;
  max-height: 90px;
  margin-top: .35rem;
  border: 1px solid var(--border);
  background: #fff;
}
.table-wrap {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
}
.table-wrap--admin-users {
  overflow-x: auto;
}
.admin-users-filters {
  display: grid;
  grid-template-columns: minmax(240px, 1fr) minmax(210px, .35fr) auto;
  gap: .65rem;
  align-items: center;
  margin-bottom: .9rem;
}
.admin-users-filters input,
.admin-users-filters select {
  width: 100%;
  min-height: 36px;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: .45rem .65rem;
  background: #fff;
}
.admin-user-flags {
  border: 1px solid var(--border);
  border-radius: 7px;
  padding: .65rem .75rem;
  margin: 0 0 .75rem;
}
.admin-user-flags legend {
  font-size: .85rem;
  font-weight: 700;
  padding: 0 .25rem;
}
.admin-user-flags__item {
  display: flex;
  align-items: center;
  gap: .45rem;
  margin-top: .45rem;
  font-size: .9rem;
}
.admin-users-table td .statut-badge + .statut-badge {
  margin-left: .25rem;
}
.admin-users-table {
  min-width: 1160px;
}
.admin-users-table th,
.admin-users-table td {
  vertical-align: middle;
}
.admin-users-table th:nth-child(1),
.admin-users-table td:nth-child(1) {
  width: 190px;
}
.admin-users-table th:nth-child(2),
.admin-users-table td:nth-child(2) {
  width: 260px;
  overflow-wrap: anywhere;
}
.admin-users-table th:nth-child(3),
.admin-users-table td:nth-child(3) {
  width: 260px;
}
.admin-users-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  min-width: 230px;
}
.admin-users-actions .btn-sm {
  padding-left: .55rem;
  padding-right: .55rem;
}
.admin-identity-main {
  display: grid;
  gap: .12rem;
}
.admin-identity-main strong,
.admin-identity-main span {
  overflow-wrap: anywhere;
}
.admin-identity-main span {
  color: var(--text-muted);
  font-size: .8rem;
}
.admin-audit-panel {
  margin-top: 1.25rem;
  border: 1px solid var(--border);
  border-radius: 7px;
  background: #fff;
  box-shadow: var(--shadow);
  overflow: hidden;
}
.admin-audit-head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: center;
  padding: .85rem 1rem;
  border-bottom: 1px solid var(--border);
  background: #fbfbfb;
}
.admin-audit-head h2 {
  margin: 0 0 .2rem;
  font-size: 1.05rem;
}
.admin-audit-head p {
  margin: 0;
  color: var(--text-muted);
  font-size: .82rem;
}
.admin-audit-actions {
  display: flex;
  gap: .45rem;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.admin-audit-filters {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(150px, .35fr) minmax(130px, .25fr) minmax(130px, .25fr) auto;
  gap: .55rem;
  padding: .75rem 1rem;
  border-bottom: 1px solid var(--border);
  align-items: center;
}
.admin-audit-filters input,
.admin-audit-filters select {
  width: 100%;
  min-height: 34px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: #fff;
  padding: .4rem .55rem;
}
.admin-audit-list {
  display: grid;
}
.admin-audit-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(160px, .35fr);
  gap: 1rem;
  padding: .65rem 1rem;
  border-bottom: 1px solid var(--border);
  align-items: center;
}
.admin-audit-row:last-child {
  border-bottom: 0;
}
.admin-audit-row div {
  display: grid;
  gap: .12rem;
}
.admin-audit-row span {
  color: var(--text-muted);
  font-size: .8rem;
  overflow-wrap: anywhere;
}
table { width: 100%; border-collapse: collapse; font-size: .87rem; }
th {
  background: var(--bg);
  padding: .6rem 1rem;
  text-align: left;
  font-weight: 700;
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-muted);
  border-bottom: 1px solid var(--border);
}
td { padding: .6rem 1rem; border-bottom: 1px solid var(--border); }
tr:last-child td { border-bottom: none; }
tr:hover td { background: var(--bg); }

/* ── Modal ────────────────────────────────────────────────────────────────────── */
.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 200;
}
.modal-backdrop.hidden { display: none; }
.modal {
  background: var(--white);
  border-radius: var(--radius);
  padding: 1.75rem;
  width: min(100% - 2rem, 560px);
  max-width: 560px;
  box-shadow: 0 8px 30px rgba(0,0,0,.2);
}
.modal h3 {
  font-family: 'Manrope', sans-serif;
  font-size: 1rem;
  font-weight: 800;
  margin-bottom: 1.25rem;
}
.modal__actions { display: flex; gap: .75rem; justify-content: flex-end; margin-top: 1.25rem; }

#pdfTemplateModal.pdf-template-backdrop {
  align-items: flex-start;
  overflow-y: auto;
  padding: 1rem;
}
#pdfTemplateModal .pdf-template-modal {
  width: min(100%, 860px);
  max-width: 860px;
  max-height: calc(100vh - 2rem);
  overflow-y: auto;
  padding: 1.15rem;
}
#pdfTemplateModal .modal__actions {
  position: sticky;
  bottom: -1.15rem;
  background: var(--white);
  border-top: 1px solid var(--border);
  padding-top: .75rem;
  padding-bottom: .2rem;
}

/* ── Toast ────────────────────────────────────────────────────────────────────── */
.toast-container {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: .5rem;
  z-index: 300;
}
.toast {
  padding: .65rem 1.1rem;
  border-radius: 6px;
  font-size: .88rem;
  font-weight: 600;
  box-shadow: 0 3px 12px rgba(0,0,0,.18);
  animation: slideIn .2s ease;
}
.toast.success { background: #1a7a45; color: #fff; }
.toast.error   { background: #b22020; color: #fff; }
@keyframes slideIn {
  from { transform: translateX(100%); opacity: 0; }
  to   { transform: translateX(0);    opacity: 1; }
}

/* ── Misc ─────────────────────────────────────────────────────────────────────── */
.empty-state { padding: 2rem 1rem; text-align: center; color: var(--text-muted); font-size: .87rem; }
.hidden      { display: none !important; }
.loading     { padding: 3rem; text-align: center; color: var(--text-muted); }
.muted       { color: var(--text-muted); font-size: .82rem; }
hr.divider   { border: none; border-top: 1px solid var(--border); margin: 1rem 0; }
.nav-back    { display: inline-flex; align-items: center; gap: .35rem; font-size: .85rem; padding: .5rem 0; color: var(--rouge); font-weight: 600; }
.nav-back::before { content: '←'; }

/* ── Réponse mail : pièces jointes ──────────────────────────────────────────── */
.reply-attach-label {
  display: block;
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--text-muted);
  margin-top: .85rem;
  margin-bottom: .35rem;
}
.reply-file-input {
  width: 100%;
  padding: .35rem 0;
  font-size: .85rem;
}
.reply-file-list {
  font-size: .8rem;
  color: var(--text-muted);
  margin-top: .35rem;
}
.reply-file-list.hidden { display: none; }

.speciality-request-card {
  border: 1px solid var(--border);
  border-radius: 7px;
  background: #fbfbfb;
  padding: .7rem;
  display: grid;
  gap: .65rem;
}
.speciality-request-card p {
  margin: 0;
  font-size: .84rem;
}
.speciality-request-cols {
  display: grid;
  grid-template-columns: 1fr;
  gap: .55rem;
}
.speciality-request-cols span {
  display: block;
  color: var(--text-muted);
  font-size: .72rem;
  font-weight: 800;
  text-transform: uppercase;
  margin-bottom: .25rem;
}
.speciality-request-cols ul {
  margin: 0;
  padding-left: 1.1rem;
  font-size: .8rem;
}

/* ── Messages : pièces jointes ─────────────────────────────────────────────── */
.msg-attachments {
  margin-top: .75rem;
  padding: .65rem .75rem;
  background: #f8f9fb;
  border: 1px solid var(--border);
  border-radius: 6px;
}
.msg-attachments__title {
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--text-muted);
  margin-bottom: .5rem;
}
.msg-attachments__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: .45rem;
}
.msg-attach-item {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .4rem .6rem;
  font-size: .84rem;
}
.msg-attach-icon { flex-shrink: 0; }
.msg-attach-name {
  flex: 1 1 8rem;
  min-width: 0;
  word-break: break-word;
}
.msg-attach-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem;
}

/* ── Admin : cases à cocher utilisateur ─────────────────────────────────────── */
.form-group--checkboxes {
  display: flex;
  flex-direction: column;
  gap: .5rem;
}
.checkbox-line {
  display: flex;
  align-items: flex-start;
  gap: .5rem;
  font-size: .86rem;
  line-height: 1.45;
  color: var(--text);
  cursor: pointer;
  font-weight: 500;
}
.checkbox-line input { margin-top: .2rem; flex-shrink: 0; }

/* ── Page adhésion CEJC ─────────────────────────────────────────────────────── */
.adhesion-page { padding: 0 1.5rem 2.5rem; max-width: 1100px; margin: 0 auto; }
.adhesion-page .form-group select optgroup {
  font-weight: 700;
  font-size: 0.875rem;
  color: var(--text-muted);
}

.adhesion-rubriques-wrap {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}
.adhesion-rubrique-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.adhesion-rubrique-row .adhesion-rubrique-select {
  flex: 1;
  min-width: 0;
}
.adhesion-rubrique-remove {
  flex-shrink: 0;
  min-width: 2.25rem;
  padding-left: 0.5rem;
  padding-right: 0.5rem;
}
.adhesion-rubrique-row .rubrique-combobox {
  flex: 1;
  min-width: 0;
}

.rubrique-combobox {
  position: relative;
}
.rubrique-combobox__input {
  width: 100%;
  padding: .5rem .7rem;
  border: 1px solid var(--border);
  border-radius: 5px;
  font-size: .9rem;
}
.rubrique-combobox__list {
  position: absolute;
  z-index: 40;
  left: 0;
  right: 0;
  top: calc(100% + 2px);
  max-height: 280px;
  overflow-x: hidden;
  overflow-y: scroll;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: var(--rouge) #f0f0f0;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 6px;
  box-shadow: var(--shadow);
}
.rubrique-combobox__list::-webkit-scrollbar {
  width: 10px;
}
.rubrique-combobox__list::-webkit-scrollbar-track {
  background: #f0f0f0;
  border-radius: 0 6px 6px 0;
}
.rubrique-combobox__list::-webkit-scrollbar-thumb {
  background: rgba(185, 0, 58, 0.45);
  border-radius: 5px;
  border: 2px solid #f0f0f0;
}
.rubrique-combobox__list::-webkit-scrollbar-thumb:hover {
  background: var(--rouge);
}
.rubrique-combobox__hl {
  background: #fff59d;
  color: inherit;
  padding: 0 .05em;
  border-radius: 2px;
}
.rubrique-combobox__option {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: .1rem;
  width: 100%;
  text-align: left;
  padding: .45rem .65rem;
  border: 0;
  background: transparent;
  cursor: pointer;
  font: inherit;
}
.rubrique-combobox__option:hover,
.rubrique-combobox__option:focus-visible {
  background: var(--rouge-light);
}
.rubrique-combobox__code {
  font-size: .72rem;
  font-weight: 700;
  color: var(--rouge);
}
.rubrique-combobox__intitule {
  font-size: .84rem;
  line-height: 1.35;
  color: var(--text);
}
.rubrique-combobox__empty {
  padding: .55rem .65rem;
  font-size: .82rem;
  color: var(--text-muted);
}

.adhesion-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
  align-items: start;
}
@media (max-width: 900px) {
  .adhesion-layout { grid-template-columns: 1fr; }
}
.adhesion-help {
  font-size: .8rem;
  color: var(--text-muted);
  margin: 0 0 .5rem;
  line-height: 1.4;
}
.adhesion-upload-row {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}
.adhesion-file-btn {
  position: relative;
  cursor: pointer;
}
.adhesion-file-label {
  font-size: .8rem;
  color: var(--rouge);
  font-weight: 600;
  margin: .5rem 0 0;
  min-height: 1.2em;
}
.adhesion-staged-files {
  list-style: none;
  margin: .5rem 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: .35rem;
}
.adhesion-staged-file {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .5rem;
  padding: .35rem .5rem;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: .85rem;
}
.adhesion-staged-file--invalid {
  border-color: var(--rouge);
  background: rgba(185, 0, 58, .06);
}
.adhesion-staged-file__name {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.adhesion-staged-file__remove {
  flex-shrink: 0;
  min-width: 2rem;
}
.adhesion-list-panel .panel__body {
  max-height: 520px;
  overflow-y: auto;
}
.adhesion-list-item {
  display: block;
  width: 100%;
  text-align: left;
  padding: .75rem .85rem;
  margin-bottom: .5rem;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--white);
  cursor: pointer;
  transition: border-color .15s, box-shadow .15s;
}
.adhesion-list-item:hover {
  border-color: var(--rouge);
  box-shadow: 0 2px 8px rgba(185,0,58,.12);
}
.adhesion-list-item__main {
  display: flex;
  flex-direction: column;
  gap: .15rem;
}
.adhesion-list-item__rub {
  font-size: .78rem;
  color: var(--text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.adhesion-list-item__meta {
  font-size: .74rem;
  color: var(--text-muted);
  margin-top: .35rem;
}
.adhesion-badge {
  display: inline-block;
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  padding: .12rem .45rem;
  border-radius: 8px;
}
.adhesion-badge--open { background: #e8f5e9; color: #1b5e20; }
.adhesion-badge--closed { background: #fce4ec; color: #880e4f; }
.adhesion-badge--pending { background: #fff3e0; color: #e65100; }
.adhesion-badge--rapport { background: #e3f2fd; color: #0d47a1; }
.adhesion-mini-vote { white-space: nowrap; }

.adhesion-detail-panel { margin-top: 1.25rem; }
.adhesion-detail-head {
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.adhesion-demande-rubriques {
  margin: 0 0 1rem 1.1rem;
  padding: 0;
  font-size: 0.9rem;
  line-height: 1.4;
}
.adhesion-demande-rubriques li {
  margin-bottom: 0.35rem;
}

.adhesion-assign-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  margin: 0.5rem 0 1rem;
}
.tj-rapport-textarea {
  width: 100%;
  max-width: 56rem;
  padding: 0.6rem 0.75rem;
  font: inherit;
  line-height: 1.5;
  border: 1px solid var(--border);
  border-radius: 6px;
  resize: vertical;
  box-sizing: border-box;
}
.tj-rapport-byline {
  margin: -.15rem 0 .65rem;
  font-size: .84rem;
  color: var(--text-muted);
}
.tj-rapport-byline strong {
  color: var(--text);
  font-weight: 600;
}
.tj-rapport-readonly {
  white-space: pre-wrap;
  padding: 0.75rem 1rem;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--white);
  font-size: 0.9rem;
  line-height: 1.5;
  max-width: 56rem;
  box-sizing: border-box;
}

/* Actus WordPress depuis l’intranet */
.actu-cejc-page .actu-cejc-panel {
  max-width: 720px;
}
.actu-cejc-banner {
  padding: .75rem 1rem;
  border-radius: 8px;
  margin-bottom: 1.25rem;
  font-size: 0.9rem;
  line-height: 1.45;
}
#mailStatusBanner {
  margin: 0 1.5rem 1.25rem;
  border-radius: 0 0 8px 8px;
}
.actu-cejc-banner--warn {
  background: rgba(198, 120, 0, 0.12);
  border: 1px solid rgba(198, 120, 0, 0.35);
}
@media (max-width: 640px) {
  #mailStatusBanner {
    margin: 0 1rem 1rem;
    font-size: .84rem;
  }
}
.actu-cejc-result {
  margin-top: 1.25rem;
  padding: .85rem 1rem;
  border-radius: 8px;
  background: rgba(22, 120, 60, 0.12);
  border: 1px solid rgba(22, 120, 60, 0.3);
  font-size: 0.9rem;
}

.actu-cejc-photo-label {
  display: block;
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--text-muted);
  margin-top: .85rem;
  margin-bottom: .35rem;
}
.actu-cejc-previews {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  margin-top: .5rem;
}
.actu-cejc-preview {
  margin: 0;
  max-width: 140px;
}
.actu-cejc-preview img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 6px;
  border: 1px solid var(--border);
}
.actu-cejc-preview figcaption {
  font-size: .72rem;
  color: var(--text-muted);
  margin-top: .25rem;
  word-break: break-all;
}
.actu-cejc-whoami-pre {
  margin-top: 0.5rem;
  padding: 0.65rem 0.75rem;
  background: var(--bg-muted, #f4f4f5);
  border: 1px solid var(--border, #ddd);
  border-radius: 6px;
  font-size: 0.78rem;
  overflow-x: auto;
  max-height: 14rem;
}

.actu-cejc-ai {
  padding: .85rem 1rem;
  background: #f8f4f6;
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-bottom: 1.25rem;
}
.actu-cejc-ai-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .65rem;
  margin-top: .5rem;
}
.actu-cejc-ai-busy {
  font-size: .82rem;
  color: var(--text-muted);
}
.actu-cejc-mode-label {
  display: block;
  font-weight: 700;
  margin-bottom: 0.35rem;
}
.actu-cejc-mode-radios {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-top: 0.5rem;
}
.actu-cejc-form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: 0.25rem;
}
.actu-cejc-drafts {
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--border);
  max-width: 720px;
}
.actu-cejc-drafts__title {
  font-family: 'Manrope', sans-serif;
  font-size: 1.1rem;
  margin: 0 0 0.5rem;
}
.actu-cejc-drafts-list {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  margin-top: 1rem;
}
.actu-cejc-draft-card {
  padding: 0.85rem 1rem;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--white);
}
.actu-cejc-draft-card__head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.35rem;
}
.actu-cejc-draft-card__excerpt {
  font-size: 0.88rem;
  color: var(--text-muted);
  margin: 0 0 0.65rem;
  white-space: pre-wrap;
}
.actu-cejc-draft-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.adhesion-detail-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  margin-bottom: 1rem;
}
.adhesion-vote-bar {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  margin-bottom: 1rem;
}
.adhesion-vote-pill {
  flex: 1;
  min-width: 100px;
  text-align: center;
  padding: .65rem .75rem;
  border-radius: 8px;
  font-size: .82rem;
  font-weight: 700;
  border: 1px solid var(--border);
}
.adhesion-vote-pill span {
  display: block;
  font-size: 1.35rem;
  font-family: 'Manrope', sans-serif;
  margin-bottom: .15rem;
}
.adhesion-vote-pill--pour { background: linear-gradient(180deg, #e8f5e9, #fff); border-color: #a5d6a7; }
.adhesion-vote-pill--contre { background: linear-gradient(180deg, #ffebee, #fff); border-color: #ef9a9a; }
.adhesion-vote-pill--abs { background: linear-gradient(180deg, #f5f5f5, #fff); border-color: #e0e0e0; }
.adhesion-closed-banner {
  background: #fce4ec;
  color: #6a1b4d;
  padding: .65rem 1rem;
  border-radius: 6px;
  font-weight: 600;
  font-size: .88rem;
  margin-bottom: 1rem;
}
.adhesion-my-vote {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .5rem;
  margin-bottom: 1rem;
  padding: .85rem 1rem;
  background: var(--bg);
  border-radius: 6px;
  border: 1px solid var(--border);
}
.adhesion-my-vote__label { font-weight: 700; font-size: .85rem; margin-right: .25rem; }
.adhesion-detail-actions {
  margin-bottom: 1rem;
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  align-items: center;
}
.adhesion-vote-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: .5rem;
}
.adhesion-note { font-size: .85rem; color: var(--text-muted); margin: 0 0 .75rem; }
.adhesion-attente {
  font-size: .84rem;
  color: var(--text);
  background: #fff8e1;
  border: 1px solid #ffe082;
  padding: .65rem .85rem;
  border-radius: 6px;
  margin-bottom: 1rem;
}
.adhesion-subh {
  font-family: 'Manrope', sans-serif;
  font-size: .82rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text-muted);
  margin: 0 0 .5rem;
}
.adhesion-votes-list {
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: .86rem;
}
.adhesion-votes-list li {
  padding: .4rem 0;
  border-bottom: 1px solid var(--border);
}
.adhesion-votes-list li:last-child { border-bottom: none; }

.adhesion-bulletin-modal {
  width: min(920px, 96vw);
  max-height: 92vh;
  display: flex;
  flex-direction: column;
}
.adhesion-bulletin-modal__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  margin-bottom: .75rem;
}
.adhesion-bulletin-modal__head h3 {
  margin: 0;
  font-size: 1rem;
}
.adhesion-bulletin-modal__body {
  flex: 1;
  min-height: 240px;
  overflow: auto;
}
.adhesion-bulletin-frame {
  width: 100%;
  min-height: 70vh;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: #fff;
}
.adhesion-bulletin-image {
  display: block;
  max-width: 100%;
  height: auto;
  margin: 0 auto;
  border-radius: 6px;
  border: 1px solid var(--border);
}

/* ── Extranet : migration ERP ─────────────────────────────────────────────── */
.extranet-page {
  max-width: 1180px;
  margin: 0 auto;
  padding: 1.5rem;
}
.extranet-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1.25rem;
  align-items: end;
  margin-bottom: 1.25rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--border);
}
.extranet-kicker {
  display: block;
  margin-bottom: .35rem;
  color: var(--rouge);
  font-family: 'Manrope', sans-serif;
  font-size: .75rem;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.extranet-hero h1 {
  margin: 0 0 .35rem;
  font-size: clamp(1.6rem, 3vw, 2.35rem);
}
.extranet-hero p {
  max-width: 680px;
  color: var(--text-muted);
  line-height: 1.55;
}
.extranet-hero__status {
  border: 1px solid #d7e7db;
  background: #f1faf3;
  color: #1a6a3b;
  border-radius: 7px;
  padding: .65rem .85rem;
  font-size: .84rem;
  font-weight: 700;
  white-space: nowrap;
}
.extranet-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(280px, .9fr);
  gap: 1rem;
}
.extranet-panel {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 1rem;
}
.extranet-panel h2 {
  margin-bottom: .75rem;
  font-size: 1rem;
}
.extranet-wide { grid-column: 1 / -1; }
.extranet-facts {
  display: grid;
  gap: .65rem;
}
.extranet-facts div {
  display: grid;
  grid-template-columns: 130px minmax(0, 1fr);
  gap: .75rem;
  align-items: baseline;
  padding-bottom: .55rem;
  border-bottom: 1px solid var(--border);
}
.extranet-facts div:last-child {
  border-bottom: none;
  padding-bottom: 0;
}
.extranet-facts dt {
  color: var(--text-muted);
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
}
.extranet-facts dd {
  min-width: 0;
  color: var(--text);
  overflow-wrap: anywhere;
}
.extranet-upload {
  display: grid;
  gap: .8rem;
}
.extranet-upload input[type="file"] {
  width: 100%;
  padding: .75rem;
  border: 1px dashed #cfcfcf;
  border-radius: 7px;
  background: #fafafa;
}
.extranet-help {
  color: var(--text-muted);
  font-size: .84rem;
  line-height: 1.45;
}
.extranet-table-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: .7rem;
}
.extranet-metric {
  border: 1px solid var(--border);
  border-radius: 7px;
  padding: .75rem;
  background: #fbfbfb;
}
.extranet-metric strong {
  display: block;
  margin-bottom: .2rem;
  font-family: 'Manrope', sans-serif;
  font-size: 1.35rem;
  color: var(--rouge);
}
.extranet-metric span {
  display: block;
  color: var(--text-muted);
  font-size: .78rem;
  font-weight: 700;
  overflow-wrap: anywhere;
}
.extranet-imports {
  display: grid;
  gap: .65rem;
}
.extranet-import-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .75rem;
  align-items: center;
  border: 1px solid var(--border);
  border-radius: 7px;
  padding: .75rem;
}
.extranet-import-row strong,
.extranet-import-row span {
  overflow-wrap: anywhere;
}
.extranet-import-row span {
  display: block;
  margin-top: .2rem;
  color: var(--text-muted);
  font-size: .82rem;
}
.extranet-import-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: .45rem;
}
.extranet-preview-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .9rem;
}
.extranet-preview-grid h3 {
  margin: 0 0 .55rem;
  font-size: .92rem;
}
.extranet-preview-list {
  display: grid;
  gap: .5rem;
}
.extranet-preview-item {
  min-height: 58px;
  border: 1px solid var(--border);
  border-radius: 7px;
  padding: .65rem .7rem;
  background: #fbfbfb;
  text-align: left;
  width: 100%;
}
.extranet-preview-item--button:hover {
  border-color: var(--rouge);
  background: var(--rouge-light);
}
.extranet-preview-item strong,
.extranet-preview-item span {
  display: block;
  overflow-wrap: anywhere;
}
.extranet-preview-item strong {
  margin-bottom: .2rem;
}
.extranet-preview-item span {
  color: var(--text-muted);
  font-size: .82rem;
}
.extranet-detail-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}
.extranet-detail-head h2 {
  margin: 0 0 .25rem;
  font-size: 1.35rem;
}
.extranet-detail-head p {
  color: var(--text-muted);
}
.extranet-detail-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: .5rem;
}
.extranet-link-admin {
  border: 1px solid var(--border);
  border-radius: 7px;
  background: #fbfbfb;
  padding: .75rem;
  margin-bottom: 1rem;
}
.extranet-link-admin h3 {
  margin: 0 0 .45rem;
  font-size: .95rem;
}
.extranet-link-form {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto;
  gap: .65rem;
  align-items: center;
}
.extranet-link-form select {
  width: 100%;
  min-height: 36px;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: .45rem .65rem;
  background: #fff;
}
.extranet-detail-grid {
  display: grid;
  grid-template-columns: minmax(280px, 1.15fr) repeat(3, minmax(0, 1fr));
  gap: 1rem;
  align-items: start;
}
.extranet-detail-grid h3 {
  margin: 0 0 .6rem;
  font-size: .92rem;
}
.extranet-detail-list,
.extranet-detail-cards {
  display: grid;
  gap: .5rem;
}
.extranet-detail-row,
.extranet-detail-card {
  border: 1px solid var(--border);
  border-radius: 7px;
  background: #fbfbfb;
  padding: .62rem .7rem;
  text-align: left;
  width: 100%;
}
.extranet-detail-row {
  display: grid;
  grid-template-columns: minmax(120px, .7fr) minmax(0, 1fr);
  gap: .65rem;
}
.extranet-detail-row dt {
  color: var(--text-muted);
  font-size: .78rem;
  font-weight: 700;
}
.extranet-detail-row dd,
.extranet-detail-card strong,
.extranet-detail-card span {
  overflow-wrap: anywhere;
}
.extranet-detail-card strong,
.extranet-detail-card span {
  display: block;
}
.extranet-detail-card strong {
  margin-bottom: .2rem;
}
.extranet-detail-card span {
  color: var(--text-muted);
  font-size: .82rem;
}
.member-document-upload {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(160px, .45fr) auto;
  gap: .6rem;
  align-items: end;
  margin: 0 0 .75rem;
  padding: .65rem;
  border: 1px solid var(--border);
  border-radius: 7px;
  background: #fff;
}
.member-document-upload label {
  display: grid;
  gap: .25rem;
  color: var(--text-muted);
  font-size: .78rem;
  font-weight: 700;
}
.member-document-upload input {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: .42rem .5rem;
  background: #fff;
  color: var(--text);
  font-weight: 500;
}
.extranet-v1-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: .9rem;
}
.extranet-v1-status {
  display: grid;
  gap: .85rem;
}
.extranet-v1-search {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(190px, .35fr) auto;
  gap: .65rem;
  align-items: center;
  margin-bottom: .9rem;
}
.extranet-v1-search input,
.extranet-v1-search select {
  width: 100%;
  min-height: 36px;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: .45rem .65rem;
  background: #fff;
}
.extranet-v1-summary {
  color: var(--text-muted);
  font-size: .86rem;
  font-weight: 700;
}
.extranet-v1-members {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: .65rem;
}
.extranet-portal-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
  padding-bottom: .85rem;
  border-bottom: 1px solid var(--border);
}
.extranet-portal-head h2 {
  margin: 0 0 .25rem;
  font-size: 1.45rem;
}
.extranet-portal-head p:last-child {
  color: var(--text-muted);
}
.member-profile-head {
  display: flex;
  align-items: center;
  gap: .8rem;
  min-width: 0;
}
.member-profile-photo {
  width: 58px;
  height: 58px;
  border-radius: 7px;
  border: 1px solid var(--border);
  background: #f7f7f7;
  color: var(--rouge);
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  font-size: 1.05rem;
  font-weight: 800;
  overflow: hidden;
}
.member-profile-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.member-profile-photo--large {
  width: 92px;
  height: 92px;
}
.member-profile-modal {
  width: min(100% - 2rem, 780px);
  max-width: 780px;
  max-height: calc(100vh - 2rem);
  overflow-y: auto;
}
.member-profile-form {
  display: grid;
  gap: 1rem;
}
.member-profile-photo-edit {
  display: grid;
  grid-template-columns: auto minmax(220px, 1fr);
  gap: .85rem;
  align-items: center;
}
.member-profile-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .75rem;
}
.member-profile-form label,
.member-profile-dynamic label {
  display: grid;
  gap: .28rem;
  color: var(--text-muted);
  font-size: .78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .02em;
}
.member-profile-form input,
.member-profile-form select,
.member-profile-dynamic input,
.member-profile-dynamic select {
  width: 100%;
  min-height: 38px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: #fff;
  color: var(--text);
  font-size: .92rem;
  font-weight: 500;
  padding: .5rem .65rem;
  text-transform: none;
  letter-spacing: 0;
}
.member-profile-form h4 {
  margin: 0 0 .55rem;
  font-size: .88rem;
}
.member-profile-section {
  margin-bottom: 1rem;
}
.member-profile-section h4 {
  margin: 0 0 .5rem;
  font-size: .88rem;
}
.member-profile-form-wide {
  grid-column: 1 / -1;
}
.member-profile-dynamic {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .75rem;
}
.member-profile-specialities {
  display: grid;
  gap: .5rem;
  margin-bottom: .6rem;
}
.member-profile-speciality-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .5rem;
  align-items: start;
}
.member-profile-speciality-picker .rubrique-combobox__input {
  min-height: 38px;
}
.extranet-portal-tabs {
  display: grid;
  grid-template-columns: minmax(280px, 1.1fr) repeat(3, minmax(0, 1fr));
  gap: 1rem;
  align-items: start;
}
.extranet-portal-tabs h3 {
  margin: 0 0 .6rem;
  font-size: .95rem;
}
.extranet-fields-list {
  display: grid;
  gap: .5rem;
}
.extranet-field-row {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto auto;
  gap: .75rem;
  align-items: center;
  border: 1px solid var(--border);
  border-radius: 7px;
  background: #fbfbfb;
  padding: .65rem .75rem;
}
.extranet-field-row strong,
.extranet-field-row span {
  display: block;
  overflow-wrap: anywhere;
}
.extranet-field-row span {
  color: var(--text-muted);
  font-size: .82rem;
  margin-top: .15rem;
}
.extranet-field-row label {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  color: var(--text);
  font-size: .86rem;
  font-weight: 700;
  white-space: nowrap;
}
.extranet-field-row input {
  accent-color: var(--rouge);
}
.extranet-account-readiness {
  display: grid;
  gap: 1rem;
}
.extranet-double-run {
  display: grid;
  gap: 1rem;
}
.extranet-double-run__latest {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  border: 1px solid var(--border);
  border-radius: 7px;
  background: #fbfbfb;
  padding: .7rem .85rem;
}
.extranet-double-run__latest span {
  color: var(--text-muted);
  font-weight: 700;
  overflow-wrap: anywhere;
}
.extranet-double-run__checks {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: .65rem;
}
.extranet-double-run-check {
  border: 1px solid var(--border);
  border-radius: 7px;
  background: #fff;
  padding: .75rem .85rem;
}
.extranet-double-run-check strong,
.extranet-double-run-check span {
  display: block;
}
.extranet-double-run-check span {
  color: var(--text-muted);
  font-size: .84rem;
  margin-top: .2rem;
}
.extranet-double-run-check.is-ok {
  border-color: rgba(42, 132, 82, .35);
  background: #f4fbf7;
}
.extranet-double-run-check.is-warning {
  border-color: rgba(190, 115, 18, .35);
  background: #fff9ef;
}
.extranet-inline-actions {
  display: flex;
  justify-content: flex-end;
  gap: .5rem;
}
.extranet-account-list {
  display: grid;
  gap: .65rem;
}
.extranet-account-rows {
  display: grid;
  gap: .5rem;
}
.extranet-account-row {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(240px, .85fr);
  gap: 1rem;
  align-items: center;
  border: 1px solid var(--border);
  border-radius: 7px;
  background: #fbfbfb;
  padding: .7rem .8rem;
  text-align: left;
  cursor: pointer;
}
.extranet-account-row:hover {
  border-color: rgba(185,0,58,.35);
  background: #fff;
}
.extranet-account-row strong,
.extranet-account-row small {
  display: block;
  overflow-wrap: anywhere;
}
.extranet-account-row small {
  color: var(--text-muted);
  font-size: .8rem;
  margin-top: .15rem;
}
.extranet-member-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  margin: 1rem 0;
  border-bottom: 1px solid var(--border);
  padding-bottom: .55rem;
}
.extranet-member-tabs button {
  border: 1px solid var(--border);
  border-radius: 7px;
  background: #fff;
  color: var(--text);
  cursor: pointer;
  font-weight: 700;
  padding: .48rem .75rem;
}
.extranet-member-tabs button.is-active {
  background: var(--rouge);
  border-color: var(--rouge);
  color: #fff;
}
.extranet-member-tabpanels {
  display: grid;
  gap: 1rem;
}
.extranet-member-tabpanels h3 {
  margin: 0 0 .6rem;
  font-size: .95rem;
}
.extranet-recipe-list {
  display: grid;
  gap: .55rem;
}
.extranet-recipe-card {
  display: grid;
  grid-template-columns: auto minmax(280px, 1fr) minmax(210px, .55fr);
  gap: .85rem;
  align-items: center;
  border: 1px solid var(--border);
  border-radius: 7px;
  background: #fbfbfb;
  padding: .75rem .85rem;
  text-align: left;
  cursor: pointer;
}
.extranet-recipe-card:hover {
  border-color: rgba(185,0,58,.35);
  background: #fff;
}
.extranet-recipe-card:disabled {
  cursor: default;
  opacity: .72;
}
.extranet-recipe-card strong,
.extranet-recipe-card small {
  display: block;
  overflow-wrap: anywhere;
}
.extranet-recipe-card small {
  color: var(--text-muted);
  font-size: .8rem;
  margin-top: .12rem;
}
.extranet-recipe-card__state {
  border-radius: 999px;
  background: #e4f5ec;
  color: var(--col-cloture);
  font-weight: 800;
  font-size: .76rem;
  padding: .25rem .5rem;
  white-space: nowrap;
}
.erp-shell {
  padding: 1.25rem;
  max-width: 1500px;
  margin: 0 auto;
}
.erp-toolbar {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-end;
  margin-bottom: 1rem;
}
.erp-toolbar h1 {
  margin: 0;
  font-size: 1.65rem;
}
.erp-export-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem;
  margin-top: .5rem;
}
.erp-stats {
  display: grid;
  grid-template-columns: repeat(5, minmax(90px, 1fr));
  gap: .5rem;
}
.erp-stat {
  border: 1px solid var(--border);
  border-radius: 7px;
  background: #fbfbfb;
  padding: .55rem .65rem;
}
.erp-stat span {
  display: block;
  color: var(--text-muted);
  font-size: .72rem;
  font-weight: 800;
}
.erp-stat strong {
  color: var(--rouge);
  font-size: 1.15rem;
}
.erp-layout {
  display: grid;
  grid-template-columns: minmax(320px, 390px) minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}
.erp-directory,
.erp-detail {
  border: 1px solid var(--border);
  border-radius: 7px;
  background: #fff;
  box-shadow: var(--shadow);
}
.erp-directory {
  padding: .85rem;
  position: sticky;
  top: .75rem;
  max-height: calc(100vh - 1.5rem);
  overflow: auto;
}
.erp-detail {
  min-height: 620px;
  padding: 1rem;
}
.erp-search {
  display: grid;
  grid-template-columns: 1fr;
  gap: .5rem;
  margin-bottom: .8rem;
}
.erp-search input,
.erp-search select {
  min-height: 36px;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: .45rem .65rem;
}
.erp-highlight {
  background: #fff1a8;
  color: inherit;
  border-radius: 3px;
  padding: 0 .08rem;
}
.erp-count {
  color: var(--text-muted);
  font-size: .82rem;
  font-weight: 800;
  margin-bottom: .5rem;
}
.erp-member-list {
  display: grid;
  gap: .45rem;
}
.erp-member-item {
  border: 1px solid var(--border);
  border-radius: 7px;
  background: #fbfbfb;
  padding: .6rem .65rem;
  text-align: left;
  cursor: pointer;
}
.erp-member-item:hover {
  border-color: rgba(185,0,58,.35);
  background: #fff;
}
.erp-member-item.is-active {
  border-color: var(--rouge);
  background: var(--rouge-light);
}
.erp-member-item strong,
.erp-member-item span {
  display: block;
  overflow-wrap: anywhere;
}
.erp-member-item span {
  color: var(--text-muted);
  font-size: .8rem;
  margin-top: .14rem;
}
.erp-empty {
  color: var(--text-muted);
  font-weight: 800;
}
.erp-detail-head {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  border-bottom: 1px solid var(--border);
  padding-bottom: .9rem;
  margin-bottom: .9rem;
}
.erp-detail-title {
  flex: 1;
  min-width: 0;
}
.erp-detail-head h2 {
  margin: 0 0 .2rem;
  font-size: 1.55rem;
}
.erp-detail-head p:last-child {
  color: var(--text-muted);
}
.erp-badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: .4rem;
}
.erp-badges span {
  border-radius: 999px;
  background: #fce8ee;
  color: var(--rouge);
  font-size: .75rem;
  font-weight: 800;
  padding: .28rem .55rem;
}
.erp-photo {
  width: 126px;
  flex: 0 0 126px;
  display: grid;
  gap: .5rem;
}
.erp-photo img,
.erp-photo__placeholder {
  width: 126px;
  aspect-ratio: 3 / 4;
  border-radius: 7px;
  border: 1px solid var(--border);
  background: #f7f7f7;
  object-fit: cover;
}
.erp-photo__placeholder {
  display: grid;
  place-items: center;
  color: var(--rouge);
  font: 800 2.4rem 'Manrope', system-ui, sans-serif;
}
.erp-photo .btn {
  width: 100%;
  text-align: center;
  justify-content: center;
}
.erp-cotisation {
  display: inline-grid;
  grid-template-columns: auto auto;
  gap: .1rem .55rem;
  align-items: baseline;
  margin-top: .45rem;
  border: 1px solid var(--border);
  border-radius: 7px;
  padding: .45rem .6rem;
  background: #fbfbfb;
}
.erp-cotisation span,
.erp-cotisation strong {
  font-weight: 900;
}
.erp-cotisation small {
  grid-column: 1 / -1;
  color: var(--text-muted);
  font-weight: 700;
}
.erp-cotisation--ok {
  border-color: rgba(26,122,69,.28);
  background: #eefaf3;
}
.erp-cotisation--ok span,
.erp-cotisation--ok strong {
  color: #1a7a45;
}
.erp-cotisation--due {
  border-color: rgba(185,0,58,.28);
  background: var(--rouge-light);
}
.erp-cotisation--due span,
.erp-cotisation--due strong {
  color: var(--rouge);
}
.erp-contact {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .65rem;
  margin-bottom: .85rem;
}
.erp-contact div {
  border: 1px solid var(--border);
  border-radius: 7px;
  background: #fbfbfb;
  padding: .65rem .75rem;
}
.erp-contact span,
.erp-contact strong {
  display: block;
  overflow-wrap: anywhere;
}
.erp-contact span {
  color: var(--text-muted);
  font-size: .74rem;
  font-weight: 800;
  margin-bottom: .12rem;
}
.erp-notes-panel {
  display: grid;
  grid-template-columns: minmax(220px, .42fr) minmax(260px, 1fr);
  gap: .65rem;
  margin-bottom: .85rem;
}
.erp-notes-card {
  border: 1px solid var(--border);
  border-radius: 7px;
  background: #fff;
  padding: .7rem .75rem;
}
.erp-notes-card.is-empty {
  background: #fbfbfb;
}
.erp-notes-card strong {
  display: block;
  margin-bottom: .35rem;
}
.erp-notes-card p,
.erp-notes-card span {
  color: var(--text-muted);
  font-size: .84rem;
  overflow-wrap: anywhere;
  white-space: pre-wrap;
}
.erp-notes-card textarea {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: .55rem .65rem;
  resize: vertical;
  min-height: 86px;
}
.erp-notes-actions {
  display: flex;
  justify-content: space-between;
  gap: .65rem;
  align-items: center;
  margin-top: .45rem;
}
.erp-directory-panel {
  border: 1px solid var(--border);
  border-radius: 7px;
  background: #fbfbfb;
  padding: .75rem;
  margin-bottom: .85rem;
}
.erp-directory-panel__head {
  display: flex;
  justify-content: space-between;
  gap: .75rem;
  align-items: baseline;
  margin-bottom: .65rem;
}
.erp-directory-panel__head h3 {
  margin: 0;
  font-size: 1rem;
}
.erp-directory-panel__head span {
  color: var(--text-muted);
  font-size: .78rem;
  font-weight: 800;
}
.erp-directory-controls {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .6rem;
  margin-bottom: .65rem;
}
.erp-directory-controls label,
.erp-speciality-row {
  display: grid;
  gap: .25rem;
}
.erp-directory-controls label > span {
  color: var(--text-muted);
  font-size: .74rem;
  font-weight: 800;
}
.erp-directory-controls select,
.erp-speciality-row input {
  min-height: 34px;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: .35rem .5rem;
  background: #fff;
}
.erp-directory-controls select.is-conflict {
  border-color: var(--rouge);
  background: var(--rouge-light);
}
.erp-directory-controls small {
  color: var(--rouge);
  font-weight: 800;
}
.erp-specialities {
  display: grid;
  gap: .4rem;
}
.erp-speciality-row {
  grid-template-columns: 1.6rem minmax(0, 1fr) auto;
  align-items: center;
}
.erp-speciality-picker,
.erp-speciality-picker .rubrique-combobox {
  min-width: 0;
}
.erp-speciality-picker .rubrique-combobox__input {
  min-height: 34px;
  padding: .35rem .5rem;
}
.erp-speciality-row > span {
  color: var(--text-muted);
  font-weight: 900;
  text-align: center;
}
.erp-directory-actions {
  display: flex;
  justify-content: flex-end;
  gap: .45rem;
  margin-top: .6rem;
}
.erp-field-row dd {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .6rem;
}
.erp-field-value {
  min-width: 0;
  overflow-wrap: anywhere;
}
.btn-xs {
  min-height: 26px;
  padding: .18rem .45rem;
  font-size: .74rem;
}
.erp-edit-field {
  opacity: .72;
  flex: 0 0 auto;
}
.erp-field-row:hover .erp-edit-field {
  opacity: 1;
}
.erp-field-editor {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: .35rem;
  width: 100%;
}
.erp-field-editor input {
  min-height: 30px;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: .25rem .45rem;
}
.erp-invoice-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .55rem;
  margin-bottom: .7rem;
}
.erp-invoice-summary div {
  border: 1px solid var(--border);
  border-radius: 7px;
  background: #fbfbfb;
  padding: .55rem .65rem;
}
.erp-invoice-summary span,
.erp-invoice-summary strong {
  display: block;
}
.erp-invoice-summary span {
  color: var(--text-muted);
  font-size: .74rem;
  font-weight: 800;
}
.erp-invoice-summary strong {
  color: var(--rouge);
  font-size: 1.05rem;
}
.erp-table-wrap {
  overflow-x: auto;
}
.erp-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .84rem;
}
.erp-table th,
.erp-table td {
  border-bottom: 1px solid var(--border);
  padding: .48rem .45rem;
  text-align: left;
  vertical-align: top;
}
.erp-table th {
  color: var(--text-muted);
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .02em;
}
.erp-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: .16rem .45rem;
  font-size: .72rem;
  font-weight: 900;
}
.erp-pill--ok {
  color: #1a7a45;
  background: #eefaf3;
}
.erp-pill--due {
  color: var(--rouge);
  background: var(--rouge-light);
}
.extranet-readiness-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .85rem;
  align-items: start;
}
.extranet-readiness-grid h3 {
  margin: 0 0 .55rem;
  font-size: .92rem;
}
.extranet-readiness-grid section {
  display: grid;
  gap: .5rem;
}

/* ── Trésorerie ────────────────────────────────────────────────────────────── */
.treasury-toolbar {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: center;
  margin-bottom: .85rem;
}
.treasury-toolbar h2 {
  margin: 0;
  font-size: 1rem;
}
.treasury-toolbar__actions {
  display: flex;
  align-items: center;
  gap: .75rem;
}
.treasury-campaign-scope-tabs {
  margin-bottom: .85rem;
}
.treasury-card--archived {
  background: #f5f5f5;
}
.treasury-card__tariffs {
  color: var(--text-muted);
  font-size: .78rem;
  margin-top: .35rem;
}
.treasury-tariff-panel {
  border: 1px solid var(--border);
  border-radius: 7px;
  background: #fff;
  padding: .75rem;
  margin-bottom: .85rem;
}
.treasury-tariff-panel--empty {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
}
.treasury-tariff-panel__head {
  display: flex;
  justify-content: space-between;
  gap: .75rem;
  align-items: baseline;
  margin-bottom: .65rem;
}
.treasury-tariff-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .65rem;
}
.treasury-tariff-grid--readonly input {
  max-width: 100%;
}
.treasury-campaign-modal {
  max-width: 560px;
}
@media (max-width: 720px) {
  .treasury-tariff-grid {
    grid-template-columns: 1fr;
  }
}
.treasury-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: .75rem;
}
.treasury-card,
.treasury-detail,
.treasury-members {
  border: 1px solid var(--border);
  border-radius: 7px;
  background: #fbfbfb;
  padding: .8rem;
}
.treasury-card strong,
.treasury-card span {
  display: block;
}
.treasury-card > span {
  color: var(--text-muted);
  font-size: .82rem;
  margin-top: .2rem;
}
.treasury-card__amounts {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .45rem;
  margin: .75rem 0;
}
.treasury-card__amounts div {
  border: 1px solid var(--border);
  border-radius: 6px;
  background: #fff;
  padding: .45rem .5rem;
}
.treasury-card__amounts span {
  color: var(--text-muted);
  font-size: .72rem;
  font-weight: 800;
}
.treasury-actions {
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: .45rem;
}
.treasury-members {
  margin-top: 1rem;
}
.treasury-members-head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: .75rem;
  margin-bottom: .75rem;
}
.treasury-members-head h3 {
  margin: 0 0 .25rem;
  font-size: .95rem;
}
.treasury-members-tools {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  align-items: center;
}
.treasury-members-search {
  min-width: min(280px, 100%);
  padding: .45rem .6rem;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: .86rem;
}
.treasury-filter-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  margin-bottom: .75rem;
}
.treasury-filter-tab {
  border: 1px solid var(--border);
  background: #fff;
  border-radius: 999px;
  padding: .28rem .7rem;
  font-size: .8rem;
  font-weight: 700;
  cursor: pointer;
}
.treasury-filter-tab.is-active {
  background: var(--rouge-light);
  border-color: rgba(185, 0, 58, .25);
  color: var(--rouge);
}
.treasury-row--due {
  background: rgba(185, 0, 58, .04);
}
.treasury-reminder-modal {
  width: min(640px, 96vw);
}
.treasury-reminder-modal textarea {
  width: 100%;
  min-height: 220px;
  padding: .55rem .65rem;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-family: inherit;
  font-size: .88rem;
  line-height: 1.45;
  resize: vertical;
}
.treasury-members h3 {
  margin: 0 0 .65rem;
  font-size: .95rem;
}
.treasury-list {
  display: grid;
  gap: .45rem;
  margin-bottom: .85rem;
}
.treasury-report-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: .75rem;
  align-items: center;
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 7px;
  background: #fff;
  padding: .65rem .75rem;
  text-align: left;
}
.treasury-report-row.is-active,
.treasury-report-row:hover {
  border-color: rgba(185,0,58,.35);
  background: #fff8fa;
}
.treasury-report-row strong,
.treasury-report-row small {
  display: block;
  overflow-wrap: anywhere;
}
.treasury-report-row small,
.treasury-report-row em {
  color: var(--text-muted);
  font-size: .8rem;
  font-style: normal;
}
.treasury-detail {
  display: grid;
  gap: .8rem;
}
.treasury-detail:empty {
  display: none;
}
.treasury-detail-head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: start;
}
.treasury-detail-head h3 {
  margin: 0 0 .2rem;
  font-size: 1rem;
}
.treasury-detail-head p {
  margin: 0;
  color: var(--text-muted);
  font-size: .84rem;
}
.treasury-detail-head__aside {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: .5rem;
  flex-shrink: 0;
}
.treasury-detail-head__aside > strong {
  color: var(--rouge);
  font-size: 1.1rem;
}
.treasury-workflow {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .5rem;
}
.treasury-workflow div {
  border: 1px solid var(--border);
  border-radius: 7px;
  background: #fff;
  padding: .55rem .65rem;
}
.treasury-workflow div.is-done {
  border-color: rgba(26,122,69,.28);
  background: #eefaf3;
}
.treasury-workflow div.is-current {
  border-color: rgba(185,0,58,.3);
  background: #fff8fa;
}
.treasury-workflow strong,
.treasury-workflow span {
  display: block;
}
.treasury-workflow strong {
  font-size: .82rem;
}
.treasury-workflow span {
  color: var(--text-muted);
  font-size: .75rem;
  margin-top: .1rem;
}
.treasury-next-action {
  border: 1px solid rgba(185,0,58,.25);
  border-radius: 7px;
  background: #fff8fa;
  padding: .7rem .8rem;
}
.treasury-next-action strong,
.treasury-next-action span {
  display: block;
}
.treasury-next-action span {
  color: var(--text-muted);
  font-size: .86rem;
  margin-top: .18rem;
}
.treasury-payment-panel {
  border: 1px solid rgba(185,0,58,.28);
  border-radius: 7px;
  background: #fff8fa;
  padding: .7rem .8rem;
}
.treasury-payment-panel strong,
.treasury-payment-panel p {
  display: block;
  margin: 0;
}
.treasury-payment-panel p {
  color: var(--text-muted);
  font-size: .84rem;
  margin-top: .2rem;
}
.treasury-item-form,
.treasury-pay-form {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: .5rem;
  align-items: center;
}
.treasury-pay-form {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  border-top: 1px solid var(--border);
  padding-top: .75rem;
}
.treasury-item-form input,
.treasury-item-form select,
.treasury-pay-form input {
  width: 100%;
  min-height: 34px;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: .35rem .5rem;
  background: #fff;
}

@media (max-width: 760px) {
  .extranet-page { padding: 1rem; }
  .extranet-hero,
  .extranet-grid,
  .extranet-preview-grid,
  .erp-layout,
  .erp-toolbar,
  .erp-stats,
  .erp-contact {
    grid-template-columns: 1fr;
  }
  .extranet-hero__status { white-space: normal; }
  .extranet-facts div { grid-template-columns: 1fr; gap: .2rem; }
  .extranet-import-row { grid-template-columns: 1fr; }
  .extranet-import-actions { justify-content: flex-start; }
  .extranet-detail-head,
  .extranet-v1-head,
  .extranet-v1-search,
  .extranet-portal-head,
  .extranet-portal-tabs,
  .extranet-field-row,
  .extranet-readiness-grid,
  .extranet-link-form,
  .extranet-account-row,
  .extranet-recipe-card,
  .extranet-detail-grid,
  .extranet-detail-row,
  .treasury-card__amounts,
  .treasury-report-row,
  .treasury-item-form,
  .treasury-pay-form {
    grid-template-columns: 1fr;
  }
  .extranet-detail-head,
  .extranet-v1-head,
  .extranet-portal-head {
    display: grid;
  }
  .member-profile-head,
  .member-profile-photo-edit,
  .member-profile-form-grid,
  .member-profile-dynamic,
  .member-profile-speciality-row {
    grid-template-columns: 1fr;
  }
  .extranet-detail-actions { justify-content: flex-start; }
}

/* ── PWA : bannière actions, pastilles nav, login ─────────────────────────── */
.pwa-action-banner {
  background: linear-gradient(90deg, var(--rouge) 0%, var(--rouge-dark) 100%);
  color: #fff;
  font-size: .88rem;
  box-shadow: 0 2px 6px rgba(0,0,0,.12);
}
.pwa-action-banner.hidden { display: none; }
.pwa-action-banner__inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .5rem 1rem;
  padding: .55rem 1.25rem;
  max-width: 1400px;
  margin: 0 auto;
}
.pwa-action-banner__title {
  font-family: 'Manrope', sans-serif;
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  opacity: .95;
}
.pwa-action-banner__links {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem .75rem;
  flex: 1;
}
.pwa-action-banner__link {
  color: #fff;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.pwa-action-banner__link:hover { opacity: .9; text-decoration: none; }
.pwa-action-banner__close {
  background: rgba(255,255,255,.2);
  border: none;
  color: #fff;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  font-size: 1.2rem;
  line-height: 1;
  flex-shrink: 0;
}
.pwa-action-banner__close:hover { background: rgba(255,255,255,.35); }
.intranet-subnav__link { position: relative; }
.nav-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.15rem;
  height: 1.15rem;
  padding: 0 .3rem;
  margin-left: .25rem;
  font-size: .65rem;
  font-weight: 700;
  line-height: 1;
  background: var(--rouge);
  color: #fff;
  border-radius: 999px;
  vertical-align: middle;
}
.intranet-subnav__link.is-current .nav-badge {
  background: #fff;
  color: var(--rouge);
}
.login-pwa-block {
  margin-top: 1.25rem;
  padding-top: 1rem;
  border-top: 1px solid var(--border);
}
.login-pwa-block .login-card__subtitle {
  margin-bottom: .65rem;
  text-align: left;
}
.login-pwa-ios {
  font-size: .78rem;
  color: var(--text-muted);
  margin-top: .5rem;
  line-height: 1.4;
}
.login-remember {
  display: flex;
  align-items: center;
  gap: .5rem;
  margin: .6rem 0 .25rem;
  padding: .65rem .75rem;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: #fafafa;
  font-size: .88rem;
  color: var(--text);
  cursor: pointer;
}
.login-remember input {
  width: auto;
  margin: 0;
  accent-color: var(--rouge);
}
