/* =========================================================
   UNIFIED v1 (drop-in)
   Goal: unify core components + fix conflicting modal styles
   while keeping all legacy selectors working.
   ========================================================= */

/* === TOKENS / ALIASES === */
:root{
  /* Existing tokens (kept) - DO NOT OVERRIDE ui.css values */
  /* Commented out to let ui.css take priority */
  /* --color-bg: #1a1a1a; */
  /* --color-bg-alt: #242424; */
  /* --color-bg-card: #2a2a2a; */
  /* --color-border: #3a3a3a; */
  /* --color-text: #e0e0e0; */
  /* --color-text-dim: #a0a0a0; */
  /* --color-primary: #3b82f6; */
  /* --color-primary-hover: #2563eb; */
  /* --color-success: #10b981; */
  /* --color-warning: #f59e0b; */
  /* --color-danger: #ef4444; */

  --color-status-ouvert: #ef4444;
  --color-status-en-cours: #f59e0b;
  --color-status-en-attente: #eab308;
  --color-status-cloture: #10b981;

  --spacing: 8px;

  /* Aliases used later in legacy blocks (fix undefined vars) */
  --bg: var(--color-bg);
  --bg-alt: var(--color-bg-alt);
  --card: var(--color-bg-alt);
  --card-2: var(--color-bg-card);
  --text: var(--color-text);
  --text-dim: var(--color-text-dim);
  --border: var(--color-border);

  /* Minimal system tokens */
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 14px;

  --fs-xs: 12px;
  --fs-sm: 14px;
  --fs-md: 16px;
  --fs-lg: 20px;
  --fs-xl: 28px;

  --border-soft: 1px solid rgba(255,255,255,.08);
  --shadow-sm: 0 4px 10px rgba(0,0,0,.20);
  --shadow-md: 0 10px 30px rgba(0,0,0,.25);
  --shadow-lg: 0 30px 80px rgba(0,0,0,.50);

  --focus-ring: 0 0 0 3px rgba(59,130,246,.18);
}

/* === RESET (kept minimal) === */
*{ margin:0; padding:0; box-sizing:border-box; }
html, body{ height:100%; }
body{
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  background-color: var(--color-bg);
  color: var(--color-text);
  line-height: 1.6;
  min-height: 100vh;
}

/* === TYPO / LINKS === */
a{ color: var(--color-primary); }
a:hover{ color: var(--color-primary-hover); }
.text-dim{ color: var(--color-text-dim); font-style: italic; }

/* === LAYOUT HELPERS === */
.container{ max-width: 1400px; margin: 0 auto; }
.stack{ display:flex; flex-direction:column; gap: calc(var(--spacing) * 2); }
.row{ display:flex; gap: calc(var(--spacing) * 2); flex-wrap:wrap; align-items:center; }
.w-100{ width:100%; }

/* === CARD (unified base) === */
.card,
.dashboard-section,
.stat-card,
.service-card,
.chambre-info-card,
.intervention-info-card{
  background-color: var(--color-bg-card, rgba(255,255,255,0.04));
  border: 1px solid var(--color-border, rgba(255,255,255,0.1));
  border-radius: var(--radius-md);
}
.card{
  background: var(--color-bg-card, rgba(255,255,255,0.04));
  border: var(--border-soft, 1px solid rgba(255,255,255,.08));
  border-radius: var(--radius-xl);
  overflow: hidden;
}
.card-head, .card-h{
  display:flex; align-items:center; justify-content:space-between;
  padding: 12px 14px;
  border-bottom: var(--border-soft);
}
.card-body{ padding: 14px; }

/* === BUTTONS (keep legacy selectors - NO TRANSFORM) === */
.btn{
  display:inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing) calc(var(--spacing) * 2);
  border: none;
  border-radius: var(--radius-sm);
  font-size: 0.9375rem;
  font-weight: 500;
  cursor: pointer;
  transition: background-color 0.2s ease, opacity 0.2s ease, box-shadow 0.2s ease;
  text-decoration: none;
  text-align: center;
}
.btn:focus{ outline:none; box-shadow: var(--focus-ring); }
.btn-primary{ background-color: var(--color-primary); color: #fff; }
.btn-primary:hover{ background-color: var(--color-primary-hover); }
.btn-secondary{
  background-color: var(--color-bg-alt);
  color: var(--color-text);
  border: 1px solid var(--color-border);
}
.btn-secondary:hover{ background-color: var(--color-border); }
.btn-link{ background:none; border:none; color: var(--color-primary); cursor:pointer; padding: 4px 8px; }
.btn-link:hover{ text-decoration: underline; }
.btn-sm{ padding: 6px 12px; font-size: 0.8125rem; }
.btn-block{ display:block; width:100%; }

/* === FORMS (unified) === */
.form-control,
.filters-compact select,
.filters-compact input,
select,
.filters select,
.filters-bar select{
  width: 100%;
  background-color: var(--color-bg-alt);
  color: var(--color-text);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 10px;
  padding: 10px 12px;
  outline: none;
}
.form-control:focus,
.filters-compact select:focus,
.filters-compact input:focus,
select:focus{
  border-color: rgba(59,130,246,.70);
  box-shadow: var(--focus-ring);
}
select{
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}
select option{ background:#1b1b1f; color:#f1f1f5; }

/* === TABLES (unified) === */
.table-wrap{
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.02);
  border-radius: 12px;
  overflow: auto;
}
.table,
.data-table,
.table-wrap table{
  width: 100%;
  border-collapse: collapse;
}
.table th, .table td,
.data-table th, .data-table td,
.table-wrap th, .table-wrap td{
  padding: 10px 12px;
  vertical-align: middle;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.table th,
.data-table th{
  opacity: .75;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .6px;
}
.data-table thead{ background-color: var(--color-bg-alt); }
.data-table tbody tr:hover{ background-color: var(--color-bg-alt); }

/* === BADGES / PILLS (unified) === */
.badge,
.badge-mini,
.pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size: 12px;
  padding: 3px 8px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.25);
}
.badge{ text-transform: uppercase; font-weight: 600; font-size: 0.75rem; border-radius: 4px; background: transparent; border: none; padding: 4px 8px; }
.badge-mini{ font-size: 11px; }
.pill{ padding: 2px 8px; }

.badge-ok{ color:#3ddc97; border-color: rgba(61,220,151,.35); }
.badge-hs{ color:#ff5d5d; border-color: rgba(255,93,93,.35); }
.badge-warn{ color:#ffb020; border-color: rgba(255,176,32,.35); }
.badge-crit{ color:#ff4d4d; border-color: rgba(255,77,77,.35); }

.pill-ok{ border-color: rgba(70,200,140,0.35); }
.pill-hs{ border-color: rgba(255,90,90,0.35); }
.pill-veille{ border-color: rgba(255,170,60,0.35); }
.pill-crit{ border-color: rgba(255,90,90,0.25); }

/* === MODALS (unified to support BOTH systems) === */
/* Works if JS sets display to 'block' OR 'flex' */
.modal{
  display: none;
  position: fixed;
  z-index: 1000;
  inset: 0;
  padding: 18px;
  background: rgba(0,0,0,.85);
  overflow-y: auto;
  text-align: center; /* centers inline-block children for "block" mode */
}
.modal-backdrop{
  position: fixed; inset: 0;
  background: rgba(0,0,0,.05);
  z-index: 999;
}
.modal-content,
.modal-card{
  display: inline-block; /* centers in block mode */
  text-align: left;
  background-color: var(--color-bg-card);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 14px;
  box-shadow: var(--shadow-lg);
  padding: calc(var(--spacing) * 3);
  width: 90%;
  max-width: 600px;
  margin: 5% auto;
}
.modal-card{
  width: min(720px, 100%);
  background: rgba(20,20,24,.98);
  padding: 14px;
}
.modal-head{
  display:flex; justify-content:space-between; align-items:center;
  gap:12px; margin-bottom: 10px;
}
.modal-close{
  color: var(--color-text-dim);
  float: right;
  font-size: 2rem;
  font-weight: bold;
  cursor: pointer;
  line-height: 1;
}
.modal-close:hover{ color: var(--color-text); }
.modal-large{ max-width: 800px; }

/* =========================================================
   LEGACY CSS (kept below)
   ========================================================= */

.main-header {
    background-color: var(--color-bg-card);
    border-bottom: 2px solid var(--color-border);
    padding: calc(var(--spacing) * 2);
    position: sticky;
    top: 0;
    z-index: 100;
}

.header-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 1400px;
    margin: 0 auto;
    margin-bottom: calc(var(--spacing) * 2);
}

.header-left {
    display: flex;
    align-items: center;
    gap: calc(var(--spacing) * 3);
}

.header-left h1 {
    font-size: 3rem;
    color: var(--color-primary);
}

.site-selector {
    display: flex;
    align-items: center;
    gap: var(--spacing);
    padding: var(--spacing) calc(var(--spacing) * 2);
    background-color: var(--color-bg-alt);
    border-radius: 6px;
    border: 1px solid var(--color-border);
}

.site-name {
    font-weight: 500;
}

.btn-change-site {
    font-size: 0.875rem;
    color: var(--color-primary);
    text-decoration: none;
    padding: 4px 8px;
    border-radius: 2px;
    transition: background-color 0.2s;
}

.btn-change-site:hover {
    background-color: var(--color-border);
}

.header-right {
    display: flex;
    align-items: center;
    gap: calc(var(--spacing) * 2);
}

.user-info {
    display: flex;
    align-items: center;
    gap: var(--spacing);
}

.user-role {
    color: var(--color-text-dim);
    font-size: 0.875rem;
}

.main-nav {
    display: flex;
    gap: calc(var(--spacing) * 2);
    max-width: 1400px;
    margin: 0 auto;
    flex-wrap: wrap;
}

.main-nav a {
    color: var(--color-text);
    text-decoration: none;
    padding: var(--spacing) calc(var(--spacing) * 2);
    border-radius: 6px;
    transition: background-color 0.2s ease, color 0.2s ease;
    font-weight: 500;
}

.main-nav a:hover {
    background-color: var(--color-bg-alt);
}

.main-nav a.active {
    background-color: var(--color-primary);
    color: white;
}

.nav-dropdown {
    position: relative;
    display: inline-block;
}

.nav-dropdown-toggle {
    cursor: pointer;
    display: inline-block;
    color: var(--color-text);
    text-decoration: none;
    padding: var(--spacing) calc(var(--spacing) * 2);
    border-radius: 6px;
    transition: background-color 0.2s ease, color 0.2s ease;
    font-weight: 500;
}

.main-nav .nav-dropdown-toggle {
    padding: var(--spacing) calc(var(--spacing) * 2);
    border-radius: 6px;
}

.main-nav .nav-dropdown-toggle:hover {
    background-color: var(--color-bg-alt);
}

.nav-dropdown-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    margin-top: 4px;
    min-width: 200px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.3);
}

.nav-dropdown:hover .nav-dropdown-menu {
    display: flex;
    flex-direction: column;
}

.nav-dropdown-menu a {
    padding: var(--spacing) calc(var(--spacing) * 2);
    border-radius: 0;
}

.main-content {
    max-width: 1400px;
    margin: 0 auto;
    padding: calc(var(--spacing) * 3);
    min-height: calc(100vh - 200px);
}

.main-footer {
    background-color: var(--color-bg-card);
    border-top: 1px solid var(--color-border);
    padding: calc(var(--spacing) * 2);
    text-align: center;
    color: var(--color-text-dim);
    font-size: 0.875rem;
}

.page-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: calc(var(--spacing) * 3);
    flex-wrap: wrap;
    gap: 1rem;
}

.page-header h1 {
    font-size: 2rem;
    color: var(--color-text);
}

@media (max-width: 768px) {
    .page-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.75rem;
    }
    .page-header h1 {
        font-size: 1.5rem;
    }
}

.btn {
    display: inline-block;
    padding: var(--spacing) calc(var(--spacing) * 2);
    border: none;
    border-radius: 6px;
    font-size: 0.9375rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
    text-decoration: none;
    text-align: center;
}

.btn-primary {
    background-color: var(--color-primary);
    color: white;
}

.btn-primary:hover {
    background-color: var(--color-primary-hover);
}

.btn-secondary {
    background-color: var(--color-bg-alt);
    color: var(--color-text);
    border: 1px solid var(--color-border);
}

.btn-secondary:hover {
    background-color: var(--color-border);
}

.btn-link {
    background: none;
    border: none;
    color: var(--color-primary);
    text-decoration: none;
    cursor: pointer;
    padding: 4px 8px;
}

.btn-link:hover {
    text-decoration: underline;
}

.btn-danger {
    color: var(--color-danger);
}

.btn-account, .btn-logout {
    color: var(--color-text);
    text-decoration: none;
    padding: 6px 12px;
    border-radius: 4px;
    transition: background-color 0.2s;
    font-size: 0.875rem;
}

.btn-account:hover, .btn-logout:hover {
    background-color: var(--color-bg-alt);
}

.btn-block {
    display: block;
    width: 100%;
}
/* =======================
   CHAMBRES – Etages en GRID (DESKTOP OK)
======================= */

.floors-grid{
  display: grid !important;
  grid-template-columns: repeat(4, minmax(240px, 1fr)) !important;
  gap: 14px !important;
  align-items: stretch !important;
  margin: 12px 0 18px !important;
}

@media (max-width: 1100px){
  .floors-grid{ grid-template-columns: repeat(2, minmax(220px, 1fr)) !important; }
}
@media (max-width: 640px){
  .floors-grid{ grid-template-columns: 1fr !important; }
}

.floor-card{
  border: 1px solid rgba(255,255,255,.12) !important;
  border-radius: 12px !important;
  background: rgba(255,255,255,.03) !important;
  padding: 14px !important;
  box-shadow: 0 10px 26px rgba(0,0,0,.22) !important;
  transition: transform .12s ease, border-color .12s ease, background .12s ease !important;
}

.floor-card:hover{
  transform: translateY(-1px) !important;
  border-color: rgba(59,130,246,.55) !important;
  background: rgba(255,255,255,.05) !important;
  cursor: pointer;
}

.floor-top{ display:flex; justify-content:space-between; gap:12px; margin-bottom:10px; }
.floor-title{ font-weight:800; }
.floor-sub{ opacity:.85; font-size:13px; margin-top:2px; }

.floor-metrics{
  display:flex; flex-wrap:wrap; gap:10px 14px;
  font-size:13px; margin:10px 0 12px;
  padding-top:10px;
  border-top: 1px solid rgba(255,255,255,.08);
}

.floor-actions{ display:flex; gap:10px; flex-wrap:wrap; }
.floor-actions a.btn{ padding:8px 10px; border-radius:10px; }
/* ===========================
   BAES UI
=========================== */

.kpi-grid{
  display:grid;
  grid-template-columns: repeat(6, minmax(140px, 1fr));
  gap:12px;
  margin:14px 0 14px;
}
@media (max-width: 1100px){
  .kpi-grid{ grid-template-columns: repeat(3, minmax(140px, 1fr)); }
}
@media (max-width: 720px){
  .kpi-grid{ grid-template-columns: repeat(2, minmax(140px, 1fr)); }
}

.kpi-card{
  border:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  border-radius:12px;
  padding:10px 12px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  min-height:56px;
}
.kpi-title{
  font-size:12px;
  opacity:.75;
  margin:0;
  line-height:1.2;
}
.kpi-value{
  font-size:20px;
  font-weight:700;
  margin:0;
  line-height:1;
}
.kpi-chip{
  font-size:11px;
  padding:3px 8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.25);
  opacity:.9;
}

.kpi-ok .kpi-value{ color:#3ddc97; }
.kpi-hs .kpi-value{ color:#ff5d5d; }
.kpi-warn .kpi-value{ color:#ffb020; }
.kpi-crit .kpi-value{ color:#ff4d4d; }
.kpi-total .kpi-value{ color:#b9c8ff; }
.kpi-active .kpi-value{ color:#ffffff; }

.filters-compact{
  border:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.02);
  border-radius:12px;
  padding:10px 12px;
  margin:10px 0 14px;
}

.filters-compact .filter-row{
  display:grid;
  grid-template-columns: 220px 220px 220px 1fr 170px;
  gap:10px;
  align-items:end;
}
@media (max-width: 1100px){
  .filters-compact .filter-row{ grid-template-columns: 1fr 1fr; }
}

.filters-compact label{
  font-size:12px;
  opacity:.75;
  margin:0 0 6px;
  display:block;
}

.filters-compact select,
.filters-compact input{
  height:36px;
  padding:6px 10px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.25);
  color: #fff;
  width:100%;
}

.filters-compact .filter-actions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
}

.table-wrap{
  border:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.02);
  border-radius:12px;
  overflow:hidden;
}

.table-wrap table{
  width:100%;
  table-layout: fixed; /* empêche la table de “changer de taille” selon les lignes */
}

.table-wrap th, .table-wrap td{
  padding:10px 12px;
  vertical-align:middle;
  border-bottom:1px solid rgba(255,255,255,.06);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.badge-mini{
  font-size:11px;
  padding:3px 8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.25);
  display:inline-block;
}

.badge-ok{ color:#3ddc97; border-color: rgba(61,220,151,.35); }
.badge-hs{ color:#ff5d5d; border-color: rgba(255,93,93,.35); }
.badge-warn{ color:#ffb020; border-color: rgba(255,176,32,.35); }
.badge-crit{ color:#ff4d4d; border-color: rgba(255,77,77,.35); }

.modal-backdrop{
  position: fixed; inset: 0;
  background: rgba(0,0,0,.05);
  z-index: 999;
}
.modal{
  position: fixed; inset: 0;
  display:flex; align-items:center; justify-content:center;
  z-index: 1000;
  padding: 18px;
}
.modal-card{
  width: min(720px, 100%);
  background: rgba(20,20,24,.98);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 14px;
  box-shadow: 0 30px 80px rgba(0,0,0,.5);
  padding: 14px;
}
.modal-head{
  display:flex; justify-content:space-between; align-items:center;
  gap:12px;
  margin-bottom: 10px;
}

.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: calc(var(--spacing) * 2);
    margin-bottom: calc(var(--spacing) * 4);
}

.stat-card {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: calc(var(--spacing) * 3);
    display: flex;
    align-items: center;
    gap: calc(var(--spacing) * 2);
}

.stat-icon {
    font-size: 2.5rem;
}

.stat-content {
    flex: 1;
}

.stat-label {
    font-size: 0.875rem;
    color: var(--color-text-dim);
    margin-bottom: 4px;
}

.stat-value {
    font-size: 2rem;
    font-weight: 700;
}

.stat-ouvert { border-left: 4px solid var(--color-status-ouvert); }
.stat-en-cours { border-left: 4px solid var(--color-status-en-cours); }
.stat-en-attente { border-left: 4px solid var(--color-status-en-attente); }
.stat-cloture { border-left: 4px solid var(--color-status-cloture); }

.dashboard-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
    gap: calc(var(--spacing) * 3);
    margin-bottom: calc(var(--spacing) * 4);
}

.dashboard-section {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: calc(var(--spacing) * 3);
}

.dashboard-section h2 {
    font-size: 1.25rem;
    margin-bottom: calc(var(--spacing) * 2);
    color: var(--color-text);
}

.intervention-urgente-card {
    background-color: var(--color-bg-alt);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    padding: calc(var(--spacing) * 2);
    margin-bottom: calc(var(--spacing) * 2);
}

.intervention-header {
    display: flex;
    gap: var(--spacing);
    margin-bottom: var(--spacing);
    flex-wrap: wrap;
}

.intervention-body strong {
    display: block;
    margin-bottom: 4px;
}

.intervention-meta {
    font-size: 0.875rem;
    color: var(--color-text-dim);
    margin-top: var(--spacing);
}

.intervention-footer {
    margin-top: var(--spacing);
    padding-top: var(--spacing);
    border-top: 1px solid var(--color-border);
}

.badge {
    display: inline-block;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
}

.status-ouvert, .badge.status-ouvert {
    background-color: rgba(239, 68, 68, 0.2);
    color: var(--color-status-ouvert);
}

.status-en-cours, .badge.status-en-cours {
    background-color: rgba(245, 158, 11, 0.2);
    color: var(--color-status-en-cours);
}

.status-en-attente,
.badge.status-en-attente {
  background-color: rgba(234, 179, 8, 0.15) !important;
  color: #eab308 !important;
  border-color: rgba(234, 179, 8, 0.35) !important;
}

.status-select-en_attente {
  background-color: rgba(234, 179, 8, 0.15) !important;
  border-color: rgba(234, 179, 8, 0.3) !important;
  color: #eab308 !important;
}

.status-cloture, .badge.status-cloture {
    background-color: rgba(16, 185, 129, 0.2);
    color: var(--color-status-cloture);
}

.priority-haute {
    background-color: rgba(239, 68, 68, 0.2);
    color: var(--color-danger);
}

.priority-normale {
    background-color: rgba(59, 130, 246, 0.2);
    color: var(--color-primary);
}

.priority-basse {
    background-color: rgba(107, 114, 128, 0.2);
    color: var(--color-text-dim);
}

.badge-critique {
    background-color: rgba(239, 68, 68, 0.3);
    color: var(--color-danger);
    font-weight: 700;
}

.evenements-list {
    display: flex;
    flex-direction: column;
    gap: calc(var(--spacing) * 2);
}

.evenement-card {
    display: flex;
    gap: calc(var(--spacing) * 2);
    background-color: var(--color-bg-alt);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    padding: calc(var(--spacing) * 2);
}

.evenement-date {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-width: 60px;
    background-color: var(--color-primary);
    color: white;
    border-radius: 6px;
    padding: var(--spacing);
}

.date-day {
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1;
}

.date-month {
    font-size: 0.75rem;
    text-transform: uppercase;
}

.evenement-content {
    flex: 1;
}

.evenement-titre {
    font-weight: 600;
    margin-bottom: 4px;
}

.evenement-equipement, .evenement-heure {
    font-size: 0.875rem;
    color: var(--color-text-dim);
}

.quick-actions {
    margin-top: calc(var(--spacing) * 4);
}

.quick-actions h2 {
    font-size: 1.25rem;
    margin-bottom: calc(var(--spacing) * 2);
}

.quick-actions-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: calc(var(--spacing) * 2);
}

.quick-action-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: calc(var(--spacing) * 3);
    text-decoration: none;
    color: var(--color-text);
    transition: background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
    min-height: 120px;
}

.quick-action-card:hover {
    background-color: var(--color-bg-alt);
    border-color: var(--color-primary);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.quick-action-icon {
    font-size: 2.5rem;
    margin-bottom: var(--spacing);
}

.quick-action-label {
    text-align: center;
    font-weight: 500;
}
.filters .filter-group select.form-control,
.filters select.form-control {
  min-width: 140px;
  max-width: 220px;
  width: 160px;
  background-color: #1f1f1f;
  color: #fff;
  border: 1px solid rgba(255,255,255,.12);
}
.filters .filter-group label{
  display:block;
  font-size:12px;
  opacity:.8;
  margin-bottom:6px;
}

.filters {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: calc(var(--spacing) * 2);
    margin-bottom: calc(var(--spacing) * 3);
}

.filters-form {
    display: flex;
    gap: calc(var(--spacing) * 2);
    flex-wrap: wrap;
    align-items: flex-end;
}

.filter-group {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.filter-group label {
    font-size: 0.875rem;
    color: var(--color-text-dim);
}

.form-group {
    margin-bottom: calc(var(--spacing) * 2);
}

.form-group label {
    display: block;
    margin-bottom: 4px;
    font-weight: 500;
    font-size: 0.9375rem;
}

.form-control {
    width: 100%;
    padding: var(--spacing) calc(var(--spacing) * 1.5);
    background-color: var(--color-bg-alt);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    color: var(--color-text);
    font-size: 0.9375rem;
    transition: border-color 0.2s;
}

.form-control:focus {
    outline: none;
    border-color: var(--color-primary);
}

.form-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: calc(var(--spacing) * 2);
}

.form-actions {
    display: flex;
    gap: calc(var(--spacing) * 2);
    margin-top: calc(var(--spacing) * 3);
}

.checkbox-label {
    display: flex;
    align-items: center;
    gap: var(--spacing);
    cursor: pointer;
}

.checkbox-label input[type="checkbox"] {
    width: auto;
}

.data-table {
    width: 100%;
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    border-collapse: collapse;
    overflow: hidden;
}

.data-table thead {
    background-color: var(--color-bg-alt);
}

.data-table th {
    padding: calc(var(--spacing) * 1.5);
    text-align: left;
    font-weight: 600;
    font-size: 0.875rem;
    text-transform: uppercase;
    color: var(--color-text-dim);
    border-bottom: 2px solid var(--color-border);
}

.data-table td {
    padding: calc(var(--spacing) * 1.5);
    border-bottom: 1px solid var(--color-border);
}

.data-table tbody tr:last-child td {
    border-bottom: none;
}

.data-table tbody tr:hover {
    background-color: var(--color-bg-alt);
}

.description-cell {
    max-width: 300px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.status-select {
    padding: 4px 8px;
    border-radius: 4px;
    border: 1px solid var(--color-border);
    font-size: 0.875rem;
    font-weight: 600;
    cursor: pointer;
}

.days-warning {
    color: var(--color-warning);
    font-weight: 600;
}

.days-critical {
    color: var(--color-danger);
    font-weight: 700;
}

.modal {
    display: none;
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.85);
    overflow-y: auto;
}

.modal-content {
    background-color: var(--color-bg-card);
    margin: 5% auto;
    padding: calc(var(--spacing) * 3);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    width: 90%;
    max-width: 600px;
}

.modal-content h2 {
    margin-bottom: calc(var(--spacing) * 3);
    color: var(--color-text);
}

.modal-close {
    color: var(--color-text-dim);
    float: right;
    font-size: 2rem;
    font-weight: bold;
    cursor: pointer;
    line-height: 1;
}

.modal-close:hover {
    color: var(--color-text);
}

/* TABLET & MOBILE MODAL RESPONSIVE */
@media (max-width: 768px) {
  .modal-content {
    width: 92% !important;
    max-width: 100% !important;
    margin: 10% auto !important;
    padding: calc(var(--spacing) * 2) !important;
  }
  .modal-content h2 {
    font-size: 1.2rem !important;
  }
}

@media (max-width: 480px) {
  .modal-content {
    width: 95% !important;
    margin: 5% auto !important;
    padding: calc(var(--spacing) * 2) !important;
    max-height: 95vh !important;
  }
  .modal-content h2 {
    font-size: 1.1rem !important;
    margin-bottom: calc(var(--spacing) * 2) !important;
  }
  .form-group {
    margin-bottom: 10px !important;
  }
  .form-group input,
  .form-group select,
  .form-group textarea {
    font-size: 16px !important;
    padding: 10px !important;
    width: 100% !important;
  }
  .form-actions {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
  }
  .form-actions button,
  .form-actions .btn {
    width: 100% !important;
    font-size: 14px !important;
    padding: 10px !important;
    min-height: 40px !important;
  }
  .modal {
    background: rgba(0,0,0,.95) !important;
  }
}

/* MOBILE LANDSCAPE MODE (Orientation: Landscape) */
@media (max-height: 500px) and (orientation: landscape) {
  .modal {
    background: rgba(0,0,0,.95) !important;
  }
  .modal-backdrop {
    background: rgba(0,0,0,0.95) !important;
  }
  .modal-content {
    margin: 2% auto !important;
    padding: calc(var(--spacing) * 1.5) !important;
    max-height: 96vh !important;
  }
  .modal-content h2 {
    font-size: 1rem !important;
    margin-bottom: calc(var(--spacing) * 1) !important;
  }
  .form-group {
    margin-bottom: 8px !important;
  }
  .form-group input,
  .form-group select,
  .form-group textarea {
    font-size: 16px !important;
    padding: 8px !important;
  }
  .form-actions button,
  .form-actions .btn {
    font-size: 13px !important;
    padding: 8px !important;
    min-height: 38px !important;
  }
}

.empty-state {
    text-align: center;
    padding: calc(var(--spacing) * 4);
    color: var(--color-text-dim);
}

.alert {
    padding: calc(var(--spacing) * 2);
    border-radius: 6px;
    margin-bottom: calc(var(--spacing) * 2);
}

.alert-error {
    background-color: rgba(239, 68, 68, 0.2);
    border: 1px solid var(--color-danger);
    color: var(--color-danger);
}

.alert-success {
    background-color: rgba(16, 185, 129, 0.2);
    border: 1px solid var(--color-success);
    color: var(--color-success);
}

.services-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: calc(var(--spacing) * 2);
    margin-bottom: calc(var(--spacing) * 4);
}

.service-card {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: calc(var(--spacing) * 2);
}

.service-card h3 {
    margin-bottom: var(--spacing);
    color: var(--color-text);
}

.service-type {
    color: var(--color-text-dim);
    font-size: 0.875rem;
    margin-bottom: var(--spacing);
}

.service-stats {
    display: flex;
    gap: calc(var(--spacing) * 2);
    margin-top: var(--spacing);
    font-size: 0.875rem;
}

.service-etage {
    color: var(--color-text-dim);
    font-size: 0.875rem;
    margin-top: 4px;
}

.chambre-info-card {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: calc(var(--spacing) * 3);
    margin-bottom: calc(var(--spacing) * 3);
}

.info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: calc(var(--spacing) * 2);
}

.info-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.info-label {
    font-size: 0.875rem;
    color: var(--color-text-dim);
}

.info-value {
    font-weight: 600;
    color: var(--color-text);
}

.equipements-chambre, .associer-equipement {
    margin-bottom: calc(var(--spacing) * 3);
}

.equipements-chambre h2, .associer-equipement h2 {
    font-size: 1.25rem;
    margin-bottom: calc(var(--spacing) * 2);
}

.form-inline {
    display: flex;
    gap: calc(var(--spacing) * 2);
    align-items: flex-end;
}

.form-inline .form-group {
    flex: 1;
    margin-bottom: 0;
}

.calendar-navigation {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: calc(var(--spacing) * 3);
}

.calendar-grid {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    overflow: hidden;
    margin-bottom: calc(var(--spacing) * 3);
}

.calendar-header {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    background-color: var(--color-bg-alt);
    border-bottom: 2px solid var(--color-border);
}

.calendar-day-name {
    padding: calc(var(--spacing) * 1.5);
    text-align: center;
    font-weight: 600;
    font-size: 0.875rem;
    text-transform: uppercase;
    color: var(--color-text-dim);
}

.calendar-body {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
}

.calendar-day {
    min-height: 100px;
    padding: var(--spacing);
    border: 1px solid var(--color-border);
}

.calendar-day-empty {
    background-color: var(--color-bg-alt);
}

.calendar-day-today {
    background-color: rgba(59, 130, 246, 0.1);
    border: 2px solid var(--color-primary);
}

.day-number {
    font-weight: 600;
    margin-bottom: 4px;
}

.day-events {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.event-item {
    font-size: 0.75rem;
    padding: 4px;
    background-color: var(--color-primary);
    color: white;
    border-radius: 4px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.event-preventif {
    background-color: var(--color-warning);
}

.event-controle {
    background-color: var(--color-danger);
}

.calendar-legend {
    margin-top: calc(var(--spacing) * 3);
}

.legend-items {
    display: flex;
    gap: calc(var(--spacing) * 3);
    flex-wrap: wrap;
}

.legend-item {
    display: flex;
    align-items: center;
    gap: var(--spacing);
}

.legend-color {
    width: 24px;
    height: 16px;
    border-radius: 4px;
}

.login-page {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    background: linear-gradient(135deg, var(--color-bg) 0%, var(--color-bg-alt) 100%);
}

.login-container {
    width: 100%;
    max-width: 400px;
    padding: calc(var(--spacing) * 2);
}

.login-card {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: calc(var(--spacing) * 4);
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.3);
}

.login-header {
    text-align: center;
    margin-bottom: calc(var(--spacing) * 3);
}

.login-header h1 {
    color: var(--color-primary);
    margin-bottom: var(--spacing);
}

.login-header p {
    color: var(--color-text-dim);
    font-size: 0.9375rem;
}

.login-form .form-group {
    margin-bottom: calc(var(--spacing) * 2);
}

.login-footer {
    text-align: center;
    margin-top: calc(var(--spacing) * 3);
    color: var(--color-text-dim);
    font-size: 0.875rem;
}

.select-site-container {
    max-width: 1000px;
    margin: 0 auto;
}

.select-site-container h1 {
    text-align: center;
    margin-bottom: calc(var(--spacing) * 4);
}

.sites-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: calc(var(--spacing) * 3);
}

.site-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    background-color: var(--color-bg-card);
    border: 2px solid var(--color-border);
    border-radius: 12px;
    padding: calc(var(--spacing) * 4);
    text-decoration: none;
    color: var(--color-text);
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.site-card:hover {
    border-color: var(--color-primary);
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.3);
}

.site-icon {
    font-size: 1.3rem;
    margin-bottom: calc(var(--spacing) * 2);
}

.site-name {
    font-size: 1.125rem;
    font-weight: 600;
    text-align: center;
    margin-bottom: var(--spacing);
}

.site-code {
    color: var(--color-primary);
    font-weight: 600;
    margin-bottom: 4px;
}

.site-type {
    color: var(--color-text-dim);
    font-size: 0.875rem;
    text-transform: capitalize;
}

.search-bar {
    margin-bottom: calc(var(--spacing) * 3);
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: calc(var(--spacing) * 2);
}

.search-form {
    width: 100%;
}

.search-input-wrapper {
    display: flex;
    gap: calc(var(--spacing) * 2);
    align-items: center;
}

.search-input {
    flex: 1;
    font-size: 1rem;
}

.results-info {
    background-color: var(--color-bg-alt);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    padding: calc(var(--spacing) * 1.5);
    margin-bottom: calc(var(--spacing) * 2);
}

.results-info p {
    margin: 0;
    color: var(--color-text-dim);
    font-size: 0.9375rem;
}

.data-table-clickable tbody tr {
    cursor: pointer;
    transition: background-color 0.2s ease;
}

.data-table-clickable tbody tr:hover {
    background-color: var(--color-bg-alt);
}

.equipment-name {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.equipment-serial {
    font-size: 0.8125rem;
    color: var(--color-text-dim);
    font-weight: normal;
}

.badge-category {
    background-color: rgba(59, 130, 246, 0.2);
    color: var(--color-primary);
    border: 1px solid rgba(59, 130, 246, 0.3);
}

.badge-normal {
    background-color: rgba(160, 160, 160, 0.2);
    color: var(--color-text-dim);
    border: 1px solid rgba(160, 160, 160, 0.3);
}

.location-info {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.location-chambre {
    font-size: 0.8125rem;
}

.location-chambre a {
    color: var(--color-primary);
    text-decoration: none;
}

.location-chambre a:hover {
    text-decoration: underline;
}

.brand-model {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.brand {
    font-weight: 500;
}

.model {
    font-size: 0.875rem;
    color: var(--color-text-dim);
}

.intervention-summary {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.intervention-count {
    font-weight: 600;
    font-size: 1.125rem;
    color: var(--color-primary);
}

.intervention-date {
    font-size: 0.8125rem;
    color: var(--color-text-dim);
}

.table-actions {
    display: flex;
    gap: var(--spacing);
    justify-content: flex-start;
}

.btn-sm {
    padding: 6px 12px;
    font-size: 0.8125rem;
}

.page-cta .cta-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 1rem;
    margin: 1rem 0 1.5rem;
}

.page-cta .stat-card {
    background: #ffffff;
    border-radius: 8px;
    padding: 0.8rem 1rem;
    border: 1px solid #e5e7eb;
}

.page-cta .stat-card h3 {
    margin: 0 0 0.3rem;
    font-size: 0.9rem;
    color: #4b5563;
}

.page-cta .stat-card .stat-value {
    margin: 0;
    font-size: 1.3rem;
    font-weight: 600;
}

.page-equipement-detail .breadcrumb,
.page-intervention-detail .breadcrumb {
    display: flex;
    align-items: center;
    gap: var(--spacing);
    margin-bottom: calc(var(--spacing) * 2);
    font-size: 0.9375rem;
    color: var(--color-text-dim);
}

.page-equipement-detail .breadcrumb a,
.page-intervention-detail .breadcrumb a {
    color: var(--color-primary);
    text-decoration: none;
}

.page-equipement-detail .breadcrumb a:hover,
.page-intervention-detail .breadcrumb a:hover {
    text-decoration: underline;
}

.detail-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: calc(var(--spacing) * 3);
    padding-bottom: calc(var(--spacing) * 2);
    border-bottom: 2px solid var(--color-border);
}

.detail-subtitle {
    color: var(--color-text-dim);
    font-size: 1rem;
    margin-top: var(--spacing);
}

.detail-actions {
    display: flex;
    gap: calc(var(--spacing) * 2);
}

.detail-grid {
    display: grid;
    grid-template-columns: 1fr 350px;
    gap: calc(var(--spacing) * 3);
}

.detail-main {
    display: flex;
    flex-direction: column;
    gap: calc(var(--spacing) * 3);
}

.detail-sidebar {
    display: flex;
    flex-direction: column;
    gap: calc(var(--spacing) * 3);
}

.info-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: calc(var(--spacing) * 2);
}

.info-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.info-label {
    font-size: 0.875rem;
    color: var(--color-text-dim);
    font-weight: 500;
}

.info-value {
    font-size: 1rem;
    color: var(--color-text);
}

.info-value a {
    color: var(--color-primary);
    text-decoration: none;
}

.info-value a:hover {
    text-decoration: underline;
}

.interventions-list, .releves-list {
    display: flex;
    flex-direction: column;
    gap: calc(var(--spacing) * 2);
}

.intervention-item {
    padding: calc(var(--spacing) * 2);
    background-color: var(--color-bg-alt);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    transition: all 0.2s;
}

.intervention-item:hover {
    border-color: var(--color-primary);
    transform: translateX(4px);
}

.intervention-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing);
}

.intervention-title {
    color: var(--color-text);
    text-decoration: none;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: var(--spacing);
}

.intervention-title:hover {
    color: var(--color-primary);
}

.intervention-date {
    font-size: 0.875rem;
    color: var(--color-text-dim);
}

.intervention-desc {
    color: var(--color-text-dim);
    font-size: 0.9375rem;
    margin-bottom: var(--spacing);
}

.intervention-tech {
    font-size: 0.875rem;
    color: var(--color-text-dim);
}

.releve-item {
    padding: calc(var(--spacing) * 1.5);
    background-color: var(--color-bg-alt);
    border: 1px solid var(--color-border);
    border-radius: 6px;
}

.releve-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing);
}

.releve-date {
    font-weight: 600;
    color: var(--color-text);
}

.releve-operator {
    font-size: 0.875rem;
    color: var(--color-text-dim);
}

.releve-value {
    font-size: 0.9375rem;
    margin-bottom: 4px;
}

.releve-value strong {
    color: var(--color-primary);
}

.releve-remarks {
    font-size: 0.875rem;
    color: var(--color-text-dim);
    font-style: italic;
}

.stats-list {
    display: flex;
    flex-direction: column;
    gap: calc(var(--spacing) * 2);
}

.stat-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-bottom: calc(var(--spacing) * 1.5);
    border-bottom: 1px solid var(--color-border);
}

.stat-item:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.stat-label {
    font-size: 0.9375rem;
    color: var(--color-text-dim);
}

.stat-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-primary);
}
.row-notes td {
    background: #f9fafb;
    padding-top: 0.25rem;
    padding-bottom: 0.75rem;
}

.room-notes {
    margin: 0.25rem 0 0;
    padding-left: 1.2rem;
    font-size: 0.85rem;
    color: #4b5563;
}
.layout-two-columns {
    display: grid;
    grid-template-columns: minmax(0, 2fr) minmax(0, 1.5fr);
    gap: 1.5rem;
    margin-top: 1rem;
}

@media (max-width: 900px) {
    .layout-two-columns {
        grid-template-columns: 1fr;
    }
}

.filters-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: flex-end;
    margin-bottom: 1rem;
}

.filter-item label {
    display: block;
    font-size: 0.85rem;
    margin-bottom: 0.2rem;
}

.row-notes td {
    background: #f9fafb;
    padding-top: 0.25rem;
    padding-bottom: 0.75rem;
}

.room-notes {
    margin: 0.25rem 0 0;
    padding-left: 1.2rem;
    font-size: 0.85rem;
    color: #4b5563;
}

	.dashboard-notes {
    margin-top: 1.5rem;
	}

	.dashboard-notes .notes-list {
		list-style: none;
		padding-left: 0;
		margin: 0.5rem 0 0;
	}

	.dashboard-notes .notes-list li {
		margin-bottom: 0.6rem;
		padding-bottom: 0.4rem;
		border-bottom: 1px solid #e5e7eb;
	}

	.dashboard-notes .notes-list li:last-child {
		border-bottom: none;
	}

	.dashboard-notes .note-sub {
		font-size: 0.85rem;
		color: #6b7280;
	}

.quick-actions {
    display: flex;
    flex-direction: column;
    gap: calc(var(--spacing) * 1.5);
}

.quick-action-btn {
    display: block;
    width: 100%;
    padding: calc(var(--spacing) * 1.5);
    background-color: var(--color-bg-alt);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    color: var(--color-text);
    text-decoration: none;
    text-align: center;
    font-weight: 500;
    transition: all 0.2s;
}

.quick-action-btn:hover {
    background-color: var(--color-primary);
    color: white;
    border-color: var(--color-primary);
    transform: translateY(-2px);
}

.modal-large {
    max-width: 800px;
}

.data-table-interventions tbody tr.intervention-row {
    cursor: pointer;
    transition: all 0.2s;
}

.data-table-interventions tbody tr.intervention-row:hover {
    background-color: var(--color-bg-alt);
    transform: translateX(2px);
}

.equipment-link a {
    color: var(--color-primary);
    text-decoration: none;
    font-weight: 500;
}

.equipment-link a:hover {
    text-decoration: underline;
}

.dashboard-notes .notes-list {
    list-style: none;
    padding-left: 0;
    margin: 0.5rem 0 0;
}

.dashboard-notes .notes-list li {
    margin-bottom: 0.6rem;
    padding-bottom: 0.4rem;
    border-bottom: 1px solid #e5e7eb;
    font-size: 0.9rem;
}

.dashboard-notes .notes-list li:last-child {
    border-bottom: none;
}

.text-dim {
    color: var(--color-text-dim);
    font-style: italic;
}

.badge-type-curatif {
    background-color: rgba(239, 68, 68, 0.2);
    color: #ef4444;
    border: 1px solid rgba(239, 68, 68, 0.3);
}

.badge-type-preventif {
    background-color: rgba(16, 185, 129, 0.2);
    color: #10b981;
    border: 1px solid rgba(16, 185, 129, 0.3);
}

.badge-type-amelioratif {
    background-color: rgba(59, 130, 246, 0.2);
    color: var(--color-primary);
    border: 1px solid rgba(59, 130, 246, 0.3);
}

.intervention-description {
    line-height: 1.4;
    color: var(--color-text);
}

.days-badge {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
}

.days-count {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--color-text);
}

.days-count.days-warning {
    color: var(--color-warning);
}

.days-count.days-critical {
    color: var(--color-danger);
}

.days-label {
    font-size: 0.75rem;
    color: var(--color-text-dim);
    text-transform: uppercase;
}

.location-info-compact {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.location-chambre-compact {
    font-size: 0.8125rem;
    color: var(--color-text-dim);
}

.status-select {
    padding: 4px 8px;
    border-radius: 4px;
    border: 1px solid var(--color-border);
    background-color: var(--color-bg-alt);
    color: var(--color-text);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
}

.status-select:hover {
    border-color: var(--color-primary);
}

.status-select-ouvert {
    background-color: rgba(239, 68, 68, 0.1);
    border-color: rgba(239, 68, 68, 0.3);
    color: #ef4444;
}

.status-select-en_cours {
    background-color: rgba(245, 158, 11, 0.1);
    border-color: rgba(245, 158, 11, 0.3);
    color: #f59e0b;
}

.status-select-en_attente {
    background-color: rgba(234, 179, 8, 0.1);
    border-color: rgba(234, 179, 8, 0.3);
    color: #eab308;
}

.status-select-cloture {
    background-color: rgba(16, 185, 129, 0.1);
    border-color: rgba(16, 185, 129, 0.3);
    color: #10b981;
}

.intervention-info-card {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: calc(var(--spacing) * 3);
}

.intervention-info-card h3 {
    color: var(--color-text);
    margin-bottom: calc(var(--spacing) * 1.5);
    font-size: 1.125rem;
}

.intervention-info-card p {
    color: var(--color-text);
    line-height: 1.6;
}

.form-update {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: calc(var(--spacing) * 3);
}

@media (max-width: 768px) {
    .header-content {
        flex-direction: column;
        gap: calc(var(--spacing) * 2);
    }

    .dashboard-grid, .quick-actions-grid {
        grid-template-columns: 1fr;
    }

    .stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .filters-form {
        flex-direction: column;
        align-items: stretch;
    }

    .form-row {
        grid-template-columns: 1fr;
    }

    .calendar-day {
        min-height: 80px;
    }

    .calendar-day-name, .event-item {
        font-size: 0.75rem;
    }

    .detail-grid {
        grid-template-columns: 1fr;
    }

    .info-grid {
        grid-template-columns: 1fr;
    }

    .detail-actions {
        flex-direction: column;
    }

    .search-input-wrapper {
        flex-direction: column;
    }

    .table-actions {
        flex-direction: column;
    }
	
	.cta-info-grid {
		display: grid;
		grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
		gap: 0.75rem 1.5rem;
	}

	.cta-info-grid .label {
		font-size: 0.75rem;
		text-transform: uppercase;
		color: #6b7280;
	}

	.cta-info-grid .value {
		font-size: 0.95rem;
		font-weight: 500;
	}

	.form-inline-grid {
		display: grid;
		grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
		gap: 0.75rem 1rem;
		margin-bottom: 1rem;
	}

	.form-group-actions {
		display: flex;
		align-items: flex-end;
	}

	.badge-type-preventif {
		background: #dbeafe;
		color: #1d4ed8;
	}

	.badge-type-curatif {
		background: #fee2e2;
		color: #b91c1c;
	}

	.badge-type-controle {
		background: #ecfdf5;
		color: #15803d;
	}
/* === Surbrillance CTA sélectionnée dans la liste === */
table.data-table tbody tr.row-selected {
    background-color: #020617 !important;         /* fond plus sombre */
    box-shadow: inset 3px 0 0 #3b82f6;           /* bandeau bleu à gauche */
}

/* Texte lisible dans la ligne sélectionnée */
table.data-table tbody tr.row-selected td,
table.data-table tbody tr.row-selected td * {
    color: #e5e7eb !important;
}

/* Bouton "Détail" dans la ligne sélectionnée */
table.data-table tbody tr.row-selected .btn {
    background-color: #3b82f6 !important;
    border-color: #3b82f6 !important;
    color: #f9fafb !important;
}

/* Toolbar historique CTA */
.history-toolbar {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
}

.history-toolbar .btn {
    padding: 0.2rem 0.6rem;
    font-size: 0.75rem;
}

/* ===== HERO IMAGE INTERVENTIONS ===== */
.page-hero{
  display:flex;
  flex-direction:column;
  align-items:center;          /* centre horizontalement */
  justify-content:center;
  gap:10px;
  margin: 16px 0 20px;
  padding: 14px 16px;
  text-align:center;
}

.page-hero__img{
  width:64px;                  /* taille desktop */
  height:64px;
  max-width:100%;
  object-fit:contain;
  opacity:0.95;
}

/* Texte */
.page-hero__text h1{
  margin:6px 0 0;
  font-size:22px;
}

.page-hero__text p{
  margin:4px 0 0;
  font-size:14px;
  opacity:0.8;
}

/* Responsive */
@media (max-width: 768px){
  .page-hero__img{
    width:48px;
    height:48px;
  }
  .page-hero__text h1{
    font-size:18px;
  }
}
/* === Fix SELECT styling (évite le blanc) === */
select,
select.input,
.filters select,
.filters-bar select {
  background: var(--card);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px 12px;
  outline: none;
  width: 100%;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}

select:disabled {
  opacity: .55;
  cursor: not-allowed;
}

select:focus,
select.input:focus,
.filters select:focus {
  box-shadow: 0 0 0 3px rgba(121, 87, 255, 0.15);
  border-color: rgba(121, 87, 255, 0.7);
}

/* option (certains navigateurs ignorent) */
select option {
  background: #1b1b1f;
  color: #f1f1f5;
}
.card-click { cursor: pointer; transition: transform .08s ease, box-shadow .08s ease; }
.card-click:hover { transform: translateY(-1px); box-shadow: 0 10px 30px rgba(0,0,0,.25); }
.card-active { outline: 2px solid rgba(59,130,246,.6); }

.row-click { cursor: pointer; }
.row-click:hover { background: rgba(255,255,255,.03); }

select.input { appearance: auto; }

/* ===== BAES Analyse (KPI + charts) ===== */
.page-head{
  display:flex; align-items:flex-start; justify-content:space-between;
  gap:16px; margin: 8px 0 18px;
}
.page-title h1{ margin:0; font-size:28px; letter-spacing:.2px; }
.page-title .muted{ margin:6px 0 0; opacity:.8; }

.grid-2{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:14px;
  margin: 14px 0;
}
@media (max-width: 1100px){
  .grid-2{ grid-template-columns:1fr; }
}

.card{
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 14px;
  overflow:hidden;
}
.card-head{
  display:flex; align-items:center; justify-content:space-between;
  padding: 12px 14px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.card-title{ font-weight:700; }
.card-subtitle{ opacity:.75; font-size:13px; margin-top:2px; }
.card-body{ padding: 14px; }

.kpi-grid{
  display:grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap:10px;
  margin: 8px 0 12px;
}
@media (max-width: 1100px){
  .kpi-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
.kpi{
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 14px;
  padding: 12px 12px;
  min-height: 62px;
}
.kpi-label{ opacity:.72; font-size:12px; }
.kpi-value{ font-size:22px; font-weight:800; margin-top:4px; }

.kpi-ok{ border-color: rgba(70,200,140,0.35); }
.kpi-hs{ border-color: rgba(255,90,90,0.35); }
.kpi-veille{ border-color: rgba(255,170,60,0.35); }
.kpi-crit{ border-color: rgba(255,90,90,0.22); }

.table-wrap{ overflow:auto; }
.table{ width:100%; border-collapse:collapse; }
.table th, .table td{
  padding: 10px 10px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  vertical-align: top;
}
.table th{ opacity:.75; font-size:12px; text-transform: uppercase; letter-spacing:.6px; }
.table .right{ text-align:right; }

.pill{
  display:inline-flex; align-items:center; justify-content:center;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 12px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.04);
}
.pill-ok{ border-color: rgba(70,200,140,0.35); }
.pill-hs{ border-color: rgba(255,90,90,0.35); }
.pill-veille{ border-color: rgba(255,170,60,0.35); }
.pill-crit{ border-color: rgba(255,90,90,0.25); }

.hint{ margin-top: 10px; font-size: 12px; opacity:.7; }

/* BAES Analyse layout */
.kpi-grid{display:grid;grid-template-columns:repeat(6,minmax(140px,1fr));gap:12px;margin:14px 0 18px}
.kpi{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:10px 12px}
.kpi-label{opacity:.75;font-size:12px}
.kpi-value{font-size:22px;font-weight:700;margin-top:2px}
.kpi-sub{opacity:.75;font-size:12px;margin-top:2px}
.kpi-ok{border-color:rgba(60,200,120,.25)}
.kpi-hs{border-color:rgba(255,80,80,.25)}
.kpi-warn{border-color:rgba(255,170,0,.25)}
.kpi-crit{border-color:rgba(180,120,255,.25)}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:start}
.card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:14px;overflow:hidden}
.card-h{display:flex;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.06)}
.table-wrap{padding:8px 10px}
.legend{display:flex;gap:14px;align-items:center;margin-top:8px;opacity:.85;font-size:12px}
.dot{display:inline-block;width:10px;height:10px;border-radius:99px;margin-right:6px;background:rgba(255,255,255,.3)}
.dot.ok{background:rgba(60,200,120,.9)} .dot.hs{background:rgba(255,80,80,.9)} .dot.ve{background:rgba(255,170,0,.9)}

.bar{display:flex;align-items:center;gap:10px}
.bar span{display:inline-block;height:8px;border-radius:99px;background:rgba(90,160,255,.9)}
.bar em{font-style:normal;opacity:.85;font-size:12px}

.txt-hs{color:#ff6b6b}
.txt-ve{color:#ffb84d}
.txt-crit{color:#b58cff}
.pill{display:inline-block;padding:2px 8px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);font-size:12px}
.pill-crit{background:rgba(180,120,255,.12);border-color:rgba(180,120,255,.25)}

@media (max-width: 1100px){
  .kpi-grid{grid-template-columns:repeat(3,minmax(140px,1fr))}
  .grid-2{grid-template-columns:1fr}
}

/* === ANALYTICS PAGE === */
.analytics-page {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  padding: 1rem;
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
}

.header-actions {
  display: flex;
  gap: 0.25rem;
  justify-content: center;
}

.kpi-section {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.1rem;
  margin-bottom: 0.1rem;
}

.kpi-compact {
  background: white;
  border-left: 2px solid;
  border-radius: 2px;
  padding: 0.2rem 0.15rem;
  display: flex;
  flex-direction: column;
  gap: 0.02rem;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
  text-align: center;
  font-size: 0.65rem;
}

.kpi-compact:hover {
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
}

.kpi-primary { border-left-color: var(--color-primary); }
.kpi-success { border-left-color: var(--color-success); }
.kpi-info { border-left-color: #0ea5e9; }
.kpi-warning { border-left-color: var(--color-warning); }

.kpi-value {
  font-size: 0.75rem;
  font-weight: 800;
  color: var(--color-primary);
  line-height: 1;
}

.kpi-label {
  font-size: 0.5rem;
  color: var(--color-text-dim);
  font-weight: 600;
}

/* Charts Grid - Ultra Compact */
.charts-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.15rem;
  height: fit-content;
}

.chart-card {
  display: flex;
  flex-direction: column;
  padding: 0.2rem;
  background: white;
  border: 1px solid var(--color-border);
  border-radius: 2px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
  text-align: center;
  height: fit-content;
  max-height: 120px;
}

.chart-card h3 {
  margin: 0;
  padding: 0.15rem 0;
  font-size: 0.65rem;
  font-weight: 600;
  color: var(--color-text);
  line-height: 1;
}

.chart-card canvas {
  max-height: 100px !important;
  width: 100% !important;
  height: 100px !important;
}

/* Top Sections */
.top-sections {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.15rem;
  height: fit-content;
}

.top-sections > .card {
  text-align: center;
  padding: 0.2rem !important;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.top-sections h3 {
  text-align: center;
  margin: 0 0 0.2rem 0;
  font-size: 0.65rem;
  font-weight: 600;
  line-height: 1;
}

.simple-list {
  display: flex;
  flex-direction: column;
  gap: 0.08rem;
  min-height: 0;
}

.simple-item {
  display: grid;
  grid-template-columns: 14px 1fr 28px;
  align-items: center;
  gap: 0.15rem;
  padding: 0.1rem 0.15rem;
  background: var(--color-bg-alt);
  border-radius: 2px;
  font-size: 0.6rem;
  height: fit-content;
}

.simple-item:hover {
  background: rgba(var(--color-rgb-primary), 0.08);
}

.rank-badge {
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover));
  color: white;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 0.45rem;
  flex-shrink: 0;
  margin: 0 auto;
  line-height: 1;
}

.simple-item .label {
  font-weight: 500;
  color: var(--color-text);
  font-size: 0.6rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-align: left;
}

.simple-item .count {
  text-align: center;
  background: var(--color-primary);
  color: white;
  padding: 0.08rem 0.2rem;
  border-radius: 2px;
  font-size: 0.5rem;
  font-weight: 600;
  white-space: nowrap;
  line-height: 1;
}

.empty-state {
  text-align: center;
  padding: 0.2rem;
  color: var(--color-text-dim);
  font-size: 0.6rem;
}

/* Context Sections - Par Étage/Lieu */
.context-sections {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.15rem;
  height: fit-content;
}

.context-sections > .card {
  text-align: left;
  padding: 0.2rem !important;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.context-sections h3 {
  text-align: left;
  margin: 0 0 0.2rem 0;
  font-size: 0.65rem;
  font-weight: 600;
  line-height: 1;
}

/* Simplified items without rank badge */
.context-sections .simple-item {
  display: grid;
  grid-template-columns: 1fr 28px;
  gap: 0.15rem;
}

/* Types List - Enhanced Display */
.types-list {
  display: flex !important;
  flex-direction: column;
  gap: 0.1rem;
  min-height: 0;
  text-align: left !important;
}

.type-item {
  background: var(--color-bg-alt);
  border-radius: 2px;
  padding: 0.1rem;
  display: flex;
  flex-direction: column;
  gap: 0.05rem;
  text-align: left;
}

.type-item:hover {
  background: rgba(var(--color-rgb-primary), 0.08);
}

.type-header {
  display: grid;
  grid-template-columns: 14px 1fr 28px;
  align-items: center;
  gap: 0.15rem;
  padding: 0.05rem 0.1rem;
  text-align: left;
}

.type-name {
  font-size: 0.6rem;
  font-weight: 500;
  color: var(--color-text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-align: left;
}

.type-count {
  text-align: center !important;
  background: var(--color-primary);
  color: white;
  padding: 0.08rem 0.2rem;
  border-radius: 2px;
  font-size: 0.5rem;
  font-weight: 600;
  white-space: nowrap;
  line-height: 1;
}

.type-stats {
  display: flex;
  flex-direction: column;
  gap: 0.05rem;
  padding: 0.05rem 0.1rem;
  text-align: left;
}

.stat-bar {
  height: 6px;
  background: rgba(0, 0, 0, 0.08);
  border-radius: 1px;
  overflow: hidden;
}

.bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--color-primary), var(--color-primary-hover));
  transition: width 0.3s ease;
}

.stat-mini {
  display: flex;
  gap: 0.15rem;
  font-size: 0.48rem;
  text-align: left;
}

.mini-stat {
  background: rgba(0, 0, 0, 0.04);
  padding: 0.04rem 0.1rem;
  border-radius: 1px;
  color: var(--color-text-dim);
  font-weight: 500;
  white-space: nowrap;
  text-align: center;
}

.mini-stat.high-priority {
  background: rgba(239, 68, 68, 0.1);
  color: #dc2626;
}

.zones-list {
  display: flex !important;
  flex-direction: column;
  gap: 0.1rem;
  min-height: 0;
  text-align: left !important;
}

.zone-item {
  background: var(--color-bg-alt);
  border-radius: 2px;
  padding: 0.1rem;
  display: flex;
  flex-direction: column;
  gap: 0.05rem;
  text-align: left;
}

.zone-item:hover {
  background: rgba(var(--color-rgb-primary), 0.08);
}

.zone-header {
  display: grid;
  grid-template-columns: 14px 1fr 28px;
  align-items: center;
  gap: 0.15rem;
  padding: 0.05rem 0.1rem;
  text-align: left;
}

.zone-name {
  font-size: 0.6rem;
  font-weight: 500;
  color: var(--color-text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-align: left;
}

.zone-count {
  text-align: center !important;
  background: var(--color-primary);
  color: white;
  padding: 0.08rem 0.2rem;
  border-radius: 2px;
  font-size: 0.5rem;
  font-weight: 600;
  white-space: nowrap;
  line-height: 1;
}

.zone-stats {
  display: flex;
  flex-direction: column;
  gap: 0.05rem;
  padding: 0.05rem 0.1rem;
  text-align: left;
}

.etages-list {
  display: flex !important;
  flex-direction: column;
  gap: 0.1rem;
  min-height: 0;
  text-align: left !important;
}

.etage-item {
  background: var(--color-bg-alt);
  border-radius: 2px;
  padding: 0.1rem;
  display: flex;
  flex-direction: column;
  gap: 0.05rem;
  text-align: left;
}

.etage-item:hover {
  background: rgba(var(--color-rgb-primary), 0.08);
}

.etage-header {
  display: grid;
  grid-template-columns: 1fr 28px;
  align-items: center;
  gap: 0.15rem;
  padding: 0.05rem 0.1rem;
  text-align: left;
}

.etage-name {
  font-size: 0.6rem;
  font-weight: 500;
  color: var(--color-text);
  text-align: left;
}

.etage-count {
  text-align: center !important;
  background: var(--color-primary);
  color: white;
  padding: 0.08rem 0.2rem;
  border-radius: 2px;
  font-size: 0.5rem;
  font-weight: 600;
  white-space: nowrap;
  line-height: 1;
}

.etage-stats {
  display: flex;
  flex-direction: column;
  gap: 0.05rem;
  padding: 0.05rem 0.1rem;
  text-align: left;
}

/* Detail Metrics */
.detail-metrics {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.15rem;
  margin-bottom: 0.15rem;
  width: 100%;
}

@media (max-width: 600px) {
  .detail-metrics {
    grid-template-columns: repeat(2, 1fr);
  }
}

.detail-card {
  background: white;
  border: 1px solid var(--color-border);
  border-radius: 2px;
  padding: 0.2rem 0.15rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}

.detail-card:hover {
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}

.metric-item {
  display: flex;
  flex-direction: column;
  gap: 0.05rem;
}

.metric-label {
  font-size: 0.55rem;
  color: var(--color-text-dim);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.metric-value {
  font-size: 0.8rem;
  font-weight: 800;
  color: var(--color-primary);
  line-height: 1;
}

/* Calendar Container */
.calendar-container {
  width: 100%;
  max-width: 700px;
  margin: 0.3rem auto 0;
  padding: 0;
}

/* Inside analytics page - calendar wrapper */
#calendar-yearly-wrapper {
  width: 100%;
  display: flex;
  flex-direction: column;
}

/* Yearly Calendar Grid */
.calendar-grid-analytics {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 0.08rem;
}

.calendar-grid-analytics .calendar-head {
  font-size: 0.55rem;
  opacity: 0.75;
  padding: 0.3rem 0.2rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 600;
  text-align: center;
}

.calendar-grid-analytics .calendar-cell {
  min-height: 50px;
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: 2px;
  padding: 0.2rem;
  background: rgba(255, 255, 255, 0.98);
  font-size: 0.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.05rem;
}

.calendar-grid-analytics .calendar-empty {
  background: transparent;
  border-color: transparent;
  min-height: 0;
}

.calendar-grid-analytics .calendar-day {
  font-weight: 700;
  font-size: 0.55rem;
  opacity: 0.9;
  margin-bottom: 0.05rem;
}

.calendar-grid-analytics .calendar-cell.is-today {
  border-color: rgba(64, 156, 255, 0.55);
  background: rgba(64, 156, 255, 0.08);
  box-shadow: 0 0 0 1px rgba(64, 156, 255, 0.25) inset;
}

.calendar-grid-analytics .ev {
  margin: 0;
  padding: 0.08rem 0.1rem;
  border-radius: 1px;
  background: rgba(0, 0, 0, 0.06);
  border: 1px solid rgba(0, 0, 0, 0.08);
  font-size: 0.45rem;
  line-height: 1.1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.calendar-grid-analytics .ev-rappel {
  background: rgba(64, 156, 255, 0.14);
  border-color: rgba(64, 156, 255, 0.25);
}

.calendar-grid-analytics .ev-link {
  color: inherit;
  text-decoration: none;
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.calendar-grid-analytics .ev-link:hover {
  text-decoration: underline;
}

/* PDF Export Styles */
@media print {
  * {
    background-color: #ffffff !important;
    color: #000000 !important;
    border-color: #cccccc !important;
  }
  
  body {
    background-color: #ffffff !important;
    color: #000000 !important;
  }

  .analytics-page {
    max-width: 210mm;
    margin: 0;
    padding: 3mm;
    gap: 0.2rem;
    background-color: #ffffff !important;
  }

  .header-actions {
    display: none;
  }

  .detail-metrics {
    gap: 0.2rem;
    page-break-inside: avoid;
  }

  .types-list {
    gap: 0.08rem;
  }

  .type-item {
    padding: 0.08rem;
  }

  .stat-bar {
    height: 5px;
  }

  .stat-mini {
    font-size: 0.42rem;
  }

  .charts-grid {
    gap: 0.2rem;
    page-break-inside: avoid;
  }

  .chart-card {
    page-break-inside: avoid;
    padding: 0.2rem;
  }

  .chart-card canvas {
    max-height: 70px !important;
  }

  .top-sections {
    gap: 0.2rem;
    page-break-inside: avoid;
  }

  .top-sections > .card {
    page-break-inside: avoid;
    padding: 0.2rem !important;
  }

  .context-sections {
    gap: 0.1rem;
    page-break-inside: avoid;
  }

  .context-sections > .card {
    page-break-inside: avoid;
    padding: 0.2rem !important;
  }

  .calendar-container {
    margin: 0.2rem auto 0;
    page-break-inside: avoid;
  }

  .calendar-yearly-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 0.1rem;
  }

  .mini-month {
    page-break-inside: avoid;
  }

  .mini-calendar-grid {
    gap: 0.5px;
    padding: 0.08rem;
  }

  .mini-cell {
    font-size: 0.35rem;
  }

  .calendar-grid-analytics {
    gap: 0.05rem;
  }

  .calendar-grid-analytics .calendar-cell {
    min-height: 30px;
    padding: 0.1rem;
    font-size: 0.4rem;
  }

  .calendar-grid-analytics .calendar-day {
    font-size: 0.45rem;
  }
}

.btn-group {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}

.btn-group .btn,
.btn-group a.btn {
  display: inline-block;
  padding: 8px 16px;
  font-size: 0.9375rem;
  white-space: nowrap;
}

.btn-group .btn-xs {
  padding: 4px 8px;
  font-size: 0.8rem;
}

/* Articles en alerte - texte rouge pour meilleure visibilité */
.alert-item {
  color: #000000 !important;
  font-weight: 600;
}

.alert-item * {
  color: #000000 !important;
}

.alert-item strong {
  color: #ff0000 !important;
}

.alert-item .btn {
  color: #000000 !important;
}

/* Dashboard - Priorités immédiates cards */
.card {
    background: rgba(255, 255, 255, 0.95) !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08) !important;
    padding: 1.25rem !important;
    border-radius: 8px !important;
    transition: transform 0.2s, box-shadow 0.2s !important;
}

.card:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12) !important;
}

.nav-dropdown a {
  display: flex;
  align-items: center;
  color: var(--color-text);
  text-decoration: none;
}

.nav-dropdown-toggle {
  display: flex;
  align-items: center;
  white-space: nowrap;
}

/* ============================================================
   UNIFIED STYLE SYSTEM (v2)
   Applied as overrides to consolidate colors, typography, spacing.
   Maintains backward compatibility with all existing classes.
   ============================================================ */

/* === STEP 1: ESTABLISH UNIFIED COLOR TOKENS ===
   These override previous definitions with consistent values.
   Priority: alert > warning > success > info > neutral */

:root {
  /* === PRIMARY COLORS (semantic roles) === */
  --color-danger: #ef4444;        /* Red: errors, dangers, critical */
  --color-warning: #f59e0b;       /* Orange: warnings, in progress */
  --color-success: #10b981;       /* Green: success, ok, healthy */
  --color-primary: #3b82f6;       /* Blue: links, primary actions */
  --color-info: #0ea5e9;          /* Cyan: informational */

  /* === SECONDARY COLORS (lighter variants for backgrounds/borders) === */
  --color-danger-light: rgba(239, 68, 68, 0.15);
  --color-warning-light: rgba(245, 158, 11, 0.15);
  --color-success-light: rgba(16, 185, 129, 0.15);
  --color-primary-light: rgba(59, 130, 246, 0.15);

  /* === STATUS COLORS (maintenance-specific) === */
  --status-ouvert: #ef4444;       /* Open = Red/danger */
  --status-en-cours: #f59e0b;     /* In progress = Orange */
  --status-en-attente: #eab308;   /* Pending = Yellow */
  --status-cloture: #10b981;      /* Closed = Green */

  /* === NEUTRAL COLORS (dark theme base) === */
  --color-bg: #1a1a1a;
  --color-bg-alt: #242424;
  --color-bg-card: #2a2a2a;
  --color-border: #3a3a3a;
  --color-text: #e0e0e0;
  --color-text-dim: #9ca3af;      /* More readable gray */

  /* === TYPOGRAPHY SCALE === */
  --fs-xs: 12px;
  --fs-sm: 14px;
  --fs-md: 16px;
  --fs-lg: 20px;
  --fs-xl: 28px;

  /* === SPACING SYSTEM (8px baseline) === */
  --spacing: 8px;
  --spacing-xs: 4px;
  --spacing-sm: 8px;
  --spacing-md: 16px;
  --spacing-lg: 24px;
  --spacing-xl: 32px;

  /* === RADIUS SYSTEM (consistent rounding) === */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-full: 9999px;

  /* === SHADOWS === */
  --shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.15);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.20);
  --shadow-lg: 0 10px 30px rgba(0, 0, 0, 0.30);
  --shadow-xl: 0 20px 60px rgba(0, 0, 0, 0.40);

  /* === FOCUS RING === */
  --focus-ring: 0 0 0 3px rgba(59, 130, 246, 0.15);

  /* === ALIASES (backward compatibility) === */
  --bg: var(--color-bg);
  --bg-alt: var(--color-bg-alt);
  --card: var(--color-bg-alt);
  --card-2: var(--color-bg-card);
  --text: var(--color-text);
  --text-dim: var(--color-text-dim);
  --border: var(--color-border);
}

/* === STEP 2: UNIFIED FONT SETTINGS === */
body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  font-size: 14px;
  line-height: 1.5;
  color: var(--color-text);
  background-color: var(--color-bg);
}

/* === STEP 3: CONSOLIDATE ALL RED/DANGER DEFINITIONS ===
   Override all conflicting reds (#dc2626, #ff5d5d, #ff6b6b, etc.) */

.badge-hs,
.badge-crit,
.badge-ok-status-ouvert,
.kpi-hs,
.status-ouvert,
.badge.status-ouvert,
.priority-haute,
.badge-critique,
.txt-hs {
  color: var(--color-danger) !important;
  border-color: rgba(239, 68, 68, 0.35) !important;
}

.status-ouvert,
.badge.status-ouvert {
  background-color: var(--color-danger-light) !important;
}

.stat-ouvert {
  border-left-color: var(--color-danger) !important;
}

.status-select-ouvert {
  background-color: var(--color-danger-light) !important;
  border-color: rgba(239, 68, 68, 0.3) !important;
  color: var(--color-danger) !important;
}

/* === STEP 4: CONSOLIDATE ALL ORANGE/WARNING DEFINITIONS ===
   Override all conflicting oranges (#ffb020, #ffb84d, #ffa340, etc.) */

.badge-warn,
.kpi-warn,
.status-en-cours,
.badge.status-en-cours,
.priority-normale,
.txt-ve,
.event-preventif {
  color: var(--color-warning) !important;
  border-color: rgba(245, 158, 11, 0.35) !important;
}

.status-en-cours,
.badge.status-en-cours {
  background-color: var(--color-warning-light) !important;
}

.stat-en-cours {
  border-left-color: var(--color-warning) !important;
}

.status-select-en_cours {
  background-color: var(--color-warning-light) !important;
  border-color: rgba(245, 158, 11, 0.3) !important;
  color: var(--color-warning) !important;
}

.kpi-warn {
  border-color: rgba(255, 170, 0, 0.25) !important;
}

.pill-veille {
  border-color: rgba(255, 170, 60, 0.35) !important;
}

/* === STEP 5: CONSOLIDATE ALL GREEN/SUCCESS DEFINITIONS ===
   Override all conflicting greens (#3ddc97, #46c88c, #3cc88c, etc.) */

.badge-ok,
.kpi-ok,
.status-cloture,
.badge.status-cloture,
.priority-basse,
.badge-type-preventif,
.event-controle,
.pill-ok {
  color: var(--color-success) !important;
  border-color: rgba(16, 185, 129, 0.35) !important;
}

.status-cloture,
.badge.status-cloture {
  background-color: var(--color-success-light) !important;
}

.stat-cloture {
  border-left-color: var(--color-success) !important;
}

.status-select-cloture {
  background-color: var(--color-success-light) !important;
  border-color: rgba(16, 185, 129, 0.3) !important;
  color: var(--color-success) !important;
}

.kpi-ok {
  border-color: rgba(70, 200, 140, 0.25) !important;
}

/* === STEP 6: CANONICAL PENDING (VIOLET) ===
   En attente = violet everywhere (desktop select + badges) */

:root{
  --color-status-en-attente: #8b5cf6;
}

.status-en-attente,
.badge.status-en-attente,
.badge[data-status="en_attente"],
.statut-en_attente,
.badge.statut-en_attente{
  background-color: rgba(139, 92, 246, 0.18) !important;
  color: #ddd6fe !important;
  border-color: rgba(139, 92, 246, 0.45) !important;
}

.status-select-en_attente,
select.quick-update-statut.statut-en_attente{
  background-color: rgba(139, 92, 246, 0.18) !important;
  color: #ddd6fe !important;
  border-color: rgba(139, 92, 246, 0.55) !important;
}

STEP 7: UNIFIED TEXT COLORS ===
   Override all conflicting grays (#666, #4b5563, #6b7280, etc.) */

.text-dim,
.badge-mini,
.filter-group label,
.info-label,
.stat-label,
.intervention-desc,
.intervention-tech,
.user-role,
.color-text-dim,
.note-sub {
  color: var(--color-text-dim) !important;
}

.room-notes,
.dashboard-notes .note-sub,
.cta-info-grid .label,
.filter-item label {
  color: var(--color-text-dim) !important;
}

/* === STEP 8: UNIFIED BORDERS ===
   Consolidate border styles */

.table th,
.data-table th {
  border-bottom-color: var(--color-border) !important;
}

.table td,
.data-table td,
.intervention-item,
.releve-item,
.stat-item {
  border-bottom-color: var(--color-border) !important;
}

/* === STEP 9: UNIFIED BUTTONS ===
   Consistent button styling across all types */

.btn {
  border-radius: var(--radius-md);
  font-weight: 500;
  transition: all 0.2s ease;
}

.btn:focus {
  outline: none;
  box-shadow: var(--focus-ring);
}

.btn-primary {
  background-color: var(--color-primary);
  color: white;
  border: none;
}

.btn-primary:hover {
  background-color: #2563eb;
}

.btn-secondary {
  background-color: var(--color-bg-alt);
  color: var(--color-text);
  border: 1px solid var(--color-border);
}

.btn-secondary:hover {
  background-color: var(--color-bg-card);
}

.btn-danger {
  color: var(--color-danger);
}

.btn-sm {
  padding: 6px 12px;
  font-size: var(--fs-sm);
}

.btn-block {
  width: 100%;
  display: block;
}

/* === STEP 10: UNIFIED CARDS ===
   Consistent card styling */

.card,
.dashboard-section,
.stat-card,
.service-card,
.chambre-info-card,
.intervention-info-card {
  background-color: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  transition: all 0.2s ease;
}

.card-head,
.card-h {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-md);
  border-bottom: 1px solid var(--color-border);
}

.card-body {
  padding: var(--spacing-md);
}

/* === STEP 11: UNIFIED BADGES ===
   Consistent badge sizing and spacing */

.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 8px;
  border-radius: var(--radius-sm);
  font-size: var(--fs-xs);
  font-weight: 600;
  text-transform: uppercase;
}

.badge-mini {
  font-size: 11px;
  padding: 3px 8px;
  border-radius: var(--radius-full);
  border: 1px solid var(--color-border);
}

.pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 2px 8px;
  border-radius: var(--radius-full);
  font-size: var(--fs-xs);
  border: 1px solid var(--color-border);
}

.pill-crit {
  background-color: rgba(180, 120, 255, 0.12);
  border-color: rgba(180, 120, 255, 0.25);
}

/* === STEP 12: UNIFIED FORMS ===
   Consistent input/select styling */

.form-control,
.filters select,
.filters-compact select,
.filters-compact input,
select {
  width: 100%;
  padding: var(--spacing-sm) var(--spacing-md);
  background-color: var(--color-bg-alt);
  color: var(--color-text);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--fs-sm);
  transition: border-color 0.2s;
}

.form-control:focus,
.filters select:focus,
.filters-compact select:focus,
.filters-compact input:focus,
select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: var(--focus-ring);
}

select option {
  background: #1b1b1f;
  color: #f1f1f5;
}

/* === STEP 13: UNIFIED TABLES ===
   Consistent table styling */

.table,
.data-table,
.table-wrap table {
  width: 100%;
  border-collapse: collapse;
}

.table th,
.data-table th,
.table-wrap th {
  padding: var(--spacing-md);
  text-align: left;
  font-weight: 600;
  font-size: var(--fs-xs);
  text-transform: uppercase;
  color: var(--color-text-dim);
  background-color: var(--color-bg-alt);
}

.table td,
.data-table td,
.table-wrap td {
  padding: var(--spacing-md);
  border-bottom: 1px solid var(--color-border);
  vertical-align: middle;
}

.data-table tbody tr:hover {
  background-color: var(--color-bg-alt);
  transition: background-color 0.2s;
}

/* === STEP 14: UNIFIED MODALS ===
   Consistent modal styling */

.modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: rgba(0, 0, 0, 0.05);
  padding: var(--spacing-lg);
  overflow-y: auto;
}

.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.05);
  z-index: 999;
}

.modal-content,
.modal-card {
  display: inline-block;
  text-align: left;
  background-color: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  padding: var(--spacing-lg);
  width: min(90%, 600px);
  margin: 5% auto;
}

.modal-card {
  width: min(720px, 100%);
  padding: var(--spacing-md);
}

.modal-close {
  color: var(--color-text-dim);
  font-size: 2rem;
  font-weight: bold;
  cursor: pointer;
  float: right;
}

.modal-close:hover {
  color: var(--color-text);
}

/* === STEP 15: UNIFIED SPACING & LAYOUT ===
   Consistent margin/padding throughout */

.page-header {
  margin-bottom: var(--spacing-lg);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.page-header h1 {
  font-size: var(--fs-lg);
  color: var(--color-text);
}

.main-content {
  max-width: 1400px;
  margin: 0 auto;
  padding: var(--spacing-lg);
}

.form-group {
  margin-bottom: var(--spacing-md);
}

.form-group label {
  display: block;
  margin-bottom: 4px;
  font-weight: 500;
  font-size: var(--fs-sm);
}

/* === STEP 16: OVERRIDE CONFLICTING LIGHT MODE STYLES ===
   Some views had inline light backgrounds; ensure dark theme consistency */

.row-notes td,
.dashboard-notes .notes-list li {
  background: transparent;
  border-bottom: 1px solid var(--color-border);
}

.room-notes {
  color: var(--color-text-dim);
  font-size: var(--fs-xs);
}

.alert-item {
  color: var(--color-text);
  font-weight: 600;
}

.alert-item strong {
  color: var(--color-danger);
}

/* === STEP 17: PAGE-SPECIFIC CONSOLIDATIONS ===
   CTA page overrides */

.page-cta .stat-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--spacing-md);
}

.page-cta .stat-card h3 {
  font-size: var(--fs-sm);
  color: var(--color-text-dim);
}

.page-cta .stat-value {
  font-size: var(--fs-lg);
  font-weight: 700;
}

/* === STEP 18: ANALYTICS PAGE CONSOLIDATION ===
   Analytics uses very small sizing; ensure consistent with theme */

.kpi-compact {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
}

.kpi-value {
  color: var(--color-primary);
  font-weight: 800;
}

.chart-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
}

/* === STEP 19: NOTIFICATION ALERTS ===
   Unified alert styling for errors, success, info */

.alert {
  padding: var(--spacing-md);
  border-radius: var(--radius-md);
  margin-bottom: var(--spacing-md);
}

.alert-error,
.alert-danger {
  background-color: rgba(239, 68, 68, 0.2);
  border: 1px solid var(--color-danger);
  color: #fecaca;
  padding: 1rem;
  border-radius: var(--radius-md);
}

.alert-error h4,
.alert-danger h4 {
  color: #fca5a5;
  margin-bottom: 0.5rem;
}

.alert-success {
  background-color: rgba(16, 185, 129, 0.2);
  border: 1px solid var(--color-success);
  color: #86efac;
  padding: 1rem;
  border-radius: var(--radius-md);
}

.alert-warning {
  background-color: rgba(245, 158, 11, 0.2);
  border: 1px solid var(--color-warning);
  color: #fcd34d;
  padding: 1rem;
  border-radius: var(--radius-md);
}

.alert-warning h4 {
  color: #fde68a;
  margin-bottom: 0.5rem;
}

/* === STEP 20: DISABLED STATES ===
   Uniform disabled appearance */

.btn:disabled,
button:disabled,
input:disabled,
select:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

/* === FINAL: RESPONSIVE ADJUSTMENTS ===
   Maintain spacing/sizing at smaller screens */

@media (max-width: 768px) {
  .page-header {
    flex-direction: column;
    gap: var(--spacing-md);
  }

  .form-row {
    grid-template-columns: 1fr;
  }

  .modal-content,
  .modal-card {
    width: 95%;
  }
}

/* ============================================================
   END UNIFIED STYLE SYSTEM
   All legacy selectors remain functional
   ============================================================ */


/* =========================================================
 * Interventions UI (stabilisation)
 * - Zéro fond blanc surprise
 * - Zéro select qui étire les colonnes
 * - Statut/Priorité visibles (lecture + écriture)
 * ========================================================= */

/* Warning badge (retard) */
.badge-warning {
  background-color: #ffc107;
  color: #000;
  font-size: 0.85rem;
  padding: 2px 6px;
  border-radius: 3px;
  margin-left: 4px;
  cursor: help;
}

/* =========================================================
 * CTA Detail — Mobile cards (stabilisation)
 * - Keep a readable card layout on phones
 * - Avoid double buttons and broken forms
 * ========================================================= */
.cta-mobile-cards{display:none;}
.cta-desktop-table{display:block;}

@media (max-width: 768px){
  .cta-mobile-cards{display:block;}
  .cta-desktop-table{display:none;}
  .grid-2{grid-template-columns:1fr !important;}
  .cta-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:10px;padding:12px;margin:10px 0;}
  .cta-card h4{margin:0 0 10px 0;font-size:1.1rem;}
  .cta-card .row{display:flex;justify-content:space-between;gap:10px;padding:6px 0;border-top:1px dashed rgba(255,255,255,0.12);}
  .cta-card .row:first-child{border-top:0;}
  .cta-card .k{opacity:.75;font-size:.92rem;}
  .cta-card .v{font-weight:600;text-align:right;max-width:60%;}
  .cta-card .actions{display:flex;gap:10px;justify-content:flex-end;margin-top:10px;}
  .cta-card input,.cta-card select{width:100%;max-width:100%;}
}

/* Quick update selects (table + cards) */
select.quick-update-statut,
select.quick-update-priorite {
  width: 150px;
  max-width: 150px;
  min-width: 150px;
  cursor: pointer;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
select.quick-update-statut:disabled,
select.quick-update-priorite:disabled {
  opacity: 0.6;
  cursor: wait;
}

/* Color hint for write mode (select) */
select.quick-update-statut.statut-ouvert { border-color: rgba(231, 76, 60, .65); }
select.quick-update-statut.statut-en_cours { border-color: rgba(241, 196, 15, .70); }
select.quick-update-statut.statut-en_attente { border-color: rgba(155, 89, 182, .65); }
select.quick-update-statut.statut-cloture { border-color: rgba(46, 204, 113, .65); }

select.quick-update-priorite.prio-haute { border-color: rgba(231, 76, 60, .65); }
select.quick-update-priorite.prio-normale { border-color: rgba(241, 196, 15, .70); }
select.quick-update-priorite.prio-basse { border-color: rgba(46, 204, 113, .65); }

/* Mobile: make status/priority colors clearly visible (not just border) */
@media (max-width: 768px) {
  select.quick-update-statut.statut-ouvert { background: rgba(231, 76, 60, .16) !important; box-shadow: 0 0 0 1px rgba(231, 76, 60, .35) inset !important; }
  select.quick-update-statut.statut-en_cours { background: rgba(241, 196, 15, .16) !important; box-shadow: 0 0 0 1px rgba(241, 196, 15, .35) inset !important; }
  select.quick-update-statut.statut-en_attente { background: rgba(155, 89, 182, .16) !important; box-shadow: 0 0 0 1px rgba(155, 89, 182, .35) inset !important; }
  select.quick-update-statut.statut-cloture { background: rgba(46, 204, 113, .16) !important; box-shadow: 0 0 0 1px rgba(46, 204, 113, .35) inset !important; }

  select.quick-update-priorite.prio-haute { background: rgba(231, 76, 60, .16) !important; box-shadow: 0 0 0 1px rgba(231, 76, 60, .35) inset !important; }
  select.quick-update-priorite.prio-normale { background: rgba(241, 196, 15, .16) !important; box-shadow: 0 0 0 1px rgba(241, 196, 15, .35) inset !important; }
  select.quick-update-priorite.prio-basse { background: rgba(46, 204, 113, .16) !important; box-shadow: 0 0 0 1px rgba(46, 204, 113, .35) inset !important; }
}

/* Card view styles (moved from inline view) */
.interventions-card-view {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 1rem;
  padding: 0.5rem 0;
}

.intervention-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: 8px;
  padding: 1rem;
  transition: box-shadow 0.2s, transform 0.2s;
}

.intervention-card:hover {
  box-shadow: 0 6px 16px rgba(0,0,0,0.35);
  transform: translateY(-2px);
}

.intervention-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.75rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--color-border);
}

.intervention-card-body { margin-bottom: 1rem; }

.intervention-card-desc {
  font-size: 0.95rem;
  margin-bottom: 0.75rem;
  color: var(--color-text);
}

.intervention-card-meta {
  font-size: 0.85rem;
  color: var(--color-text-dim);
  margin-bottom: 0.75rem;
}

.intervention-card-meta div { margin-bottom: 0.25rem; }

.intervention-card-controls {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin-bottom: 0.75rem;
}

.card-control-group {
  flex: 1;
  min-width: 140px;
}

.card-control-group label {
  display: block;
  font-size: 0.8rem;
  margin-bottom: 0.25rem;
  color: var(--color-text-dim);
}

.intervention-card-footer {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}

.empty-state {
  grid-column: 1 / -1;
  text-align: center;
  padding: 2rem;
  color: var(--color-text-dim);
}

@media (max-width: 768px) {
  .interventions-card-view { grid-template-columns: 1fr; }
}


/* Force 'En attente' violet everywhere */
.badge.statut-en_attente, .badge.status-en_attente, .badge[data-status="en_attente"]{
  background: rgba(139,92,246,.18) !important;
  border: 1px solid rgba(139,92,246,.45) !important;
  color: #c4b5fd !important;
}
.status-select-en_attente, .statut-en_attente, .status-en_attente{
  background: rgba(139,92,246,.15) !important;
  border-color: rgba(139,92,246,.45) !important;
  color: #c4b5fd !important;
}

/* =========================================================
   FINAL ADJUSTMENT — MODAL ABOVE HEADER (MOBILE/TABLET)
   ========================================================= */
@media (max-width: 1024px){

  /* When modal is open, push header below */
  body.modal-open .main-header,
  body.modal-open header,
  body.modal-open .topbar{
    z-index: 9998 !important;
  }

  /* Ensuring modal stays above the header */
  .modal{
    position: fixed !important;
    inset: 0 !important;
    z-index: 99999 !important;
    padding: 12px !important;
    margin-top: calc(72px + 12px) !important; /* Adjust for mobile/tablet header */
  }

  /* Modal card size and position */
  .modal-card,
  .modal-content{
    box-sizing: border-box !important;
    transform: scale(0.85) !important;
    transform-origin: top center !important;
    margin: 8vh auto !important;
    max-width: 360px !important;
    max-height: 85vh !important;
    overflow-y: auto !important;
  }

  /* Adjust form width and margins */
  .main-content form,
  .main-content .card,
  .main-content .panel,
  .main-content .box{
    max-width: 360px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  /* Ensure modal doesn't get covered by the header */
  body.modal-open .main-content {
    margin-top: 72px !important; /* Offset for header */
  }

}
