@charset "UTF-8";

/* ==========================================================================
   TABLE DES MATIÈRES
   ==========================================================================
   1. CONFIGURATION & VARIABLES GLOBALES (:root)
   2. RESET & STYLES DE BASE
   3. LAYOUT PRINCIPAL (Topbar, Sidebar, Section droite)
   4. COMPOSANTS COMMUNS (Toolbar, Cartes, Badges)
   5. SECTIONS SPÉCIFIQUES (Formulaires, Tableaux/DataTables)
   6. RESPONSIVE DESIGN (breakpoints)
   7. HARMONISATION VUE-MULTISELECT / SELECT2
   8. LABELS & FORM HELP
   ========================================================================== */


/* ==========================================================================
   1) CONFIGURATION & VARIABLES GLOBALES
   ========================================================================== */
[v-cloak]{display:none!important;}

:root{
  /* Thème principal */
  --primary-dark:#146354;
  --primary-main:#2FA885;
  --primary-light:#E9FBF6;

  /* Accents & états */
  --accent:#56B2A0;
  --success:#2FA885;
  --warning:#B38B00;
  --danger:#B24D4D;
  --ring-focus:rgba(47,168,133,.35);

  /* Neutres & texte */
  --neutral-bg:#F7FAF9;
  --neutral-card:#FFFFFF;
  --text-primary:#1A202C;
  --text-secondary:#4A5568;
  --border-color:#E2E8F0;
  --border-dark:#2c3e50;

  /* Spacings / tailles */
  --card-max-width:920px;
  --card-padding:1.5rem;
  --row-gap:.875rem;

  /* Ombres */
  --shadow-sm:0 1px 2px rgba(0,0,0,.06);
  --shadow-md:0 4px 12px rgba(20,99,84,.08);
}

/* Thèmes alternatifs */
:root[data-theme="emerald"]{
  --primary-dark:#0F5132;--primary-main:#2E7D5B;--primary-light:#EAF6F0;
  --accent:#39A96B;--ring-focus:rgba(46,125,91,.35);
}
:root[data-theme="sage"]{
  --primary-dark:#3E5F50;--primary-main:#5E8A74;--primary-light:#EFF7F3;
  --accent:#8FBFA8;--ring-focus:rgba(94,138,116,.35);
}

:root{
    /* Couleurs des messages flash */
  --color-message-success-bg: #e3fcec;
    --color-message-success-text: #1f9d55;
    --color-message-success-border: #51d88a;

    --color-message-warning-bg: #fffabc;
    --color-message-warning-text: #8d7b00;
    --color-message-warning-border: #d3b800;

    --color-message-error-bg: #fcebea;
    --color-message-error-text: #cc1f1a;
    --color-message-error-border: #ef5753;

    --color-message-info-bg: #eff8ff;
    --color-message-info-text: #2779bd;
    --color-message-info-border: #6cb2eb;
}


/* ==========================================================================
   2) RESET & STYLES DE BASE
   ========================================================================== */
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,'Helvetica Neue',Arial,'Noto Sans',sans-serif;
  background-color:var(--neutral-bg);
  color:var(--text-primary);
   overflow-x: hidden;
 /* overflow-x:clip;  évite la barre globale tout en autorisant le scroll interne */
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
a{text-decoration:none;color:inherit}


/* ==========================================================================
   3) LAYOUT PRINCIPAL
   ========================================================================== */

/* --- Topbar --- */
.topbar{
  background-color:var(--primary-dark);
  color:#fff;height:64px;display:flex;align-items:center;
  padding:0 24px;box-shadow:0 2px 4px rgba(0,0,0,.1);
  position:fixed;top:0;left:0;right:0;z-index:1000;
}
.topbar-toggle{
  background:none;border:none;color:#fff;font-size:20px;cursor:pointer;
  margin-right:16px;padding:8px;border-radius:50%;transition:background-color .2s;
}
.topbar-toggle:hover{background-color:rgba(255,255,255,.1)}
.logo{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:700;margin-right:24px;letter-spacing:-.5px}
.logo-icon{width:36px;height:36px;background-color:var(--primary-main);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px}

/* >>> Correctif topbar-selects: wrap + rétrécissement propre */
.topbar-selects{
  display:flex;
  flex-wrap:wrap;      /* autorise le retour à la ligne */
  gap:12px;
  flex:1 1 auto;       /* peut grandir/rétrécir */
  min-width:0;         /* IMPORTANT pour éviter le débordement */
  max-width:none;      /* supprime la limite 700px */
}
.topbar-select{flex:1 1 240px;min-width:0}
.topbar-select select{
  width:100%;min-width:0; /* permet l’ellipsis */
  padding:8px 12px;border:1px solid rgba(255,255,255,.2);
  border-radius:6px;background:rgba(255,255,255,.1);color:#fff;font-size:14px;cursor:pointer;
  transition:background-color .2s,border-color .2s;
  text-overflow:ellipsis;white-space:nowrap;overflow:hidden;
}
.topbar-select select:hover{background:rgba(255,255,255,.2)}
.topbar-select select option{background:var(--primary-dark);color:#fff}

.topbar-right{display:flex;align-items:center;gap:16px;margin-left:auto}
.topbar-icon{color:#fff;font-size:18px;cursor:pointer;padding:8px;border-radius:50%;transition:background-color .2s}
.topbar-icon:hover{background-color:rgba(255,255,255,.1)}
.user-info{display:flex;align-items:center;gap:10px}
.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary-main);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}

/* --- Layout --- */
.app-layout{display:flex;margin-top:64px;min-height:calc(100vh - 64px)}

/* --- Sidebar --- */
.sidebar{
  width:250px;background:var(--neutral-card);border-right:1px solid var(--border-color);
  transition:width .3s ease,transform .3s ease;position:fixed;left:0;top:64px;bottom:0;
  overflow-y:auto;z-index:900;padding:16px 0;
}
.sidebar.collapsed{width:70px}
.sidebar.collapsed .menu-text,.sidebar.collapsed .menu-arrow{display:none}
.sidebar.collapsed .menu-item{justify-content:center}
.sidebar::-webkit-scrollbar{width:5px}
.sidebar::-webkit-scrollbar-track{background:transparent}
.sidebar::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}
.sidebar::-webkit-scrollbar-thumb:hover{background:#A0AEC0}

.menu-item{
  display:flex;align-items:center;gap:12px;padding:12px 20px;margin:4px 8px;border-radius:6px;
  color:var(--text-secondary);white-space:nowrap;cursor:pointer;transition:all .2s ease-in-out;
}
.menu-item:hover{background:var(--neutral-bg);color:var(--text-primary)}
.menu-item.active{background:var(--primary-light);color:var(--primary-main);font-weight:600}
.menu-icon{font-size:18px;width:24px;text-align:center;flex-shrink:0}
.menu-text{flex:1;font-size:14px;font-weight:500}

/* --- Section principale --- */
.main-section{flex:1;margin-left:250px;transition:margin-left .3s ease;display:flex;flex-direction:column}
.main-section.expanded{margin-left:70px}
.project-header{padding:10px 24px;border-bottom:1px solid var(--border-color)}
.project-title{display:flex;align-items:center;gap:10px}
.project-title h1{font-size:16px;color:var(--text-primary);font-weight:600}
.main-content{flex:1;padding:24px}

/* Overlay pour mobile */
.sidebar-overlay{display:none;position:fixed;top:64px;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:850}
.sidebar-overlay.active{display:block}


/* ==========================================================================
   4) COMPOSANTS COMMUNS
   ========================================================================== */

/* Toolbar (barre d’outils) */
.main-toolbar{
  background:var(--toolbar-bg,#f0f7f5);
  padding:8px 16px;border-bottom:1px solid var(--border-color);display:flex;gap:8px;align-items:center;min-height:52px;
  position:relative;box-shadow:var(--shadow-sm);
}
.main-toolbar .toolbar-container{display:flex;align-items:center;gap:8px;width:100%;flex-wrap:wrap}
.main-toolbar .toolbar-item-wrapper{position:relative}
.main-toolbar .toolbar-logo{background:var(--primary-main);border-radius:8px;padding:10px 12px;display:flex;align-items:center;justify-content:center;margin-right:8px}
.main-toolbar .toolbar-logo i{color:#fff;font-size:12px}
.main-toolbar .toolbar-btn{
  display:inline-flex;align-items:center;gap:4px;padding:5px 6px;background:var(--neutral-card);
  border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);font-size:14px;font-weight:500;
  cursor:pointer;transition:all .2s ease;white-space:nowrap;box-shadow:var(--shadow-sm);
}
.main-toolbar .toolbar-btn:hover{
  background:var(--neutral-bg);border-color:var(--accent);color:var(--text-primary);
  transform:translateY(-1px);box-shadow:var(--shadow-md);
}
.main-toolbar .toolbar-btn.open{
  background:var(--primary-light);border-color:var(--primary-main);color:var(--primary-main);
  box-shadow:0 0 0 3px var(--ring-focus);
}
.main-toolbar .toolbar-btn i:first-child{font-size:16px;color:var(--primary-main)}
.main-toolbar .dropdown-arrow{font-size:12px;color:var(--text-secondary);transition:transform .2s;margin-left:4px}
.main-toolbar .toolbar-btn.open .dropdown-arrow{transform:rotate(180deg)}
.main-toolbar .dropdown-menu{
  display:none;position:absolute;top:calc(100% + 8px);left:0;min-width:240px;background:var(--neutral-card);
  border-radius:8px;border:1px solid var(--border-color);box-shadow:var(--shadow-md);padding:6px;animation:slideDown .2s ease-out;z-index:1102;
}
.main-toolbar .toolbar-btn.open + .dropdown-menu{display:block}
.main-toolbar .dropdown-item{
  display:flex;align-items:center;gap:12px;padding:10px 14px;color:var(--text-secondary);font-size:14px;border-radius:6px;transition:all .15s;
}
.main-toolbar .dropdown-item:hover{background:var(--primary-light);color:var(--primary-dark)}
.main-toolbar .dropdown-item i{font-size:16px;width:20px;color:var(--accent);text-align:center}

@keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}

/* Cartes de contenu */
.content-card{
  background:var(--neutral-card);border-radius:12px;padding:32px;
  box-shadow:0 4px 6px -1px rgba(0,0,0,.05),0 2px 4px -1px rgba(0,0,0,.03);
  min-height:500px;
}
.welcome-section{text-align:center;padding:60px 20px;display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%}
.welcome-icon{font-size:48px;width:80px;height:80px;line-height:80px;background:var(--primary-light);color:var(--primary-main);border-radius:50%;margin-bottom:24px}
.welcome-section h2{font-size:28px;margin-bottom:12px;font-weight:700}
.welcome-section p{font-size:16px;color:var(--text-secondary);max-width:550px;margin:0 auto;line-height:1.6}

/* Badges & sélecteurs */
.module-badge{display:inline-block;background:var(--primary-main);color:#fff;padding:6px 16px;border-radius:20px;font-weight:600;margin-top:24px;font-size:13px}
.exercice-badge{display:inline-flex;align-items:center;margin-left:auto}
.exercice-select{
  appearance:none;-webkit-appearance:none;padding:10px 40px 10px 16px;min-width:100px;background:var(--select-exercice-bg,#e4f2f3);
  border:1px solid var(--border-color);border-radius:4px;font-size:13px;font-weight:500;color:var(--text-primary);line-height:.7;cursor:pointer;transition:.3s;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;background-size:12px;
}
.exercice-select:hover{border-color:var(--warning);background:var(--neutral-card)}
.exercice-select:focus{outline:none;border-color:var(--warning);background:var(--neutral-card);box-shadow:0 0 0 3px rgba(212,160,23,.1)}


/* ==========================================================================
   5) SECTIONS SPÉCIFIQUES
   ========================================================================== */

/* --- Formulaires (.form-card) --- */
.form-card{
  border-radius:8px;overflow:hidden;border:1px solid var(--border-dark);
  background:var(--neutral-card);max-width:var(--card-max-width);
}
/* Largeur responsive (mobile-first) */
.form-card{width:95%;margin:0 auto}
@media (min-width:576px){.form-card{width:92%}}
@media (min-width:992px){.form-card{width:85%}}
@media (min-width:1200px){.form-card{width:70%}}

.form-card-header{
  background:rgba(70,180,151,.06);padding:1rem 1.25rem;border-bottom:1px solid rgba(70,180,151,.15);
  display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;
}
.form-icon-box{width:36px;height:36px;background:#fff;border:1px solid rgba(70,180,151,.25);border-radius:8px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}
.form-icon-box i{font-size:16px;color:#379b82}
.form-card-header h5{font-weight:600;font-size:1.1rem;margin:0;color:var(--border-dark)}
.form-card-header small{color:var(--text-secondary);font-size:.875rem;display:block}
.form-card-body{padding:var(--card-padding)}
.form-label{font-weight:500;color:var(--text-secondary);margin-bottom:.375rem;font-size:.875rem}
.form-control,.form-select{
  border:1px solid var(--border-color);border-radius:6px;padding:.5rem .75rem;font-size:.9375rem;transition:border-color .15s ease;width:100%;
}
.form-control:focus,.form-select:focus{border-color:var(--primary-main);box-shadow:none;outline:none}
textarea.form-control{resize:vertical}
.form-card-footer{
  background:var(--neutral-bg);padding:1rem 1.5rem;border-top:1px solid var(--border-color);
  display:flex;justify-content:space-between;align-items:center;gap:.75rem;flex-wrap:wrap;
}
.btn{padding:.5rem 1.25rem;border-radius:6px;font-size:.9375rem;font-weight:500;transition:all .2s;border:1px solid transparent;cursor:pointer}
.btn-outline-secondary{border-color:var(--text-secondary);color:var(--text-secondary);background:transparent}
.btn-outline-secondary:hover{background:var(--text-secondary);color:#fff}
.btn-success{background:var(--primary-main);border-color:var(--primary-main);color:#fff}
.btn-success:hover{background:var(--primary-dark);border-color:var(--primary-dark)}
.row.g-3{row-gap:var(--row-gap)!important}
.row.g-2{row-gap:.4rem!important}

/* Variantes compactes */
.form-compact .form-card-header,.form-compact .form-card-footer{padding-top:.4rem;padding-bottom:.4rem}
.form-compact .form-card-body{padding-top:1rem;padding-bottom:1rem}
.form-compact .form-label{margin-bottom:.25rem}
.form-compact .form-control,.form-compact .form-select{padding-top:.375rem;padding-bottom:.375rem;font-size:.9rem}
.form-compact .row.g-3{row-gap:.3rem!important}

.form-ultracompact .form-card-header,.form-ultracompact .form-card-footer{padding:.5rem 1.25rem}
.form-ultracompact .form-card-body{padding:.75rem 1.25rem}
.form-ultracompact .form-label{font-size:.8rem;margin-bottom:.1rem;line-height:1.15;font-weight:700}
.form-ultracompact .form-control,.form-ultracompact .form-select{padding:.4rem .75rem;font-size:.875rem;line-height:1.2}
.form-ultracompact .row.g-3,.form-ultracompact .row.g-2{row-gap:.3rem!important}
.form-ultracompact .form-icon-box{width:32px;height:32px}
.form-ultracompact .form-icon-box i{font-size:14px}
.form-ultracompact .form-card-header h5{font-size:1rem}

/* --- Tableaux & DataTables (.table-card) --- */
.table-card{
  background:var(--neutral-card);border:1px solid var(--border-color);
  border-radius:12px;box-shadow:var(--shadow-sm);
  /* >>> Correctif scroll DataTables */
  overflow:visible; /* ne coupe plus la barre horizontale interne */
  transition:box-shadow .2s ease-in-out;
}
.table-card-header{
  display:flex;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid var(--border-color);background:var(--neutral-bg);
}
.table-card-title{display:inline-flex;align-items:center;gap:10px;font-weight:700;color:var(--text-primary);font-size:16px;margin-right:auto}
.table-card-title i{color:var(--primary-main);font-size:18px}
.table-card-actions{display:inline-flex;align-items:center;gap:8px}
.table-card-body{padding:8px}

.table>:not(caption)>*>*{padding:.8rem;vertical-align:middle}
.table-card .thead-soft thead th{
  background:var(--neutral-bg);color:var(--text-primary);font-weight:bolder;border-bottom-width:1px;text-transform:uppercase;font-size:14px;letter-spacing:.5px;
}
.table-card tbody tr:hover{background-color:rgba(47,168,133,.08)} /* hover doux */

/* DataTables: laisser voir le scroll interne */
.table-card .dataTables_scroll{overflow:visible!important}
.table-card .dataTables_scrollBody{overflow:auto!important}

/* DataTables & Pagination */
.table-card .dataTables_wrapper{padding:12px}
.table-card .dataTables_paginate .page-link{border-color:var(--border-color);color:var(--text-secondary)}
.table-card .dataTables_paginate .page-item.active .page-link{
  background:var(--primary-main);border-color:var(--primary-main);color:#fff;box-shadow:var(--shadow-sm);
}

/* Variante compacte */
.table-compact>:not(caption)>*>*{padding:.30rem .55rem}
.table-compact thead th{padding:.48rem .55rem;font-size:13px} /* vrai compact */
.table.table-striped.table-striped-soft{--bs-table-striped-bg:rgba(47,168,133,.06)}

/* Aide scrollX: empêcher les retours automatiques */
.table thead th,.table tbody td{white-space:nowrap}

/* >>> DataTables wrapper: contrôles qui wrap sur petite largeur */
.dataTables_wrapper .row{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
}
.dataTables_wrapper .dataTables_length,
.dataTables_wrapper .dataTables_filter,
.dataTables_wrapper .dataTables_info,
.dataTables_wrapper .dataTables_paginate{
  flex:1 1 auto;
  min-width:200px;
}


/* ==========================================================================
   6) RESPONSIVE DESIGN
   ========================================================================== */
/* ≥1920px */
@media (min-width:1920px){
  .sidebar{width:280px}
  .main-section{margin-left:280px}
  .main-section.expanded{margin-left:70px}
  .topbar-selects{max-width:900px}
  .content-card{max-width:1600px;margin:0 auto}
}
/* ≥1200px */
@media (min-width:1200px){:root{--card-max-width:980px}}
/* ≤1199.98px */
@media (max-width:1199.98px){:root{--card-max-width:920px}}
/* ≤991.98px (tablette et moins) */
@media (max-width:991.98px){
  :root{--card-max-width:720px;--card-padding:1.25rem}
  .topbar{height:56px;padding:0 12px}
  .app-layout{margin-top:56px;min-height:calc(100vh - 56px)}
  .sidebar{top:56px;transform:translateX(-100%);width:260px;box-shadow:2px 0 8px rgba(0,0,0,.15)}
  .sidebar.mobile-open{transform:translateX(0)}
  .main-section,.main-section.expanded{margin-left:0}
  .topbar-right{margin-left:8px}           /* >>> tasse la zone à droite */
  .topbar-selects{gap:8px}                 /* >>> resserre l’espacement */
  .exercice-select{display:none}
  .main-content{padding:16px}
  .content-card{padding:20px;border-radius:8px}
}
/* ≤768px */
@media (max-width:768px){
  :root{--card-padding:1rem}
  .user-info span{display:none}
  .topbar-right{flex-shrink:0}             /* >>> évite qu'elle mange tout */
  /* Sélecteurs spécifiques mobile */
  .mobile-selects{display:flex;flex-direction:column;gap:10px;padding:12px 16px;background:var(--primary-dark);order:-1}
  .mobile-selects select{
    width:100%;padding:10px 12px;border:1px solid rgba(255,255,255,.2);border-radius:6px;background:rgba(255,255,255,.1);color:#fff;
  }
  /* Footer de formulaire empilé */
  .form-card-footer{flex-direction:column;align-items:stretch}
  .btn{width:100%}
}
/* ≤480px */
@media (max-width:480px){
  .sidebar{max-width:280px}
  .main-content{padding:12px}
  .content-card{padding:16px}
}


/* ==========================================================================
   7) HARMONISATION VUE-MULTISELECT / SELECT2
   ========================================================================== */

/* Vue-Multiselect */
.multiselect{font-family:inherit;width:100%;position:relative}
.multiselect__tags{
  min-height:38px;padding:.4rem .75rem;border:1px solid var(--border-color);border-radius:6px;background:#fff;
  box-shadow:none;display:flex;align-items:center;gap:.35rem;transition:border-color .15s,box-shadow .15s;
}
.multiselect__placeholder,.multiselect__single{margin:0;padding:0;line-height:1.2;font-size:.9375rem;color:var(--text-secondary)}
.multiselect__input{margin:0;padding:0;height:24px;line-height:24px;font-size:.9375rem}
.multiselect--active .multiselect__tags,
.multiselect:focus-within .multiselect__tags{border-color:var(--primary-main);box-shadow:0 0 0 3px var(--ring-focus)}
.multiselect__select{height:100%;width:36px}
.multiselect__select:before{border-color:var(--text-secondary) transparent transparent transparent}
.multiselect__content-wrapper{
  border:1px solid var(--border-color);border-radius:8px;box-shadow:var(--shadow-md);
  margin-top:6px;z-index:2005;background:var(--neutral-card);
}
.multiselect__option{padding:.5rem .75rem;font-size:.9375rem;color:var(--text-primary);transition:background-color .12s}
.multiselect__option--highlight{background:var(--primary-light);color:var(--primary-dark)}
.multiselect__option--selected{background:rgba(0,0,0,.035);color:var(--text-primary)}
.multiselect__tag{
  background:rgba(0,0,0,.06);color:var(--text-primary);border:1px solid var(--border-color);
  border-radius:6px;padding:.15rem .45rem;font-size:.85rem;font-weight:500;
}
.multiselect__tag-icon:after{color:var(--text-secondary)}
.multiselect__tag-icon:focus,.multiselect__tag-icon:hover{background:rgba(0,0,0,.08)}
.multiselect--disabled .multiselect__tags{background:#f8f9fa;color:var(--text-secondary);opacity:.8}
/* Ultra compact */
.form-ultracompact .multiselect__tags{min-height:34px;padding:.3rem .6rem}
.form-ultracompact .multiselect__option{padding:.4rem .6rem;font-size:.875rem}

/* Select2 (z-index pour passer au-dessus des toolbars/cartes) */
.select2-container .select2-dropdown{z-index:2005}







/* ==========================================================================
   8) LABELS & FORM HELP
   ========================================================================== */

.form-label,label.form-label,.form-card .form-label{
  display:inline-block;font-weight:600;color:var(--text-secondary);
  font-size:.9rem;line-height:1.25;margin-bottom:.35rem;
}
.form-ultracompact .form-label{font-size:.85rem;margin-bottom:.25rem}
.form-label.label-colon::after{content:' :'}
.form-label .req{color:var(--danger);margin-left:.2rem;font-weight:700}
.form-label .opt{
  margin-left:.35rem;padding:.05rem .35rem;border-radius:.35rem;background:rgba(0,0,0,.05);
  color:var(--text-secondary);font-size:.75rem;font-weight:600;
}
label + .multiselect,label + .form-control,label + .form-select{margin-top:0}
.multiselect__tags,.form-control,.form-select{min-height:38px}
.is-invalid,.multiselect.is-invalid .multiselect__tags{
  border-color:var(--danger)!important;box-shadow:0 0 0 3px rgba(178,77,77,.08)!important;
}
.form-help{display:block;margin-top:.25rem;color:var(--text-secondary);font-size:.8rem}
/* Alignement des champs dans la grille */
.form-card .row [class*="col-"]{display:flex;flex-direction:column}
/* Layout horizontal (≥ md) */
@media (min-width:768px){
  .form-horizontal .form-group{
    display:grid;grid-template-columns:220px 1fr;align-items:center;column-gap:.75rem;
  }
  .form-horizontal .form-group .form-label{margin:0}
}



/* Flash messages */
.message {
    padding: .5rem 1rem;
    background: var(--color-message-info-bg);
    color: var(--color-message-info-text);
    border-color: var(--color-message-info-border);
    border-width: 1px;
    border-style: solid;
    border-radius: 4px;
    margin-bottom: 1rem;
    cursor: pointer;
}
.message.hidden {
    display: none;
}
.message.success {
    background: var(--color-message-success-bg);
    color: var(--color-message-success-text);
    border-color: var(--color-message-success-border);
}
.message.warning {
    background: var(--color-message-warning-bg);
    color: var(--color-message-warning-text);
    border-color: var(--color-message-warning-border);
}
.message.error {
    background: var(--color-message-error-bg);
    color: var(--color-message-error-text);
    border-color: var(--color-message-error-border);
}




/* Confinement natif BS5 + DataTables : Pas de hidden forcé */
.table-responsive {
    overflow-x: auto;  /* Scroll horizontal seulement si besoin */
    -webkit-overflow-scrolling: touch;  /* Fluide mobile */
}

.table-responsive table {
    min-width: 100%;  /* Fluidité : S'étend sans forcer min-width fixe */
}

/* Compactage doux pour colonnes longues */
.table th:nth-child(3), .table td:nth-child(3) {  /* Libellé */
    max-width: 250px;  /* Limite sur grand écran */
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

@media (max-width: 992px) {
    .table-responsive::-webkit-scrollbar {
        height: 6px;  /* Fine sur mobile */
    }
    .table th, .table td {
        padding: 0.4rem 0.25rem;  /* Plus compact */
    }
    .table th:nth-child(3), .table td:nth-child(3) {
        max-width: 120px;  /* Plus serré sur petit écran */
    }
}


/* Alignement contrôles DataTables : Haut, gauche/droite sur même ligne */
.dataTables_wrapper .top {  /* Conteneur haut (length + filter) */
    display: flex !important;
    justify-content: space-between !important;  /* Gauche : length, Droite : filter */
    align-items: center !important;  /* Verticalement centrés */
    flex-wrap: wrap;  /* Wrap seulement si trop étroit */
    gap: 1rem;  /* Espacement entre eux */
    margin-bottom: 1rem;
}

.dataTables_wrapper .dataTables_length {  /* "Show X entries" */
    order: 1;  /* À gauche */
    flex: 0 1 auto;  /* Ne grandit pas trop */
    min-width: 120px;  /* Compact */
}

.dataTables_wrapper .dataTables_filter {  /* "Search:" */
    order: 2;  /* À droite */
    flex: 0 1 auto;
    margin-left: auto;  /* Pousse à droite si flex */
}

.dataTables_wrapper .dataTables_info {  /* "Showing X to Y of Z entries" */
    order: 3;
    flex: 1 1 auto;  /* Centre si espace */
    text-align: center;
    margin: 0.5rem 0;
}

/* Pagination en bas, centrée */
.dataTables_wrapper .bottom {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 1rem;
}

.dataTables_wrapper .dataTables_paginate {
    order: 1;
}

/* Sur très petit écran : Empile verticalement */
@media (max-width: 576px) {
    .dataTables_wrapper .top {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 0.5rem;
    }
    .dataTables_wrapper .dataTables_length,
    .dataTables_wrapper .dataTables_filter {
        margin: 0 !important;
        text-align: center !important;
    }
    .dataTables_wrapper .dataTables_filter input {
        width: 100% !important;  /* Pleine largeur sur mobile */
    }
}

