/* ===========================================================
   CAPE 31 – Adhésions
   Palette teal (petite enfance), polices système (RGPD-friendly)
   =========================================================== */

.cape31-wrap,
.cape31-admin {
	--c31-font: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	--c31-ink: #1e2a30;
	--c31-muted: #5d6b72;
	--c31-accent: #2f8f83;
	--c31-accent-dark: #246b62;
	--c31-accent-soft: #e9f4f1;
	--c31-card: #ffffff;
	--c31-border: #e2e7e6;
	--c31-line: #eef1f0;
	--c31-star: #d1453b;
	--c31-radius: 14px;
	--c31-radius-sm: 9px;
	--c31-shadow: 0 1px 2px rgba(20,40,40,.05), 0 8px 24px rgba(20,40,40,.05);
	max-width: 100%;
}

/* Override agressif de la police imposée par le thème (ex. monospace) */
.cape31-wrap, .cape31-wrap *,
.cape31-admin, .cape31-admin * {
	font-family: var(--c31-font);
	box-sizing: border-box;
}

.cape31-wrap {
	max-width: 680px;
	margin: 0 auto;
	color: var(--c31-ink);
	line-height: 1.55;
	-webkit-font-smoothing: antialiased;
}

/* En-tête */
.cape31-head { margin-bottom: 22px; }
.cape31-head h2 {
	font-size: clamp(1.7rem, 4vw, 2.25rem);
	font-weight: 700;
	letter-spacing: -.02em;
	line-height: 1.1;
	margin: 0 0 8px;
	color: var(--c31-ink);
}
.cape31-sub { margin: 0; color: var(--c31-muted); font-size: .98rem; }
.cape31-star { color: var(--c31-star); font-weight: 700; }

/* Sections (cartes) */
.cape31-section {
	background: var(--c31-card);
	border: 1px solid var(--c31-border);
	border-radius: var(--c31-radius);
	box-shadow: var(--c31-shadow);
	padding: 22px 22px 24px;
	margin: 0 0 18px;
}
.cape31-eyebrow {
	margin: 0 0 16px;
	font-size: .72rem;
	font-weight: 700;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--c31-accent);
}
.cape31-help {
	margin: -8px 0 16px;
	font-size: .86rem;
	color: var(--c31-muted);
}

/* Champs */
.cape31-field { margin: 0 0 16px; }
.cape31-field:last-child { margin-bottom: 0; }
.cape31-field label {
	display: block;
	font-weight: 600;
	font-size: .92rem;
	margin-bottom: 6px;
	color: var(--c31-ink);
}
.cape31-field input[type="text"],
.cape31-field input[type="email"],
.cape31-field input[type="tel"],
.cape31-field input[type="number"],
.cape31-field select,
.cape31-admin input[type="text"],
.cape31-admin input[type="email"],
.cape31-admin input[type="number"],
.cape31-admin select,
.cape31-admin textarea {
	width: 100%;
	padding: 11px 13px;
	font-size: 1rem;
	color: var(--c31-ink);
	background: #fff;
	border: 1px solid #cdd6d4;
	border-radius: var(--c31-radius-sm);
	transition: border-color .15s ease, box-shadow .15s ease;
}
.cape31-field input:focus,
.cape31-field select:focus,
.cape31-admin input:focus,
.cape31-admin select:focus,
.cape31-admin textarea:focus {
	outline: none;
	border-color: var(--c31-accent);
	box-shadow: 0 0 0 3px var(--c31-accent-soft);
}
.cape31-field input::placeholder { color: #9aa6a4; }
.cape31-help { font-weight: 400; }
.cape31-field .cape31-help { display: block; margin: 6px 0 0; font-size: .8rem; }

/* Ligne compacte agréments + logée Mairie (résiste aux styles du thème) */
.cape31-form .cape31-creche-line {
	display: flex !important;
	flex-wrap: wrap;
	gap: 14px;
	align-items: flex-start;
}
.cape31-form .cape31-creche-line .cape31-field { margin: 0; float: none; flex: 0 0 auto; }
.cape31-form .cape31-creche-line label { white-space: nowrap; }
.cape31-form .cape31-field-agr input { width: 110px; }
.cape31-form .cape31-field-mairie select { width: 130px; }

/* Cartes crèche */
.cape31-creche {
	border: 1px solid var(--c31-line);
	border-radius: var(--c31-radius);
	background: #fbfdfc;
	padding: 16px 16px 18px;
	margin-bottom: 14px;
}
.cape31-creche-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 14px;
}
.cape31-badge {
	display: inline-block;
	font-size: .78rem;
	font-weight: 700;
	letter-spacing: .04em;
	color: var(--c31-accent-dark);
	background: var(--c31-accent-soft);
	border-radius: 999px;
	padding: 4px 12px;
}
.cape31-remove {
	background: none;
	border: none;
	color: var(--c31-muted);
	font-size: .82rem;
	cursor: pointer;
	padding: 4px 6px;
	border-radius: 6px;
	text-decoration: underline;
}
.cape31-remove:hover { color: var(--c31-star); }

/* Groupe radio en ligne : question + Oui/Non sur la même ligne */
.cape31-radio-inline {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px 14px;
	margin: 0 0 18px;
}
.cape31-radio-inline .cape31-q {
	font-weight: 600;
	font-size: .92rem;
	color: var(--c31-ink);
	margin-right: 2px;
}
.cape31-choice {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-right: 12px;
	padding: 9px 16px;
	border: 1px solid #cdd6d4;
	border-radius: 999px;
	cursor: pointer;
	font-size: .95rem;
	transition: border-color .15s, background .15s;
}
.cape31-choice:hover { border-color: var(--c31-accent); }
.cape31-choice input { accent-color: var(--c31-accent); margin: 0; }
.cape31-choice:has(input:checked) {
	border-color: var(--c31-accent);
	background: var(--c31-accent-soft);
	color: var(--c31-accent-dark);
	font-weight: 600;
}

/* Récapitulatif (élément signature) */
.cape31-recap {
	border: 1px solid var(--c31-border);
	border-radius: var(--c31-radius);
	overflow: hidden;
	background: #fff;
}
.cape31-recap-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 12px 16px;
	border-bottom: 1px solid var(--c31-line);
	font-size: .95rem;
	color: var(--c31-muted);
}
.cape31-recap-row strong { color: var(--c31-ink); font-size: 1.05rem; font-variant-numeric: tabular-nums; }
.cape31-recap-total {
	background: var(--c31-accent-soft);
	border-bottom: none;
	color: var(--c31-accent-dark);
}
.cape31-recap-total span { font-weight: 600; }
.cape31-recap-total strong { color: var(--c31-accent-dark); font-size: 1.45rem; font-weight: 800; }

/* Boutons */
.cape31-btn,
.cape31-btn-ghost,
.cape31-btn-sec,
.cape31-btn-quittance,
.cape31-btn-danger {
	cursor: pointer;
	font-size: 1rem;
	font-weight: 600;
	border-radius: var(--c31-radius-sm);
	border: 1px solid transparent;
	transition: background .15s ease, border-color .15s ease, transform .05s ease;
}
.cape31-btn {
	display: inline-block;
	width: 100%;
	padding: 14px 22px;
	background: var(--c31-accent);
	color: #fff;
	box-shadow: 0 2px 8px rgba(47,143,131,.25);
}
.cape31-btn:hover { background: var(--c31-accent-dark); }
.cape31-btn:active { transform: translateY(1px); }
.cape31-btn:disabled { opacity: .55; cursor: not-allowed; box-shadow: none; }
.cape31-btn-ghost {
	background: #fff;
	color: var(--c31-accent-dark);
	border-color: var(--c31-accent);
	padding: 10px 16px;
}
.cape31-btn-ghost:hover { background: var(--c31-accent-soft); }

/* Messages */
.cape31-message {
	padding: 13px 16px;
	border-radius: var(--c31-radius-sm);
	margin-bottom: 18px;
	font-size: .95rem;
	border: 1px solid transparent;
}
.cape31-info { background: var(--c31-accent-soft); border-color: #c7e6df; color: var(--c31-accent-dark); }
.cape31-warning { background: #fdf6e7; border-color: #f0dcae; color: #8a6516; }
.cape31-success { background: #eafaef; border-color: #b7e8c6; color: #1a7f37; }
.cape31-error { background: #fdeceb; border-color: #f5c2c0; color: #b32d2e; }

.cape31-restricted {
	max-width: 680px; margin: 0 auto;
	padding: 16px 18px;
	background: #fbfdfc;
	border: 1px dashed var(--c31-border);
	border-radius: var(--c31-radius);
	color: var(--c31-muted);
	font-family: var(--c31-font);
}

/* ---- Interface de gestion [cape31_admin] ---- */
.cape31-admin { max-width: 1040px; margin: 0 auto; color: var(--c31-ink); line-height: 1.5; }
.cape31-admin h2 { font-size: 1.6rem; font-weight: 700; letter-spacing: -.01em; margin: 0 0 18px; }
.cape31-tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--c31-border); margin: 0 0 22px; }
.cape31-tabs a {
	padding: 11px 20px;
	text-decoration: none;
	color: var(--c31-muted);
	font-weight: 600;
	border-bottom: 2px solid transparent;
	margin-bottom: -1px;
}
.cape31-tabs a:hover { color: var(--c31-accent-dark); }
.cape31-tabs a.cape31-tab-active { color: var(--c31-accent-dark); border-bottom-color: var(--c31-accent); }

.cape31-admin-form { max-width: 560px; }
.cape31-admin-form .cape31-field label { display: block; font-weight: 600; font-size: .92rem; margin-bottom: 6px; }
.cape31-admin-form textarea { min-height: 64px; }
.cape31-admin-form .cape31-btn { width: auto; }

.cape31-year-form { margin: 0 0 16px; }
.cape31-year-form select { padding: 9px 12px; border: 1px solid #cdd6d4; border-radius: var(--c31-radius-sm); }

.cape31-table-wrap { width: 100%; max-width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; border: 1px solid var(--c31-border); border-radius: var(--c31-radius); }
.cape31-table { width: 100%; border-collapse: collapse; font-size: .9rem; background: #fff; }
.cape31-table th, .cape31-table td { text-align: left; padding: 12px 14px; border-bottom: 1px solid var(--c31-line); vertical-align: top; }
.cape31-table thead th { background: #f6f9f8; font-weight: 700; color: var(--c31-ink); white-space: nowrap; }
.cape31-table tbody tr:last-child td { border-bottom: none; }
.cape31-table tbody tr:hover { background: #fbfdfc; }
.cape31-muted { color: var(--c31-muted); font-size: .8rem; }
.cape31-paid { color: #1a7f37; font-weight: 700; }
.cape31-pending { color: #b32d2e; font-weight: 700; }
.cape31-total { margin-top: 14px; font-size: 1.05rem; }
.cape31-inline-form { margin: 0; }
.cape31-btn-small { width: auto; padding: 7px 14px; font-size: .82rem; box-shadow: none; }

/* Responsive */
@media (max-width: 560px) {
	.cape31-section { padding: 18px 16px 20px; }
}

/* Accessibilité : focus clavier visible + mouvement réduit */
.cape31-wrap a:focus-visible,
.cape31-wrap button:focus-visible,
.cape31-admin a:focus-visible,
.cape31-admin button:focus-visible {
	outline: 2px solid var(--c31-accent-dark);
	outline-offset: 2px;
}
@media (prefers-reduced-motion: reduce) {
	.cape31-wrap *, .cape31-admin * { transition: none !important; }
}

/* ---- Réglages : section e-mail + pièces jointes ---- */
.cape31-admin-form .cape31-sep { border: none; border-top: 1px solid var(--c31-border); margin: 22px 0 16px; }
.cape31-admin-form .cape31-eyebrow { margin: 0 0 14px; }
.cape31-admin-form textarea[name="email_body"] { font-family: var(--c31-font); line-height: 1.5; }
.cape31-admin-form .cape31-help { display: block; margin-top: 6px; font-size: .82rem; color: var(--c31-muted); font-weight: 400; }
.cape31-admin-form .cape31-help code {
	background: var(--c31-accent-soft); color: var(--c31-accent-dark);
	padding: 1px 5px; border-radius: 5px; font-size: .82em;
}
.cape31-attachments { list-style: none; margin: 0 0 10px; padding: 0; }
.cape31-attachments li {
	display: flex; align-items: center; gap: 12px;
	padding: 8px 12px; border: 1px solid var(--c31-line); border-radius: var(--c31-radius-sm);
	margin-bottom: 6px; background: #fbfdfc;
}
.cape31-remove-att { font-size: .82rem; color: var(--c31-muted); margin-left: auto; }
.cape31-admin-form input[type="file"] { display: block; margin-top: 8px; font-size: .9rem; }

/* ---- Filtres + actions de la liste ---- */
.cape31-filters {
	display: flex; flex-wrap: wrap; align-items: center; gap: 10px;
	margin: 0 0 16px;
}
.cape31-filters label { display: inline-flex; align-items: center; gap: 6px; font-size: .9rem; color: var(--c31-muted); }
.cape31-filters select,
.cape31-filters input[type="text"],
.cape31-filters input[type="search"] {
	padding: 8px 11px; border: 1px solid #cdd6d4; border-radius: var(--c31-radius-sm); font-size: .92rem;
}
.cape31-filters input[type="text"],
.cape31-filters input[type="search"] { min-width: 240px; flex: 1 1 200px; }
.cape31-reset { font-size: .85rem; color: var(--c31-muted); }
.cape31-actions { display: flex; flex-direction: column; gap: 6px; align-items: stretch; width: 152px; max-width: 152px; }
.cape31-actions .cape31-inline-form { width: 100%; }
.cape31-actions .cape31-btn-small { width: 100%; text-align: center; }
.cape31-actions a, .cape31-actions button { white-space: normal !important; word-break: break-word; padding-left: 8px; padding-right: 8px; }

/* ---- Boutons secondaires + quittance + historique ---- */
.cape31-btn-sec {
	background: var(--c31-accent-soft);
	color: var(--c31-accent-dark);
	border-color: var(--c31-accent);
}
.cape31-btn-sec:hover { background: #dcefe9; }
.cape31-btn-quittance {
	background: #fff;
	color: var(--c31-accent-dark);
	border-color: var(--c31-accent);
}
.cape31-btn-quittance:hover { background: var(--c31-accent-soft); }
.cape31-actions-note { font-size: .78rem; color: var(--c31-muted); }
.cape31-hist { margin-top: 8px; width: 152px; max-width: 152px; }
.cape31-hist-pill {
	display: inline-block; max-width: 100%;
	font-size: .72rem; color: #1a7f37; background: #eafaef;
	border: 1px solid #b7e8c6; border-radius: 12px; padding: 3px 10px;
	white-space: normal; overflow-wrap: anywhere; cursor: help;
}
.cape31-logo-preview { display: flex; align-items: center; gap: 14px; margin-bottom: 8px; }
.cape31-logo-preview img {
	max-height: 60px; max-width: 180px; border: 1px solid var(--c31-line);
	border-radius: 8px; padding: 6px; background: #fff;
}

/* Bouton de suppression (tests) */
.cape31-btn-danger {
	background: #fdeceb;
	color: #b32d2e;
	border-color: #e8a9a6;
}
.cape31-btn-danger:hover { background: #f9d9d6; border-color: #d1453b; }

/* ---- Modale de détail ---- */
.cape31-modal[hidden] { display: none; }
.cape31-modal {
	position: fixed; inset: 0; z-index: 2147483000;
	display: flex; align-items: flex-start; justify-content: center;
	padding: 40px 16px; overflow-y: auto; -webkit-overflow-scrolling: touch;
	--c31-font: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	--c31-ink: #1e2a30; --c31-muted: #5d6b72;
	--c31-accent: #2f8f83; --c31-accent-dark: #246b62; --c31-accent-soft: #e9f4f1;
	--c31-card: #ffffff; --c31-border: #e2e7e6; --c31-line: #eef1f0; --c31-star: #d1453b;
	--c31-radius: 14px; --c31-radius-sm: 9px;
	color: var(--c31-ink); line-height: 1.5;
}
.cape31-modal, .cape31-modal * { font-family: var(--c31-font); box-sizing: border-box; }
.cape31-modal .cape31-modal-title { color: var(--c31-ink); }
.cape31-modal label { color: var(--c31-ink); }
.cape31-modal input[type="text"], .cape31-modal input[type="email"],
.cape31-modal input[type="number"], .cape31-modal select, .cape31-modal textarea {
	width: 100%; padding: 10px 12px; border: 1px solid var(--c31-border); border-radius: var(--c31-radius-sm);
	background: #fff; color: var(--c31-ink); font-size: .95rem;
}
.cape31-modal-backdrop { position: absolute; inset: 0; background: rgba(20, 32, 32, .5); }
.cape31-modal-card {
	position: relative; background: #fff; border-radius: var(--c31-radius);
	width: 100%; max-width: 560px; max-height: calc(100vh - 80px); overflow: auto;
	margin: auto; box-shadow: 0 24px 70px rgba(0, 0, 0, .3); padding: 26px 26px 28px;
}
.cape31-modal-close {
	position: sticky; top: 0; float: right; margin: -8px -8px 0 0; border: none;
	width: 34px; height: 34px; border-radius: 50%; background: #fff;
	font-size: 1.6rem; line-height: 1; cursor: pointer; color: var(--c31-muted); z-index: 2;
}
.cape31-modal-close:hover { color: var(--c31-ink); }
.cape31-modal-title { margin: 0 0 2px; font-size: 1.3rem; font-weight: 700; }
.cape31-modal-sub { margin: 0 0 18px; color: var(--c31-muted); font-size: .9rem; }
.cape31-modal .cape31-eyebrow { margin: 18px 0 8px; }
.cape31-dl { border: 1px solid var(--c31-line); border-radius: var(--c31-radius-sm); overflow: hidden; }
.cape31-dl-row {
	display: flex; justify-content: space-between; gap: 16px;
	padding: 9px 14px; border-bottom: 1px solid var(--c31-line); font-size: .9rem;
}
.cape31-dl-row:last-child { border-bottom: none; }
.cape31-dl-row span { color: var(--c31-muted); }
.cape31-dl-row strong { text-align: right; color: var(--c31-ink); }
.cape31-modal-table { width: 100%; border-collapse: collapse; font-size: .88rem; }
.cape31-modal-table th, .cape31-modal-table td { text-align: left; padding: 8px 12px; border-bottom: 1px solid var(--c31-line); }
.cape31-modal-table thead th { background: #f6f9f8; font-weight: 700; }
.cape31-modal-hist { list-style: none; margin: 0; padding: 0; font-size: .88rem; }
.cape31-modal-hist li { padding: 6px 0; border-bottom: 1px solid var(--c31-line); color: var(--c31-ink); }
.cape31-modal-hist li:last-child { border-bottom: none; }

/* ---- Onglet Accès ---- */
.cape31-access-form { max-width: 480px; margin-bottom: 8px; }
.cape31-access-form .cape31-btn { width: auto; }
.cape31-access-form .cape31-reset { margin-left: 12px; }
.cape31-actions a.cape31-btn-sec,
.cape31-actions a.cape31-btn-danger {
	text-decoration: none;
	display: inline-block;
	box-sizing: border-box;
	text-align: center;
}

/* ---- Onglet Mailing ---- */
.cape31-test-form .cape31-test-row { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.cape31-test-form input[type="email"] { flex: 1 1 240px; padding: 9px 12px; border: 1px solid #cdd6d4; border-radius: var(--c31-radius-sm); }
.cape31-test-form .cape31-btn-small { width: auto; }
.cape31-recipients {
	border: 1px solid var(--c31-border); border-radius: var(--c31-radius-sm);
	max-height: 280px; overflow: auto; padding: 10px 12px; background: #fff;
}
.cape31-rec-all { display: block; padding: 4px 0 8px; border-bottom: 1px solid var(--c31-line); margin-bottom: 6px; }
.cape31-rec-item { display: flex; align-items: center; gap: 9px; padding: 5px 0; font-size: .9rem; }
.cape31-rec-item input { margin: 0; }
.cape31-mail-body {
	background: #fbfdfc; border: 1px solid var(--c31-line); border-radius: var(--c31-radius-sm);
	padding: 12px 14px; font-size: .92rem; line-height: 1.55; white-space: pre-wrap;
}

/* ---- Sous-menu (barre de menu) ---- */
.cape31-subtabs {
	display: flex; flex-wrap: wrap; gap: 4px; margin: 0 0 22px;
	width: 100%; box-sizing: border-box;
	padding: 6px; background: #e3efed; border: 1px solid var(--c31-border, #d7e2df); border-radius: 14px;
}
.cape31-subtabs a {
	padding: 8px 20px; border-radius: 999px; text-decoration: none;
	font-weight: 600; font-size: .9rem; color: var(--c31-muted, #5d6b72);
	background: transparent; border: 1px solid transparent;
}
.cape31-subtabs a:hover { color: var(--c31-accent-dark, #246b62); }
.cape31-subtabs a.cape31-subtab-active { background: var(--c31-accent, #2f8f83); color: #fff; }

/* ---- Pièces jointes du mailing (multi + retrait) ---- */
.cape31-attach-row { display: flex; gap: 10px; align-items: center; margin-bottom: 8px; }
.cape31-attach-row input[type="file"] { flex: 1 1 auto; font-size: .9rem; }
.cape31-remove-attach {
	background: #fff; border: 1px solid #e8a9a6; color: #b32d2e;
	border-radius: 8px; padding: 6px 11px; cursor: pointer; font-size: .82rem; white-space: nowrap;
}
.cape31-remove-attach:hover { background: #fdeceb; }
.cape31-add-attach { margin-top: 4px; }

/* ---- Bibliothèque de documents ---- */
.cape31-pill {
	display: inline-block; background: var(--c31-accent-soft, #e9f4f1); color: var(--c31-accent-dark, #246b62);
	border: 1px solid var(--c31-accent, #2f8f83); border-radius: 999px; padding: 2px 10px; font-size: .8rem; font-weight: 600;
}
.cape31-search { flex: 1 1 220px; padding: 9px 12px; border: 1px solid #cdd6d4; border-radius: var(--c31-radius-sm); }
.cape31-link-btn {
	background: none; border: none; padding: 0; cursor: pointer; color: var(--c31-accent-dark, #246b62);
	font-weight: 600; font-size: .88rem; text-decoration: underline;
}
.cape31-link-btn:hover { color: var(--c31-accent, #2f8f83); }
.cape31-actions a.cape31-btn { text-decoration: none; display: inline-block; box-sizing: border-box; text-align: center; }

/* ---- Espace adhérents : connexion ---- */
.cape31-login { max-width: 460px; }
.cape31-login-info {
	background: #fbfdfc; border: 1px solid var(--c31-line, #eef1f0); border-left: 3px solid var(--c31-accent, #2f8f83);
	border-radius: var(--c31-radius-sm, 10px); padding: 12px 16px; margin: 14px 0 18px; font-size: .92rem; line-height: 1.5;
}
.cape31-login-info p { margin: 0 0 8px; }
.cape31-login-info p:last-child { margin-bottom: 0; }
.cape31-login .login-username,
.cape31-login .login-password { margin-bottom: 12px; }
.cape31-login label { display: block; font-weight: 600; font-size: .9rem; margin-bottom: 5px; }
.cape31-login input[type="text"],
.cape31-login input[type="password"] { width: 100%; padding: 10px 12px; border: 1px solid #cdd6d4; border-radius: var(--c31-radius-sm, 10px); box-sizing: border-box; }
.cape31-login .button,
.cape31-login #wp-submit { background: var(--c31-accent, #2f8f83); color: #fff; border: none; padding: 11px 20px; border-radius: var(--c31-radius-sm, 10px); font-weight: 600; cursor: pointer; }
.cape31-login-links { margin-top: 14px; }

/* ---- Bibliothèque : barre d'outils + catégories ---- */
.cape31-lib-toolbar { display: flex; justify-content: space-between; align-items: center; gap: 14px; flex-wrap: wrap; margin-bottom: 16px; }
.cape31-lib-toolbar .cape31-filters { margin: 0; }
.cape31-lib-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.cape31-lib-actions .cape31-btn,
.cape31-lib-actions .cape31-btn-sec { width: auto; }
.cape31-cat-row { display: flex; gap: 8px; align-items: center; margin-bottom: 8px; flex-wrap: wrap; }
.cape31-cat-edit { display: flex; gap: 8px; align-items: center; flex: 1 1 auto; }
.cape31-cat-row input[type="text"] { flex: 1 1 160px; padding: 8px 10px; border: 1px solid #cdd6d4; border-radius: 8px; }
.cape31-cat-row .cape31-btn-small,
.cape31-cat-row .cape31-btn-sec,
.cape31-cat-row .cape31-btn-danger { width: auto; }
#cape31-cats .cape31-modal-card { max-height: 82vh; overflow: auto; }

/* ---- Échanges (questions / réponses) ---- */
.cape31-thread {
	border: 1px solid var(--c31-border, #d7e2df); border-radius: var(--c31-radius, 14px);
	padding: 16px 18px; margin-bottom: 16px; background: #fff;
}
.cape31-thread-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
.cape31-thread-title { margin: 0; font-size: 1.05rem; color: var(--c31-ink, #1e2a30); }
.cape31-thread-meta { margin: 2px 0 8px; font-size: .8rem; color: var(--c31-muted, #5d6b72); }
.cape31-thread-body { font-size: .95rem; line-height: 1.55; white-space: pre-wrap; }
.cape31-replies { margin: 12px 0 4px; padding-left: 14px; border-left: 3px solid var(--c31-line, #eef1f0); }
.cape31-reply { padding: 8px 0; border-bottom: 1px dashed var(--c31-line, #eef1f0); }
.cape31-reply:last-child { border-bottom: none; }
.cape31-reply-form { display: flex; gap: 10px; align-items: flex-start; margin-top: 12px; }
.cape31-reply-form textarea { flex: 1 1 auto; padding: 9px 12px; border: 1px solid #cdd6d4; border-radius: var(--c31-radius-sm, 10px); font-family: inherit; }
.cape31-reply-form .cape31-btn-small { width: auto; white-space: nowrap; }
.cape31-reply .cape31-link-btn { font-size: .78rem; margin-left: 6px; color: #b32d2e; }

/* ---- Appels d'offres ---- */
.cape31-tender-files { margin: 10px 0 4px; padding-left: 18px; }
.cape31-tender-files li { margin: 3px 0; }

/* ---- Échanges : mise en avant des questions ---- */
.cape31-lib-toolbar { text-align: left; }
.cape31-notify-pref { margin: 0; font-size: .88rem; }
.cape31-notify-pref label {
	display: inline-flex; align-items: center; gap: 9px; cursor: pointer;
	background: #fff; border: 1px solid var(--c31-border, #d7e2df); border-radius: 999px;
	padding: 8px 16px; color: var(--c31-ink, #1e2a30); font-weight: 500;
}
.cape31-notify-pref label:hover { border-color: var(--c31-accent, #2f8f83); }
.cape31-notify-pref input[type="checkbox"] { width: 16px; height: 16px; margin: 0; accent-color: var(--c31-accent, #2f8f83); }
.cape31-thread { border: 1px solid var(--c31-border, #d7e2df); border-left: 4px solid var(--c31-accent, #2f8f83); }
.cape31-thread-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
.cape31-thread-title { flex: 1 1 auto; margin: 0; text-align: left !important; font-size: 1.15rem; font-weight: 700; }
.cape31-toggle-replies { margin-top: 4px; width: auto; }
.cape31-replies-wrap { margin-top: 12px; padding-top: 6px; border-top: 1px dashed var(--c31-line, #eef1f0); }

/* ---- Mailing : zone destinataires ---- */
.cape31-recipients-zone {
	display: block; width: 100%; text-align: left; cursor: pointer;
	background: #fff; border: 1px solid #cdd6d4; border-radius: var(--c31-radius-sm, 10px);
	padding: 11px 14px; font-size: .92rem; color: var(--c31-ink, #1e2a30);
}
.cape31-recipients-zone:hover { border-color: var(--c31-accent, #2f8f83); }
.cape31-recipients-zone .cape31-rec-edit { color: var(--c31-accent-dark, #246b62); font-weight: 600; text-decoration: underline; }
#cape31-recipients-modal .cape31-recipients { max-height: 50vh; }

/* ---- Import & notices ---- */
.cape31-notice { padding: 12px 16px; border-radius: var(--c31-radius-sm, 10px); margin: 14px 0; font-size: .92rem; }
.cape31-notice-ok { background: #eaf6f1; border: 1px solid #bfe3d6; color: #1f6b54; }
.cape31-notice-error { background: #fdeceb; border: 1px solid #f3c4c0; color: #b32d2e; }

/* ---- Édition depuis le détail ---- */
.cape31-edit-toggle { margin-top: 18px; }
.cape31-edit-wrap { margin-top: 14px; border-top: 1px solid var(--c31-line, #eef1f0); padding-top: 14px; }
.cape31-edit-form .cape31-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 0 16px; }
@media (max-width: 560px) { .cape31-edit-form .cape31-grid2 { grid-template-columns: 1fr; } }

/* ---- Bandeau récapitulatif des adhésions ---- */
.cape31-summary { display: flex; flex-wrap: wrap; gap: 12px; margin: 6px 0 18px; }
.cape31-summary-card {
	flex: 1 1 140px; display: flex; flex-direction: column; gap: 2px;
	background: var(--c31-accent-soft, #e9f4f1); border: 1px solid #cfe6e0;
	border-radius: var(--c31-radius, 14px); padding: 14px 16px;
}
.cape31-summary-num { font-size: 1.5rem; font-weight: 800; color: var(--c31-accent-dark, #246b62); line-height: 1.1; }
.cape31-summary-lbl { font-size: .82rem; color: var(--c31-muted, #5d6b72); }

/* ---- Édition des crèches dans le détail ---- */
.cape31-creche-list { display: flex; flex-direction: column; gap: 8px; margin: 6px 0 10px; }
.cape31-creche-row { display: flex; gap: 8px; align-items: center; }
.cape31-creche-row input[type="text"] { flex: 1 1 auto; min-width: 0; }
.cape31-creche-row .cape31-creche-agr { width: 92px; flex: 0 0 auto; }
.cape31-creche-row .cape31-creche-mairie { width: 120px; flex: 0 0 auto; }
.cape31-remove-creche {
	flex: 0 0 auto; width: 32px; height: 32px; border-radius: 8px;
	background: #fff; border: 1px solid #e8a9a6; color: #b32d2e; cursor: pointer; font-size: 1.1rem; line-height: 1;
}
.cape31-remove-creche:hover { background: #fdeceb; }
.cape31-add-creche { margin-bottom: 6px; }
@media (max-width: 560px) { .cape31-creche-row { flex-wrap: wrap; } .cape31-creche-row .cape31-creche-mairie { width: 100%; } }

/* ---- Bandeau « Bienvenue » + déconnexion ---- */
.cape31-userbar {
	display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px;
	background: var(--c31-accent-soft, #e9f4f1); border: 1px solid #cfe6e0;
	border-radius: var(--c31-radius, 14px); padding: 12px 18px; margin-bottom: 18px;
}
.cape31-userbar-hello { color: var(--c31-ink, #1e2a30); font-size: .98rem; }
.cape31-userbar-hello strong { color: var(--c31-accent-dark, #246b62); }
.cape31-logout { width: auto !important; text-decoration: none; white-space: nowrap; }
