/* ═══════════════════════════════════════════════════════
   SEN'EAU — Wallboard Centre d'Appels
   Polices système uniquement (pas de CDN externe)
═══════════════════════════════════════════════════════ */

:root {
  --font-main  : -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
  --font-num   : "Segoe UI", "Arial Black", Arial, sans-serif;

  --vert-suez   : #96C11E;
  --bleu-suez   : #1F3B72;
  --vert-nature : #00955E;
  --bleu-turq   : #0099A8;
  --jaune-or    : #FDC22D;
  --rouge       : #D32F2F;

  --bg-page     : #F4F7FB;
  --bg-card     : #FFFFFF;
  --border      : #E0E6EF;
  --border-light: #F0F4F8;
  --txt-main    : #0D1B3E;
  --txt-sub     : #6B7A8D;
  --txt-muted   : #A0AFBE;

  --shadow-sm   : 0 1px 4px rgba(13,27,62,0.07);
  --shadow      : 0 2px 14px rgba(13,27,62,0.09);
  --shadow-lg   : 0 6px 28px rgba(13,27,62,0.13);
  --radius      : 12px;
  --radius-sm   : 8px;
  --radius-xs   : 6px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  background : var(--bg-page);
  color      : var(--txt-main);
  font-family: var(--font-main);
  font-size  : 14px;
  min-height : 100vh;
}

::-webkit-scrollbar       { width:5px; height:5px; }
::-webkit-scrollbar-thumb { background:#C8D0DC; border-radius:3px; }

/* ══════════════════════════════════════════
   HEADER
══════════════════════════════════════════ */
.sn-header {
  background    : #FFFFFF;
  border-bottom : 3px solid var(--bleu-suez);
  height        : 62px;
  display              : grid;
  grid-template-columns: 1fr auto 1fr;
  align-items          : center;
  padding              : 0 28px;
  position             : sticky;
  top                  : 0;
  z-index              : 200;
  box-shadow           : 0 1px 6px rgba(13,27,62,0.08);
  gap                  : 16px;
}

.sn-logo { display:flex; align-items:center; gap:10px; }
.sn-logo img { height:50px; width:auto; display:block; }
.sn-logo-icon {
  width:36px; height:36px; background:var(--bleu-suez);
  border-radius:8px; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-num); font-weight:900; font-size:1rem; color:#fff;
}
.sn-logo-texts { display:flex; flex-direction:column; line-height:1.2; }
.sn-logo-name  { font-family:var(--font-num); font-weight:800; font-size:1.1rem; color:var(--bleu-suez); }
.sn-logo-name em { color:var(--vert-suez); font-style:normal; }
.sn-logo-tag   { font-size:0.57rem; color:var(--txt-sub); letter-spacing:0.15em; text-transform:uppercase; font-weight:600; }
.sn-divider    { width:1px; height:26px; background:var(--border); margin:0 8px; }
.sn-module     { font-size:0.72rem; font-weight:600; color:var(--txt-sub); }

.sn-header-right { display:flex; align-items:center; gap:10px; }

.sn-live {
  display:flex; align-items:center; gap:6px;
  background:rgba(0,149,94,0.09); border:1.5px solid rgba(0,149,94,0.3);
  border-radius:20px; padding:4px 12px;
  font-size:0.65rem; font-weight:700; color:var(--vert-nature);
  text-transform:uppercase; letter-spacing:0.08em;
}
.sn-live-dot {
  width:7px; height:7px; border-radius:50%; background:var(--vert-nature);
  animation:snPulse 1.4s ease-in-out infinite;
}
@keyframes snPulse { 0%,100%{opacity:1;} 50%{opacity:.25;} }

.sn-clock { font-family:var(--font-num); font-size:1.15rem; font-weight:700; color:var(--bleu-suez); letter-spacing:0.04em; }
.sn-sql-badge { font-size:0.61rem; font-weight:700; padding:4px 11px; border-radius:20px; text-transform:uppercase; letter-spacing:0.06em; }
.sn-sql-badge.ok   { background:rgba(0,149,94,.1);  color:#005C2E; border:1px solid rgba(0,149,94,.3); }
.sn-sql-badge.demo { background:rgba(253,194,45,.1); color:#7A5200; border:1px solid rgba(253,194,45,.35); }
.sn-maj { font-size:0.61rem; color:var(--txt-muted); font-weight:500; }

/* ══════════════════════════════════════════
   SOUS-BARRE
══════════════════════════════════════════ */
.sn-datebar {
  background:var(--bleu-suez); padding:7px 28px;
  display:flex; align-items:center; justify-content:space-between;
}
.sn-datebar-left { display:flex; align-items:center; gap:8px; font-size:0.74rem; color:rgba(255,255,255,0.75); font-weight:500; }
.sn-datebar-left strong { color:#fff; font-weight:700; }
.sn-datebar-sep  { color:rgba(255,255,255,0.3); }
.sn-refresh-info { display:flex; align-items:center; gap:6px; font-size:0.63rem; color:rgba(255,255,255,0.55); }
.sn-refresh-dot  { width:5px; height:5px; border-radius:50%; background:#AADC14; animation:snPulse 1.4s ease-in-out infinite; }

/* ══════════════════════════════════════════
   CONTENU PRINCIPAL
══════════════════════════════════════════ */
.sn-main { padding:22px 28px; max-width:1800px; margin:0 auto; }

.sn-section-label {
  font-size:0.6rem; font-weight:700; color:var(--txt-muted);
  text-transform:uppercase; letter-spacing:0.18em;
  margin-bottom:12px; display:flex; align-items:center; gap:10px;
}
.sn-section-label::after { content:''; flex:1; height:1px; background:var(--border); }

/* ══════════════════════════════════════════
   RANGÉE 1 — 3 GRANDES CARTES KPI
══════════════════════════════════════════ */
.sn-kpi-row-top {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:16px; margin-bottom:14px;
}

.sn-kpi-big {
  background:var(--bg-card); border-radius:var(--radius);
  padding:26px 28px 22px; box-shadow:var(--shadow);
  border:1px solid var(--border); text-align:center;
  position:relative; overflow:hidden;
  transition:box-shadow .2s, transform .2s;
}
.sn-kpi-big:hover { box-shadow:var(--shadow-lg); transform:translateY(-2px); }
.sn-kpi-big::before {
  content:''; position:absolute; top:0; left:0; right:0; height:5px;
  background:var(--kpi-color, var(--bleu-suez));
}

.sn-kpi-big-label {
  font-size:0.65rem; font-weight:700; color:var(--txt-sub);
  text-transform:uppercase; letter-spacing:0.14em; margin-bottom:12px;
}
.sn-kpi-big-value {
  font-family:var(--font-num); font-size:4.2rem; font-weight:900;
  color:var(--kpi-color, var(--bleu-suez)); line-height:1; letter-spacing:-1px;
}
.sn-kpi-big-sub {
  font-size:0.7rem; color:var(--txt-sub); margin-top:8px; font-weight:500;
}
.sn-kpi-big-badge {
  display:inline-flex; align-items:center; gap:5px; margin-top:12px;
  font-size:0.67rem; font-weight:700; padding:4px 14px; border-radius:20px;
  background:rgba(0,149,94,0.09); color:var(--vert-nature);
  border:1px solid rgba(0,149,94,0.22);
}
.sn-kpi-big-badge.bad {
  background:rgba(211,47,47,0.08); color:var(--rouge);
  border:1px solid rgba(211,47,47,0.22);
}

/* ══════════════════════════════════════════
   RANGÉE 2 — 5 PETITES CARTES KPI
══════════════════════════════════════════ */
.sn-kpi-row-bottom {
  display:grid; grid-template-columns:repeat(5,1fr);
  gap:14px; margin-bottom:18px;
}

.sn-kpi-small {
  background:var(--bg-card); border-radius:var(--radius-sm);
  padding:18px 18px 14px 22px; box-shadow:var(--shadow-sm);
  border:1px solid var(--border); position:relative; overflow:hidden;
  transition:box-shadow .2s, transform .2s;
}
.sn-kpi-small:hover { box-shadow:var(--shadow); transform:translateY(-2px); }
.sn-kpi-small::before {
  content:''; position:absolute; top:0; left:0; bottom:0; width:5px;
  background:var(--kpi-color, var(--bleu-suez));
  border-radius:var(--radius-sm) 0 0 var(--radius-sm);
}
.sn-kpi-small-label {
  font-size:0.59rem; font-weight:700; color:var(--txt-sub);
  text-transform:uppercase; letter-spacing:0.13em; margin-bottom:8px;
}
.sn-kpi-small-value {
  font-family:var(--font-num); font-size:2.8rem; font-weight:900;
  color:var(--kpi-color, var(--bleu-suez)); line-height:1;
}
.sn-kpi-small-tag {
  font-size:0.58rem; color:var(--txt-muted); margin-top:4px; font-weight:500; display:block;
}

/* Masquer ancienne grille */
.sn-kpi-grid { display:none !important; }

/* KPI durées (masqués, remplacés par rangée 1) */
.sn-kpi-dur-grid { display:none; }

/* ══════════════════════════════════════════
   FILTRES
══════════════════════════════════════════ */
.sn-filter-bar {
  background:var(--bg-card); border-radius:var(--radius-sm);
  padding:12px 20px; display:flex; align-items:center; gap:22px;
  box-shadow:var(--shadow-sm); border:1px solid var(--border);
  margin-bottom:18px; flex-wrap:wrap;
}
.sn-filter-label {
  font-size:0.59rem; font-weight:700; color:var(--txt-muted);
  text-transform:uppercase; letter-spacing:0.12em;
  margin-bottom:3px; display:block;
}
.Select-control {
  background:#F8FAFC !important; border:1.5px solid var(--border) !important;
  border-radius:var(--radius-xs) !important; font-family:var(--font-main) !important;
  font-weight:600 !important; font-size:0.82rem !important;
}
.Select-control:hover { border-color:var(--bleu-suez) !important; }
.Select-menu-outer {
  background:#fff !important; border:1.5px solid var(--bleu-suez) !important;
  border-radius:var(--radius-xs) !important; box-shadow:var(--shadow-lg) !important;
}
.Select-option { color:var(--txt-main) !important; font-size:0.82rem; }
.Select-option:hover { background:#EFF6FF !important; }
.Select-option.is-selected { background:var(--bleu-suez) !important; color:#fff !important; }
.Select-value-label { color:var(--txt-main) !important; font-weight:600 !important; }

.rc-slider-rail  { background:var(--border); }
.rc-slider-track { background:var(--bleu-suez); }
.rc-slider-handle { border-color:var(--bleu-suez) !important; }

.sn-btn-refresh {
  margin-left:auto; background:var(--bleu-suez); color:#fff; border:none;
  border-radius:var(--radius-xs); padding:8px 18px; font-family:var(--font-main);
  font-size:0.8rem; font-weight:600; cursor:pointer; display:flex;
  align-items:center; gap:6px; transition:background .18s, transform .15s;
  white-space:nowrap;
}
.sn-btn-refresh:hover { background:#274B8A; transform:translateY(-1px); }

/* ══════════════════════════════════════════
   TABLEAUX
══════════════════════════════════════════ */
.dash-table-container .dash-spreadsheet-container .dash-spreadsheet-inner th {
  background:#F8FAFC !important; color:var(--txt-sub) !important;
  font-size:0.61rem !important; font-weight:700 !important;
  text-transform:uppercase !important; letter-spacing:0.1em !important;
  padding:9px 14px !important; border-bottom:2px solid var(--border) !important;
  font-family:var(--font-main) !important;
}
.dash-table-container .dash-spreadsheet-container .dash-spreadsheet-inner td {
  font-size:0.8rem !important; color:var(--txt-main) !important;
  padding:8px 14px !important; border-bottom:1px solid var(--border-light) !important;
  font-family:var(--font-main) !important; font-weight:500 !important;
}
.dash-table-container tr:hover td { background:#F5F9FF !important; }

/* ══════════════════════════════════════════
   FOOTER
══════════════════════════════════════════ */
.sn-footer {
  background:#fff; border-top:1px solid var(--border);
  padding:12px 28px; display:flex; align-items:center;
  justify-content:space-between; font-size:0.67rem; color:var(--txt-muted);
}
.sn-footer strong { color:var(--bleu-suez); }

/* ══════════════════════════════════════════
   ANIMATIONS
══════════════════════════════════════════ */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(8px); }
  to   { opacity:1; transform:translateY(0); }
}
.sn-kpi-big:nth-child(1) { animation:fadeUp .3s .05s both; }
.sn-kpi-big:nth-child(2) { animation:fadeUp .3s .10s both; }
.sn-kpi-big:nth-child(3) { animation:fadeUp .3s .15s both; }
.sn-kpi-small:nth-child(1) { animation:fadeUp .28s .18s both; }
.sn-kpi-small:nth-child(2) { animation:fadeUp .28s .21s both; }
.sn-kpi-small:nth-child(3) { animation:fadeUp .28s .24s both; }
.sn-kpi-small:nth-child(4) { animation:fadeUp .28s .27s both; }
.sn-kpi-small:nth-child(5) { animation:fadeUp .28s .30s both; }

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media (max-width:1200px) {
  .sn-kpi-row-bottom { grid-template-columns:repeat(3,1fr); }
}
@media (max-width:900px) {
  .sn-kpi-row-top    { grid-template-columns:1fr; }
  .sn-kpi-row-bottom { grid-template-columns:repeat(2,1fr); }
  .sn-main           { padding:16px; }
}
