    /* ── Parc tab ───────────────────────────────────────────────────────────── */
    .parc-stat-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
      gap: 12px;
      margin-bottom: 8px;
    }
    .parc-stat-card {
      background: var(--surface-2);
      border: 1px solid var(--border);
      border-radius: 8px;
      padding: 14px 16px;
      text-align: center;
    }
    .parc-stat-val {
      font-family: var(--font-head);
      font-size: 30px;
      font-weight: 700;
      margin-bottom: 2px;
    }
    .parc-stat-label {
      font-family: var(--font-head);
      font-size: 11px;
      font-weight: 600;
      color: var(--text-dim);
      text-transform: uppercase;
      letter-spacing: 0.06em;
    }
    .parc-section-sub {
      font-family: var(--font-head);
      font-size: 12px;
      font-weight: 600;
      color: var(--text-dim);
      text-transform: uppercase;
      letter-spacing: 0.08em;
      margin-bottom: 10px;
      margin-top: 4px;
    }
    .accord-header {
      display: flex;
      align-items: center;
      gap: 12px;
      padding: 14px 20px;
      border-bottom: 1px solid var(--border);
      cursor: pointer;
      user-select: none;
    }
    .accord-header:hover { background: #1a2030; }
    .accord-arrow { margin-left: auto; color: var(--text-dim); }
    .accord-body { display: none; padding: 16px 20px; overflow-x: auto; }
    .accord-body.open { display: block; }
    .interv-table { width: 100%; border-collapse: collapse; font-size: 13px; min-width: 700px; }
    .interv-table th {
      font-family: var(--font-head); font-size: 11px; font-weight: 700;
      text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-dim);
      padding: 6px 10px; border-bottom: 1px solid var(--border); text-align: left;
    }
    .interv-table td { padding: 9px 10px; border-bottom: 1px solid #1e2530; vertical-align: top; }
    .interv-table tr:last-child td { border-bottom: none; }
    .interv-table tr:hover td { background: #1a2030; }
    .prio-urgente { color: #ff4444; font-weight: 700; }
    .prio-normale { color: var(--accent); }
    .prio-faible  { color: var(--green); }
    .badge-interv-statut {
      display: inline-block; font-family: var(--font-head); font-size: 11px;
      font-weight: 700; text-transform: uppercase; padding: 2px 8px;
      border-radius: 4px; white-space: nowrap;
    }
    .badge-aplanifier { background: #2e0d0d; color: #ff6b6b; border: 1px solid #e3001b; }
    .badge-planifiee  { background: #2e2000; color: var(--accent); border: 1px solid var(--accent); }
    .badge-encours-i  { background: #0d2035; color: #3a9bd5; border: 1px solid #3a9bd5; }
    .badge-terminee-i { background: #0e2e1a; color: #2ea84b; border: 1px solid #2ea84b; }
    .overdue-tag {
      display: inline-block; background: #2e1a00; color: #f0a500;
      border: 1px solid #f0a500; border-radius: 4px;
      font-family: var(--font-head); font-size: 11px; font-weight: 700;
      padding: 2px 8px; margin-left: 6px;
    }
    .ok-tag {
      display: inline-block; background: #0e2e1a; color: #2ea84b;
      border: 1px solid #2ea84b; border-radius: 4px;
      font-family: var(--font-head); font-size: 11px; font-weight: 700;
      padding: 2px 8px;
    }
    .serrure-urgente { color: #ff4444; }
    .empty-msg { color: var(--green); font-family: var(--font-head); font-size: 15px; padding: 8px 0; }
    .chart-toggle {
      background: var(--surface-2);
      border: 1px solid var(--border);
      color: var(--text-dim);
      font-family: var(--font-head);
      font-size: 13px;
      font-weight: 600;
      padding: 5px 12px;
      border-radius: 5px;
      cursor: pointer;
      transition: all 0.15s;
    }
    .chart-toggle:hover { border-color: var(--accent); color: var(--text); }
    .chart-toggle.active { background: var(--accent); border-color: var(--accent); color: #0d1117; }

