/* ============================================================================
   Formations Reanova — feuille de style
   Design hérité de l'outil V1, adapté à la spec V2 :
   - plus d'icône ni de badge sur les cartes ;
   - la couleur est portée par le domaine principal (7 domaines fixes) ;
   - matrice métier × niveau dans le détail et l'édition.
   ========================================================================== */

:root {
    --color-primary: #6366F1; --color-primary-light: #818CF8; --color-primary-dark: #4F46E5;
    --gradient-button: linear-gradient(135deg, #6366F1 0%, #8B5CF6 100%);
    --gradient-button-hover: linear-gradient(135deg, #4F46E5 0%, #7C3AED 100%);
    --shadow-card: 0 1px 3px rgba(15,23,42,0.04), 0 4px 12px rgba(15,23,42,0.03);
    --shadow-card-hover: 0 4px 16px rgba(99,102,241,0.10), 0 8px 32px rgba(15,23,42,0.06);
    --shadow-lg: 0 10px 15px -3px rgba(15,23,42,0.08), 0 4px 6px -4px rgba(15,23,42,0.05);
    --shadow-xl: 0 24px 48px rgba(15,23,42,0.16), 0 8px 16px rgba(15,23,42,0.08);
    --radius-sm: 6px; --radius-md: 10px; --radius-lg: 14px;
    --font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    --color-text: #0F172A; --color-text-muted: #475569; --color-text-light: #94A3B8;
    --color-bg: #F8FAFC; --color-surface: #FFFFFF;
    --color-danger: #EF4444;
    --transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
    --transition-base: 200ms cubic-bezier(0.4, 0, 0.2, 1);
}
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body { font-family: var(--font-sans); color: var(--color-text); background: var(--color-bg); line-height: 1.6; min-height: 100vh; }
button { font-family: var(--font-sans); }
:focus-visible { outline: 2px solid var(--color-primary); outline-offset: 2px; }

/* ----------------- Écrans d'authentification (style portail) -------------- */
/* Reprise du design + animations de la page de login de interne.reanova.fr :
   aurora de blobs flous dérivants, filet SVG qui se dessine, logo et titre en
   fondu montant. Décliné dans la couleur dédiée Formations (indigo/violet). */
.auth-stage { position: relative; isolation: isolate; min-height: 100vh; min-height: 100dvh; display: flex; align-items: center; justify-content: center; overflow: hidden; padding: 3rem 1.5rem; background: var(--color-surface); }
.auth-aurora { pointer-events: none; position: absolute; inset: 0; z-index: -1; overflow: hidden; }
.auth-blob { position: absolute; border-radius: 50%; filter: blur(90px); mix-blend-mode: multiply; will-change: transform; }
.auth-blob--a { left: -8rem; top: -10rem; width: 48rem; height: 48rem; opacity: 0.42; background: radial-gradient(closest-side, #6366F1, transparent); }
.auth-blob--b { right: -8rem; bottom: -11rem; width: 50rem; height: 50rem; opacity: 0.36; background: radial-gradient(closest-side, #7C3AED, transparent); }
.auth-blob--c { left: 50%; top: 30%; width: 44rem; height: 44rem; transform: translateX(-50%); opacity: 0.30; background: radial-gradient(closest-side, #818CF8, transparent); }
.auth-line-svg { position: absolute; inset: 0; width: 100%; height: 100%; }
.auth-veil { position: absolute; inset: 0; background: radial-gradient(40% 42% at 50% 48%, rgba(255,255,255,0.5), transparent 70%); }

.auth-content { display: flex; flex-direction: column; align-items: center; width: 100%; max-width: 24rem; text-align: center; }
.auth-content--wide { max-width: 27rem; }
.auth-logo { height: 6rem; width: auto; user-select: none; }
@media (min-width: 640px) { .auth-logo { height: 7rem; } }
.auth-underline { margin-top: 1.25rem; display: block; height: 2px; width: 4rem; border-radius: 100px; transform-origin: center; background: linear-gradient(90deg, var(--color-primary), #8B5CF6); }
.auth-title { margin-top: 1.5rem; font-size: 1.5rem; font-weight: 700; letter-spacing: -0.02em; color: var(--color-text); line-height: 1.25; }
.auth-sub { margin-top: 0.85rem; font-size: 0.88rem; color: var(--color-text-muted); line-height: 1.55; }
.auth-form { margin-top: 1.75rem; width: 100%; display: flex; flex-direction: column; gap: 1rem; text-align: left; }
.auth-form .btn-block { margin-top: 0.25rem; }
.auth-footer { margin-top: 1.5rem; font-size: 0.74rem; color: var(--color-text-light); }
.login-error { display: none; background: #FEF2F2; color: #991B1B; border: 1px solid #FECACA; padding: 0.6rem 0.9rem; border-radius: 8px; font-size: 0.82rem; margin-top: 1rem; width: 100%; }
.login-error.visible { display: block; }
.login-back { display: block; margin: 0.25rem auto 0; background: none; border: none; color: var(--color-text-muted); font-size: 0.78rem; cursor: pointer; padding: 0.3rem 0.6rem; border-radius: 6px; transition: all var(--transition-fast); }
.login-back:hover { color: var(--color-text); background: var(--color-bg); }
.otp-input { text-align: center; font-size: 1.4rem !important; letter-spacing: 0.45em; font-variant-numeric: tabular-nums; }
.otp-qr { display: flex; justify-content: center; margin: 1rem 0 0.25rem; }
.otp-qr svg { width: 180px; height: 180px; border: 1px solid #E2E8F0; border-radius: 10px; background: #fff; padding: 6px; }
.otp-secret { text-align: center; font-size: 0.74rem; color: var(--color-text-muted); margin-top: 0.6rem; word-break: break-all; }
.otp-secret code { background: #F1F5F9; padding: 0.15rem 0.4rem; border-radius: 5px; font-size: 0.72rem; user-select: all; }

/* Animations (clonées de interne.reanova.fr). */
@keyframes login-rise { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
@keyframes login-underline { from { transform: scaleX(0); } to { transform: scaleX(1); } }
@keyframes login-drift-a { 0% { transform: translate3d(0,0,0) scale(1); } 100% { transform: translate3d(48px,34px,0) scale(1.06); } }
@keyframes login-drift-b { 0% { transform: translate3d(0,0,0) scale(1); } 100% { transform: translate3d(-46px,-34px,0) scale(1.05); } }
@keyframes login-drift-c { 0% { transform: translateX(-50%) translate3d(0,0,0) scale(1); } 100% { transform: translateX(-50%) translate3d(30px,-30px,0) scale(1.04); } }
@keyframes login-draw { 0% { stroke-dashoffset: 1; } 100% { stroke-dashoffset: 0; } }
.login-rise { animation: login-rise 560ms var(--ease-out-quart, cubic-bezier(0.25,1,0.5,1)) both; }
.login-underline { animation: login-underline 500ms var(--ease-out-quart, cubic-bezier(0.25,1,0.5,1)) both; animation-delay: 250ms; }
.login-blob-a { animation: login-drift-a 26s ease-in-out infinite alternate; }
.login-blob-b { animation: login-drift-b 32s ease-in-out infinite alternate; }
.login-blob-c { animation: login-drift-c 38s ease-in-out infinite alternate; }
.login-line { animation: login-draw 7s ease-in-out infinite alternate; }
@media (prefers-reduced-motion: reduce) {
  .login-blob-a, .login-blob-b, .login-blob-c { animation: none !important; }
  .login-line { animation: none !important; stroke-dashoffset: 0 !important; }
  .login-underline { animation: none !important; transform: scaleX(1) !important; }
  .login-rise { animation: none !important; }
}

/* ------------------------------- Navbar ---------------------------------- */
.navbar { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; display: flex; align-items: center; justify-content: space-between; gap: 0.75rem; padding: 0 1.5rem; height: 60px; background: rgba(15,23,42,0.93); backdrop-filter: blur(12px); border-bottom: 1px solid rgba(255,255,255,0.06); box-shadow: 0 4px 20px rgba(15,23,42,0.25); }
.navbar__brand { display: flex; align-items: center; gap: 0.7rem; color: #fff; min-width: 0; flex-shrink: 1; overflow: hidden; }
.navbar__logo { width: 34px; height: 34px; background: var(--gradient-button); border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 1rem; box-shadow: 0 2px 8px rgba(99,102,241,0.3); flex-shrink: 0; }
.navbar__title { font-size: 1.05rem; font-weight: 700; letter-spacing: -0.01em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.navbar__actions { display: flex; align-items: center; gap: 0.35rem; flex-wrap: nowrap; flex-shrink: 0; }
.navbar__btn { display: inline-flex; align-items: center; justify-content: center; height: 36px; padding: 0 0.8rem; gap: 0.35rem; border: none; border-radius: 8px; background: rgba(255,255,255,0.07); color: rgba(255,255,255,0.65); cursor: pointer; transition: all var(--transition-fast); font-size: 0.8rem; font-weight: 500; white-space: nowrap; }
.navbar__btn:hover { background: rgba(255,255,255,0.13); color: rgba(255,255,255,0.95); }
.navbar__btn--primary { background: var(--gradient-button); color: #fff; }
.navbar__btn--primary:hover { background: var(--gradient-button-hover); color: #fff; }
.navbar__badge { background: #F97066; color: #fff; padding: 0.1rem 0.45rem; border-radius: 100px; font-size: 0.7rem; font-weight: 700; }
.navbar__user { display: inline-flex; align-items: center; gap: 0.5rem; height: 36px; padding: 0 0.4rem 0 0.75rem; border-radius: 100px; background: rgba(255,255,255,0.07); color: rgba(255,255,255,0.85); font-size: 0.78rem; }
.navbar__user-role { font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.05em; font-weight: 700; padding: 0.1rem 0.45rem; border-radius: 100px; background: rgba(255,255,255,0.12); }
.navbar__user-role--admin { background: #F97066; color: #fff; }
.navbar__user-role--manager { background: #38BDF8; color: #0C4A6E; }

/* --------------------------- Recherche + filtres -------------------------- */
.search-section { max-width: 1200px; margin: 1.5rem auto 0; padding: 0 1.5rem; }
.search-wrapper { background: var(--color-surface); border-radius: var(--radius-md); border: 1px solid rgba(0,0,0,0.06); box-shadow: var(--shadow-card); padding: 0.7rem 1.25rem; display: flex; align-items: center; gap: 0.75rem; }
.search-wrapper:focus-within { border-color: #6366F1; box-shadow: 0 0 0 3px rgba(99,102,241,0.12); }
.search-icon { font-size: 1.05rem; color: var(--color-text-light); }
.search-input { flex: 1; border: none; outline: none; font-size: 0.95rem; font-family: var(--font-sans); color: var(--color-text); background: transparent; }
.search-input::placeholder { color: var(--color-text-light); }
.filters-section { max-width: 1200px; margin: 0.85rem auto 0; padding: 0 1.5rem; display: flex; flex-direction: column; gap: 0.7rem; }
.filters-row { display: flex; gap: 0.35rem; flex-wrap: wrap; align-items: center; }
.filters-label { font-size: 0.68rem; font-weight: 700; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.06em; margin-right: 0.25rem; }
.filter-chip { padding: 0.32rem 0.75rem; border-radius: 100px; border: 1px solid transparent; background: #F1F5F9; font-size: 0.75rem; font-weight: 500; color: #475569; cursor: pointer; transition: all var(--transition-fast); }
.filter-chip:hover { border-color: #CBD5E1; color: #334155; background: #E2E8F0; }
.filter-chip.active { border-color: #6366F1; background: #EEF2FF; color: #4F46E5; font-weight: 650; }
.filter-chip--domaine { display: inline-flex; align-items: center; gap: 0.4rem; }
.filter-chip__dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }

/* --------------- Filtre matrice métier × niveau (double entrée) ----------- */
.fmx-wrap { overflow-x: auto; background: var(--color-surface); border: 1px solid rgba(0,0,0,0.06); border-radius: var(--radius-md); box-shadow: var(--shadow-card); }
.fmx { border-collapse: collapse; width: 100%; min-width: 640px; font-size: 0.78rem; }
.fmx th, .fmx td { border-bottom: 1px solid #EEF1F5; text-align: center; }
.fmx thead th { position: sticky; top: 0; background: linear-gradient(180deg, #8C8A5B, #7E7C50); color: #fff; font-weight: 650; padding: 0.5rem 0.4rem; font-size: 0.72rem; line-height: 1.2; vertical-align: middle; }
.fmx thead th.fmx-corner { background: transparent; }
.fmx-metier { cursor: pointer; user-select: none; transition: background var(--transition-fast); }
.fmx-metier:hover { background: #6f6d45; }
.fmx-niveau { text-align: left; font-weight: 650; color: var(--color-text); white-space: nowrap; padding: 0.45rem 0.85rem 0.45rem 0.7rem; cursor: pointer; user-select: none; position: sticky; left: 0; background: var(--color-surface); }
.fmx-niveau:hover { color: var(--color-primary-dark); }
.fmx tbody tr:nth-child(even) td, .fmx tbody tr:nth-child(even) .fmx-niveau { background: #F8FAFC; }
.fmx tbody tr:first-child .fmx-niveau, .fmx tbody tr:first-child td { background: #FBFBF4; } /* ligne « Tout » */
.fmx-cell { cursor: pointer; color: #B6BDC7; font-size: 0.95rem; line-height: 1; padding: 0.4rem 0.5rem; transition: all var(--transition-fast); user-select: none; }
.fmx-cell:hover { background: #EEF2FF; color: var(--color-primary); }
.fmx-cell.active { color: var(--color-primary-dark); font-weight: 700; background: #EEF2FF; }
.fmx-cell.dimmed { color: #DDE3EA; background: #F1F5F9; }
.fmx-cell.dimmed.active { color: var(--color-primary-dark); background: #E0E7FF; }
.fmx-cell:focus-visible { outline: 2px solid var(--color-primary); outline-offset: -2px; }
.fmx-domaines { padding-top: 0.1rem; }
.fmx-reset { margin-left: auto; padding: 0.32rem 0.75rem; border-radius: 100px; border: 1px solid #FECACA; background: #FEF2F2; color: #991B1B; font-size: 0.74rem; font-weight: 600; cursor: pointer; transition: all var(--transition-fast); }
.fmx-reset:hover { background: #FEE2E2; }

/* --------------------------- Groupes de tuiles --------------------------- */
.card-host { display: flex; flex-direction: column; gap: 1.9rem; }
.group__title { display: flex; align-items: center; gap: 0.55rem; font-size: 1.05rem; font-weight: 700; color: var(--color-text); margin-bottom: 0.9rem; padding-bottom: 0.5rem; border-bottom: 2px solid #E2E8F0; letter-spacing: -0.01em; }
.group__count { font-size: 0.78rem; font-weight: 600; color: var(--color-text-muted); background: #F1F5F9; border: 1px solid #E2E8F0; border-radius: 100px; padding: 0.05rem 0.5rem; }

/* -------------------------------- Section -------------------------------- */
.section { max-width: 1200px; margin: 0 auto; padding: 1.5rem 1.5rem 4rem; }
.section__header { text-align: center; margin-bottom: 1.6rem; }
.section__title { font-size: 1.5rem; font-weight: 750; letter-spacing: -0.02em; margin-bottom: 0.3rem; }
.section__description { font-size: 0.9rem; color: var(--color-text-muted); max-width: 520px; margin: 0 auto; }

/* --------------------------------- Cartes -------------------------------- */
.card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(310px, 1fr)); gap: 1.4rem; }
.card { position: relative; background: var(--color-surface); border: 1px solid rgba(226,232,240,0.8); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-card); transition: all var(--transition-base); display: flex; flex-direction: column; }
.card:hover { transform: translateY(-2px); box-shadow: var(--shadow-card-hover); }
.card__visual { position: relative; height: 56px; display: flex; align-items: center; padding: 0 1.15rem; flex-shrink: 0; }
.card__visual-pattern { position: absolute; inset: 0; opacity: 0.10; background-image: radial-gradient(circle at 25% 25%, rgba(255,255,255,0.55) 1px, transparent 1px), radial-gradient(circle at 75% 75%, rgba(255,255,255,0.55) 1px, transparent 1px); background-size: 22px 22px; }
.card__domaine { position: relative; font-size: 0.7rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.08em; }
.card__body { padding: 0.95rem 1.15rem 1.15rem; display: flex; flex-direction: column; flex: 1; gap: 0.55rem; }
.card__title { font-size: 1rem; font-weight: 650; line-height: 1.35; letter-spacing: -0.01em; }
.card__session { font-size: 0.76rem; font-weight: 600; color: #4F46E5; display: inline-flex; align-items: center; gap: 0.35rem; }
.card__session--vide { color: var(--color-text-light); font-weight: 500; }
.card__meta { display: flex; flex-wrap: wrap; gap: 0.3rem; align-items: center; }
.niveau-tag { padding: 0.14rem 0.5rem; border-radius: 6px; font-size: 0.62rem; font-weight: 700; background: #F1F5F9; color: #334155; border: 1px solid #E2E8F0; }
.niveau-tag--D { background: #ECFEFF; color: #155E75; border-color: #A5F3FC; }
.niveau-tag--1 { background: #ECFDF5; color: #065F46; border-color: #A7F3D0; }
.niveau-tag--2 { background: #FEF9C3; color: #854D0E; border-color: #FDE68A; }
.niveau-tag--3 { background: #FFE4E6; color: #9F1239; border-color: #FECDD3; }
.niveau-tag--bonus { background: #EEF2FF; color: #4338CA; border-color: #C7D2FE; }
.card__inscrits { font-size: 0.7rem; font-weight: 600; color: #4F46E5; background: #EEF2FF; padding: 0.15rem 0.55rem; border-radius: 100px; border: 1px solid #C7D2FE; }
.card__fait { font-size: 0.7rem; font-weight: 600; color: #065F46; background: #ECFDF5; padding: 0.15rem 0.55rem; border-radius: 100px; border: 1px solid #A7F3D0; }
.card__actions { display: flex; gap: 0.5rem; margin-top: auto; padding-top: 0.4rem; }
.card__actions .btn { flex: 1; justify-content: center; }

/* -------------------------------- Boutons -------------------------------- */
.btn { display: inline-flex; align-items: center; gap: 0.4rem; padding: 0.55rem 1rem; border: none; border-radius: 8px; font-size: 0.82rem; font-weight: 600; cursor: pointer; transition: all var(--transition-fast); white-space: nowrap; }
.btn-primary { background: var(--gradient-button); color: #fff; box-shadow: 0 1px 2px rgba(99,102,241,0.24), 0 2px 8px rgba(99,102,241,0.12); }
.btn-primary:hover { background: var(--gradient-button-hover); transform: translateY(-1px); }
.btn-primary:active { transform: scale(0.98); }
.btn-outline { background: var(--color-surface); color: var(--color-text); border: 1px solid rgba(0,0,0,0.12); }
.btn-outline:hover { background: var(--color-bg); border-color: rgba(0,0,0,0.2); }
.btn-success { background: #ECFDF5; color: #065F46; border: 1px solid #A7F3D0; }
.btn-success:hover { background: #D1FAE5; }
.btn-danger { background: var(--color-danger); color: #fff; }
.btn-danger:hover { background: #B91C1C; }
.btn-sm { padding: 0.35rem 0.7rem; font-size: 0.75rem; }
.btn-block { width: 100%; justify-content: center; }
.btn[disabled] { opacity: 0.6; cursor: wait; }

/* -------------------------------- Modales -------------------------------- */
.modal-backdrop { position: fixed; inset: 0; background: rgba(15,23,42,0.6); backdrop-filter: blur(4px); display: flex; align-items: center; justify-content: center; z-index: 2000; animation: fadeIn 0.15s; padding: 1rem; }
.modal { background: var(--color-surface); border-radius: var(--radius-lg); box-shadow: var(--shadow-xl); width: 100%; max-width: 600px; max-height: 92vh; overflow-y: auto; animation: slideUp 0.25s cubic-bezier(0.16,1,0.3,1); }
.modal-lg { max-width: 860px; }
.modal-header { padding: 1.15rem 1.5rem; border-bottom: 1px solid rgba(0,0,0,0.06); display: flex; align-items: center; justify-content: space-between; gap: 1rem; position: sticky; top: 0; background: var(--color-surface); z-index: 5; }
.modal-header h2 { font-size: 1.1rem; font-weight: 700; line-height: 1.3; }
.modal-close { background: none; border: none; font-size: 1.5rem; cursor: pointer; color: var(--color-text-light); line-height: 1; padding: 0.2rem 0.45rem; border-radius: 50%; transition: all var(--transition-fast); }
.modal-close:hover { color: var(--color-text); background: var(--color-bg); }
.modal-body { padding: 1.4rem 1.5rem; }
.modal-footer { padding: 1rem 1.5rem; border-top: 1px solid rgba(0,0,0,0.06); display: flex; justify-content: flex-end; gap: 0.5rem; position: sticky; bottom: 0; background: var(--color-surface); }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
@keyframes slideUp { from{opacity:0;transform:translateY(20px) scale(.98)} to{opacity:1;transform:translateY(0) scale(1)} }

/* ------------------------------ Formulaires ------------------------------ */
.form-group { margin-bottom: 1.05rem; }
.form-group label { display: block; font-size: 0.83rem; font-weight: 600; margin-bottom: 0.35rem; }
.form-group input, .form-group textarea, .form-group select { width: 100%; padding: 0.6rem 0.85rem; border: 2px solid #E2E8F0; border-radius: var(--radius-sm); font-size: 0.9rem; outline: none; transition: border-color var(--transition-fast), box-shadow var(--transition-fast); font-family: var(--font-sans); background: var(--color-surface); color: var(--color-text); }
.form-group input:focus, .form-group textarea:focus, .form-group select:focus { border-color: #6366F1; box-shadow: 0 0 0 3px rgba(99,102,241,0.12); }
.form-group textarea { resize: vertical; min-height: 76px; }
.form-hint { font-size: 0.72rem; color: var(--color-text-light); margin-top: 0.25rem; }
.form-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 0 1rem; }
@media (max-width: 640px) { .form-grid-2 { grid-template-columns: 1fr; } }

/* ----------------------- Matrice métier × niveau ------------------------- */
.matrix-wrap { overflow-x: auto; border: 1px solid #E2E8F0; border-radius: var(--radius-md); }
.matrix { width: 100%; border-collapse: collapse; font-size: 0.78rem; min-width: 560px; }
.matrix th, .matrix td { padding: 0.45rem 0.6rem; border-bottom: 1px solid #F1F5F9; text-align: center; }
.matrix th { background: var(--color-bg); font-weight: 650; color: var(--color-text-muted); font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.04em; }
.matrix td:first-child, .matrix th:first-child { text-align: left; font-weight: 600; color: var(--color-text); white-space: nowrap; position: sticky; left: 0; background: var(--color-surface); }
.matrix tr:last-child td { border-bottom: none; }
.matrix input[type="radio"] { accent-color: #6366F1; width: 15px; height: 15px; cursor: pointer; }
.matrix__niveau { display: inline-flex; min-width: 26px; justify-content: center; }

/* ----------------------------- Listes / tables --------------------------- */
.data-table { width: 100%; border-collapse: collapse; font-size: 0.83rem; }
.data-table th, .data-table td { text-align: left; padding: 0.55rem 0.7rem; border-bottom: 1px solid #F1F5F9; }
.data-table th { background: var(--color-bg); font-weight: 600; color: var(--color-text-muted); font-size: 0.74rem; text-transform: uppercase; letter-spacing: 0.04em; }
.data-table tr:hover td { background: #F8FAFC; }
.table-wrap { overflow-x: auto; }
.pill-list { list-style: none; display: flex; flex-wrap: wrap; gap: 0.3rem; }
.pill-list li { font-size: 0.72rem; font-weight: 500; color: #4F46E5; background: #EEF2FF; padding: 0.18rem 0.55rem; border-radius: 100px; border: 1px solid #C7D2FE; }
.pill-list li.done { color: #065F46; background: #ECFDF5; border-color: #A7F3D0; }
.detail-rows { display: flex; flex-direction: column; gap: 0.55rem; margin-bottom: 1.1rem; }
.detail-row { display: flex; gap: 0.6rem; font-size: 0.85rem; }
.detail-row dt { min-width: 150px; font-weight: 600; color: var(--color-text-muted); }
.detail-row dd { flex: 1; word-break: break-word; }
.detail-section-title { font-size: 0.85rem; font-weight: 700; margin: 1.1rem 0 0.5rem; }
.dbx { display: flex; flex-direction: column; gap: 0.45rem; }
.dbx-actions { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.dbx-actions .btn { text-decoration: none; }
.dbx-path { font-size: 0.74rem; word-break: break-all; background: #F1F5F9; border: 1px solid #E2E8F0; border-radius: 6px; padding: 0.35rem 0.55rem; color: var(--color-text-muted); }
.empty-state { text-align: center; padding: 3.5rem 1rem; color: var(--color-text-light); font-size: 1.05rem; }
.empty-state-icon { font-size: 2.6rem; margin-bottom: 0.8rem; opacity: 0.5; }
.muted { color: var(--color-text-light); font-size: 0.8rem; }

/* --------------------------------- Toasts -------------------------------- */
.toast-container { position: fixed; top: 5rem; right: 1.5rem; z-index: 3000; display: flex; flex-direction: column; gap: 0.5rem; }
.toast { padding: 0.8rem 1.4rem; border-radius: var(--radius-md); font-size: 0.88rem; font-weight: 500; box-shadow: var(--shadow-lg); animation: toastIn 0.3s cubic-bezier(0.16,1,0.3,1); max-width: 380px; }
.toast-success { background: #ECFDF5; color: #065F46; border: 1px solid #A7F3D0; }
.toast-error { background: #FEF2F2; color: #991B1B; border: 1px solid #FECACA; }
@keyframes toastIn { from{opacity:0;transform:translateX(40px)} to{opacity:1;transform:translateX(0)} }

/* -------------------------------- Footer --------------------------------- */
.footer { text-align: center; padding: 2rem 1.5rem; font-size: 0.78rem; color: var(--color-text-light); border-top: 1px solid rgba(0,0,0,0.05); }

/* ------------------------------- Responsive ------------------------------ */
@media (max-width: 1024px) { .card-grid { grid-template-columns: repeat(2, 1fr); } }
/* Navbar serrée : dès qu'on manque de place, les boutons passent en icônes
   seules (le titre reste) pour éviter tout chevauchement avec le titre. */
@media (max-width: 1080px) { .navbar__btn .btn-label { display: none; } }
@media (max-width: 680px) {
    .navbar { padding: 0 0.7rem; } .navbar__title { display: none; }
    .section { padding: 1rem 0.75rem 3rem; } .search-section, .filters-section { padding: 0 0.75rem; }
    .card-grid { grid-template-columns: 1fr; gap: 1rem; }
    .filters-label { min-width: 0; width: 100%; }
    .detail-row { flex-direction: column; gap: 0.1rem; } .detail-row dt { min-width: 0; }
}
