/* =========================================================================
   GLSM — Design System « Console claire »
   Papier froid + IBM Plex Mono + signal indigo. Tokens, composants, responsive.
   Phase 1 : tokens + typo appliquée. Le fond clair s'active en Phase 2.
   ========================================================================= */

:root {
  /* — Tokens — */
  --paper:    #F4F6FA;   /* fond (papier froid bleuté) */
  --ink:      #14181F;   /* texte fort contraste */
  --grid:     #D7DCE5;   /* filets, bordures, lignes */
  --signal:   #2440FF;   /* accent unique : actif / maintenant / liens */
  --ok:       #0E9F6E;   /* couverture, succès */
  --warn:     #C2410C;   /* blocages, erreurs (rare) */

  /* — Dérivés — */
  --panel:      #FFFFFF;            /* panneaux sur le papier */
  --panel-2:    #FAFBFD;           /* zones internes */
  --ink-2:      #5A6472;           /* texte secondaire */
  --ink-3:      #8A93A2;           /* labels / tertiaire */
  --signal-2:   #1B30C9;           /* signal hover */
  --signal-soft:rgba(36,64,255,.09);
  --ok-soft:    rgba(14,159,110,.12);
  --warn-soft:  rgba(194,65,12,.12);

  /* — Typo — */
  --mono: 'IBM Plex Mono', ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  --sans: 'IBM Plex Sans', ui-sans-serif, system-ui, -apple-system, sans-serif;

  /* — Échelle — */
  --fs-xs: 11px; --fs-sm: 12px; --fs-md: 13px; --fs-lg: 15px;
  --fs-xl: 20px; --fs-2xl: 28px; --fs-3xl: 40px;
  --r: 8px; --r-sm: 5px; --r-pill: 999px;
  --sp: 16px;
  --hair: 1px solid var(--grid);
  --shadow: 0 1px 2px rgba(20,24,31,.04), 0 1px 3px rgba(20,24,31,.06);
}

/* ===== Base typographie (Phase 1 : typo seulement) ===== */
*, *::before, *::after { box-sizing: border-box; }   /* indispensable pour la page login (sans Tailwind) */
html, body { font-family: var(--sans); }
body { -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
.mono, code, kbd, pre { font-family: var(--mono); }

/* champs de saisie : clairs par défaut (filet de sécurité) */
input, select, textarea {
  font-family: var(--sans); font-size: var(--fs-md);
  background: #FFFFFF; color: var(--ink);
  border: 1px solid var(--grid); border-radius: var(--r-sm);
  padding: 8px 10px; max-width: 100%;
}
input:focus, select:focus, textarea:focus { border-color: var(--signal); outline: none; }
::placeholder { color: var(--ink-3); }

/* labels / eyebrows : mono, capitales, tracking = l'identité « banc d'ingénierie » */
.label {
  font-family: var(--mono); font-size: var(--fs-xs);
  letter-spacing: .09em; text-transform: uppercase; color: var(--ink-3);
}

/* ===== Composants (thème clair — utilisés à partir de la Phase 2) ===== */
.panel {
  background: var(--panel); border: var(--hair); border-radius: var(--r);
  padding: var(--sp); box-shadow: var(--shadow);
}
.panel-flush { padding: 0; }
.panel-title { font-family: var(--mono); font-size: var(--fs-md); font-weight: 600; color: var(--ink); }

/* relevé / stat */
.stat { display: flex; flex-direction: column; gap: 2px; }
.stat-num { font-family: var(--mono); font-size: var(--fs-2xl); font-weight: 600; color: var(--ink); line-height: 1; }
.stat-lbl { font-family: var(--mono); font-size: var(--fs-xs); letter-spacing: .06em; color: var(--ink-3); }

/* boutons */
.btn {
  font-family: var(--mono); font-size: var(--fs-sm); font-weight: 500;
  padding: 8px 14px; border-radius: var(--r-sm); border: var(--hair);
  background: var(--panel); color: var(--ink); cursor: pointer;
  min-height: 36px; transition: background .12s, border-color .12s;
}
.btn:hover { background: var(--panel-2); border-color: var(--ink-3); }
.btn-signal { background: var(--signal); color: #fff; border-color: var(--signal); }
.btn-signal:hover { background: var(--signal-2); border-color: var(--signal-2); }
.btn-ghost { background: transparent; border-color: transparent; color: var(--ink-2); }
.btn-ghost:hover { background: var(--signal-soft); color: var(--signal); }

/* badges (mono pill) */
.badge2 {
  font-family: var(--mono); font-size: var(--fs-xs); font-weight: 500;
  padding: 2px 9px; border-radius: var(--r-pill); border: var(--hair);
  color: var(--ink-2); background: var(--panel-2); display: inline-block;
}
.badge2.is-signal { color: var(--signal); border-color: var(--signal); background: var(--signal-soft); }
.badge2.is-ok     { color: var(--ok);     border-color: var(--ok);     background: var(--ok-soft); }
.badge2.is-warn   { color: var(--warn);   border-color: var(--warn);   background: var(--warn-soft); }

/* pastille d'état (worker) */
.dot { width: 9px; height: 9px; border-radius: 50%; display: inline-block; }
.dot.is-on   { background: var(--ok);   box-shadow: 0 0 0 3px var(--ok-soft); }
.dot.is-idle { background: var(--ink-3); }
.dot.is-warn { background: var(--warn); box-shadow: 0 0 0 3px var(--warn-soft); }
.dot.pulse   { animation: glsm-pulse 1.6s ease-out infinite; }
@keyframes glsm-pulse {
  0%   { box-shadow: 0 0 0 0 var(--signal-soft); }
  100% { box-shadow: 0 0 0 8px rgba(36,64,255,0); }
}

/* tables de données (mono, lignes hairline) */
.tbl { width: 100%; border-collapse: collapse; font-size: var(--fs-md); }
.tbl th { font-family: var(--mono); font-size: var(--fs-xs); letter-spacing: .06em;
          text-transform: uppercase; color: var(--ink-3); text-align: left;
          font-weight: 500; padding: 8px 10px; border-bottom: var(--hair); }
.tbl td { padding: 9px 10px; border-bottom: var(--hair); color: var(--ink); }
.tbl tr:hover td { background: var(--panel-2); }
.tbl .num { font-family: var(--mono); text-align: right; }

/* Le Flux — bande de télémétrie (signature, stylée en Phase 4) */
.tape { font-family: var(--mono); font-size: var(--fs-sm); line-height: 1.7;
        background: var(--panel-2); border: var(--hair); border-radius: var(--r);
        padding: 10px 14px; overflow: hidden; }
.tape-line { display: flex; gap: 12px; white-space: nowrap; color: var(--ink-2); }
.tape-line .t-time { color: var(--ink-3); }
.tape-line .t-ok   { color: var(--ok); }
.tape-line .t-sig  { color: var(--signal); }
.tape-line .t-warn { color: var(--warn); }

/* cellule heatmap */
.heatcell { width: 22px; height: 22px; border: none; border-radius: 3px; cursor: pointer; display: block; }

/* boutons d'action (tableau Leads) — jetons texte monospace, style « commande » */
.act {
  display: inline-flex; align-items: center; flex: 0 0 auto;
  font-family: var(--mono); font-size: 10.5px; letter-spacing: .02em;
  padding: 3px 7px; border-radius: 4px;
  border: 1px solid var(--grid); background: #fff; color: var(--ink-2);
  cursor: pointer; text-decoration: none; white-space: nowrap;
  transition: border-color .12s, color .12s, background .12s;
}
.act:hover { border-color: var(--signal); color: var(--signal); background: var(--signal-soft); }
.act-danger:hover { border-color: var(--warn); color: var(--warn); background: var(--warn-soft); }
.act-primary { border-color: var(--signal); color: var(--signal); background: var(--signal-soft); font-weight: 600; }
.act-primary:hover { background: var(--signal); color: #fff; }
.act-on { border-color: var(--ok); color: var(--ok); background: var(--ok-soft); }

/* ===== Layout & responsive (foundations — coque en Phase 2) ===== */
.container { width: 100%; max-width: 1240px; margin: 0 auto; padding: 0 20px; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.scroll-x { overflow-x: auto; -webkit-overflow-scrolling: touch; }

@media (max-width: 900px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  :root { --sp: 12px; }
  .container { padding: 0 12px; }
  .hide-mobile { display: none !important; }
  .stat-num { font-size: var(--fs-xl); }
  /* champs : 16px = pas de zoom auto iOS + lisibilité, cibles tactiles ~44px */
  input, select, textarea { font-size: 16px; padding: 11px 12px; }
  .btn { min-height: 44px; }
}

/* carte vivante : pouls indigo sur le département scrapé en ce moment */
@keyframes deptpulse { 0%, 100% { stroke-width: 1; } 50% { stroke-width: 3.5; } }
path.dept-live { stroke: var(--signal) !important; animation: deptpulse 1.2s ease-in-out infinite; }

/* ===== Plancher qualité : focus visible, motion, scrollbar ===== */
:focus-visible { outline: 2px solid var(--signal); outline-offset: 2px; }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}
