/* ═══════════════════════════════════════════════════════════════════════════
   admin-telemetry-v9.css — TELEMETRIE premium mobile-first
   Reference visuelle: DataDog Mobile, Vercel Analytics, Linear Insights, PostHog.
   Branding: rouge Suisse #DC2626. Fonts: Inter / Instrument Serif / JetBrains Mono.
   Scope: namespace .tlm-* (zero conflit avec .mon-* / .tel-* / .chart-v9-*).
   Mobile-first: tap targets >=44px, inputs >=16px, 100dvh, safe-area-inset-bottom.
   ═══════════════════════════════════════════════════════════════════════════ */

/* ─── Tokens ─────────────────────────────────────────────────────────────── */
:root {
  --tlm-bg: rgba(15, 23, 42, 0.65);
  --tlm-bg-deep: rgba(10, 15, 30, 0.82);
  --tlm-bg-glass: rgba(20, 28, 45, 0.72);
  --tlm-border: rgba(255, 255, 255, 0.08);
  --tlm-border-soft: rgba(255, 255, 255, 0.05);
  --tlm-border-strong: rgba(255, 255, 255, 0.14);
  --tlm-border-hover: rgba(220, 38, 38, 0.22);
  --tlm-border-active: rgba(220, 38, 38, 0.55);
  --tlm-text: #f1f5f9;
  --tlm-text2: rgba(241, 245, 249, 0.72);
  --tlm-text3: rgba(241, 245, 249, 0.48);
  --tlm-accent: #DC2626;
  --tlm-accent-2: #EF4444;
  --tlm-accent-soft: rgba(220, 38, 38, 0.14);
  --tlm-accent-glow: rgba(220, 38, 38, 0.42);
  --tlm-success: #10B981;
  --tlm-success-soft: rgba(16, 185, 129, 0.14);
  --tlm-warn: #F59E0B;
  --tlm-warn-soft: rgba(245, 158, 11, 0.14);
  --tlm-danger: #EF4444;
  --tlm-danger-soft: rgba(239, 68, 68, 0.14);
  --tlm-info: #3B82F6;
  --tlm-info-soft: rgba(59, 130, 246, 0.14);
  --tlm-purple: #8B5CF6;
  --tlm-purple-soft: rgba(139, 92, 246, 0.14);
  --tlm-grid: rgba(255, 255, 255, 0.06);
  --tlm-grid-strong: rgba(255, 255, 255, 0.12);
  --tlm-mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
  --tlm-serif: 'Instrument Serif', 'Times New Roman', serif;
  --tlm-sans: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  --tlm-radius: 14px;
  --tlm-radius-sm: 10px;
  --tlm-radius-pill: 9999px;
  --tlm-shadow: 0 8px 32px rgba(0, 0, 0, 0.32);
  --tlm-shadow-glow: 0 0 0 1px var(--tlm-border-active), 0 8px 28px rgba(220, 38, 38, 0.18);
  --tlm-blur: 20px;
}

[data-theme="light"] {
  --tlm-bg: rgba(255, 255, 255, 0.86);
  --tlm-bg-deep: rgba(248, 250, 252, 0.95);
  --tlm-bg-glass: rgba(255, 255, 255, 0.78);
  --tlm-border: rgba(15, 23, 42, 0.08);
  --tlm-border-soft: rgba(15, 23, 42, 0.05);
  --tlm-border-strong: rgba(15, 23, 42, 0.14);
  --tlm-text: #0f172a;
  --tlm-text2: rgba(15, 23, 42, 0.68);
  --tlm-text3: rgba(15, 23, 42, 0.48);
  --tlm-grid: rgba(15, 23, 42, 0.06);
  --tlm-grid-strong: rgba(15, 23, 42, 0.12);
  --tlm-shadow: 0 6px 22px rgba(15, 23, 42, 0.08);
}

/* ─── Root container ─────────────────────────────────────────────────────── */
.tlm-root {
  font-family: var(--tlm-sans);
  color: var(--tlm-text);
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding-bottom: max(24px, env(safe-area-inset-bottom));
  overscroll-behavior: contain;
  animation: tlmFadeIn .42s cubic-bezier(.22,.85,.28,1) both;
}

@keyframes tlmFadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ─── Sticky topbar ──────────────────────────────────────────────────────── */
.tlm-topbar {
  position: sticky;
  top: 0;
  z-index: 30;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: linear-gradient(180deg, rgba(10,15,30,0.92), rgba(10,15,30,0.74));
  backdrop-filter: blur(var(--tlm-blur)) saturate(160%);
  -webkit-backdrop-filter: blur(var(--tlm-blur)) saturate(160%);
  border-bottom: 1px solid var(--tlm-border);
  border-radius: var(--tlm-radius);
  box-shadow: var(--tlm-shadow);
}
[data-theme="light"] .tlm-topbar {
  background: linear-gradient(180deg, rgba(255,255,255,0.95), rgba(248,250,252,0.82));
}
.tlm-topbar-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  font-size: 0.96rem;
  letter-spacing: -0.01em;
}
.tlm-topbar-title i { color: var(--tlm-accent); }
.tlm-topbar-spacer { flex: 1; }

.tlm-icon-btn {
  width: 44px;
  height: 44px;
  min-width: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--tlm-radius-sm);
  border: 1px solid var(--tlm-border);
  background: var(--tlm-bg);
  color: var(--tlm-text);
  cursor: pointer;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
  font-size: 0.95rem;
  -webkit-tap-highlight-color: transparent;
}
.tlm-icon-btn:hover {
  border-color: var(--tlm-border-hover);
  transform: translateY(-1px);
  background: var(--tlm-accent-soft);
}
.tlm-icon-btn:active { transform: scale(0.96); }
.tlm-icon-btn.tlm-loading i { animation: tlmSpin 0.9s linear infinite; }
@keyframes tlmSpin { to { transform: rotate(360deg); } }

/* ─── Range picker (segmented) ───────────────────────────────────────────── */
.tlm-range {
  display: inline-flex;
  background: var(--tlm-bg-deep);
  border: 1px solid var(--tlm-border);
  border-radius: var(--tlm-radius-pill);
  padding: 3px;
  gap: 2px;
  overflow: hidden;
}
.tlm-range-btn {
  border: 0;
  background: transparent;
  color: var(--tlm-text2);
  font-family: var(--tlm-mono);
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  padding: 8px 12px;
  min-height: 36px;
  border-radius: var(--tlm-radius-pill);
  cursor: pointer;
  transition: background .18s ease, color .18s ease;
  white-space: nowrap;
  -webkit-tap-highlight-color: transparent;
}
.tlm-range-btn:hover { color: var(--tlm-text); }
.tlm-range-btn.is-active {
  background: linear-gradient(135deg, var(--tlm-accent), var(--tlm-accent-2));
  color: #fff;
  box-shadow: 0 4px 12px rgba(220, 38, 38, 0.34);
}

/* ─── KPI grid ───────────────────────────────────────────────────────────── */
.tlm-kpi-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
@media (min-width: 480px) {
  .tlm-kpi-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
}
@media (min-width: 768px) {
  .tlm-kpi-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; }
}

.tlm-kpi {
  position: relative;
  background: var(--tlm-bg);
  backdrop-filter: blur(var(--tlm-blur)) saturate(160%);
  -webkit-backdrop-filter: blur(var(--tlm-blur)) saturate(160%);
  border: 1px solid var(--tlm-border);
  border-radius: var(--tlm-radius);
  padding: 14px 14px 16px;
  overflow: hidden;
  isolation: isolate;
  transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease;
  cursor: default;
}
.tlm-kpi::before {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(120% 120% at 100% 0%, var(--tlm-accent-soft), transparent 55%);
  opacity: 0.55;
  pointer-events: none;
  z-index: -1;
}
.tlm-kpi:hover {
  transform: translateY(-2px);
  border-color: var(--tlm-border-hover);
  box-shadow: var(--tlm-shadow-glow);
}
.tlm-kpi-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--tlm-mono);
  font-size: 0.66rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--tlm-text3);
  font-weight: 600;
  margin-bottom: 6px;
}
.tlm-kpi-label i { color: var(--tlm-accent); font-size: 0.78rem; }
.tlm-kpi-value {
  font-family: var(--tlm-serif);
  font-size: 2.1rem;
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: -0.02em;
  background: linear-gradient(135deg, #ffffff 0%, #f1f5f9 50%, #fca5a5 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: 4px;
  font-variant-numeric: tabular-nums;
}
[data-theme="light"] .tlm-kpi-value {
  background: linear-gradient(135deg, #0f172a 0%, #1e293b 50%, #DC2626 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media (min-width: 480px) { .tlm-kpi-value { font-size: 2.3rem; } }
@media (min-width: 768px) { .tlm-kpi-value { font-size: 2.5rem; } }

.tlm-kpi-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  font-size: 0.74rem;
  color: var(--tlm-text2);
}
.tlm-kpi-sub {
  font-family: var(--tlm-mono);
  font-size: 0.7rem;
  color: var(--tlm-text3);
  letter-spacing: 0.02em;
}
.tlm-delta {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-family: var(--tlm-mono);
  font-size: 0.68rem;
  font-weight: 600;
  padding: 3px 7px;
  border-radius: var(--tlm-radius-pill);
  letter-spacing: 0.02em;
}
.tlm-delta.up   { color: var(--tlm-success); background: var(--tlm-success-soft); }
.tlm-delta.down { color: var(--tlm-danger);  background: var(--tlm-danger-soft); }
.tlm-delta.flat { color: var(--tlm-text3);   background: var(--tlm-grid); }

/* ─── Cards ──────────────────────────────────────────────────────────────── */
.tlm-card {
  background: var(--tlm-bg);
  backdrop-filter: blur(var(--tlm-blur)) saturate(160%);
  -webkit-backdrop-filter: blur(var(--tlm-blur)) saturate(160%);
  border: 1px solid var(--tlm-border);
  border-radius: var(--tlm-radius);
  padding: 14px;
  transition: border-color .22s ease, transform .22s ease;
}
.tlm-card:hover { border-color: var(--tlm-border-hover); transform: translateY(-1px); }

.tlm-card-head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.tlm-card-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.96rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--tlm-text);
  margin: 0;
}
.tlm-card-title i { color: var(--tlm-accent); }
.tlm-card-sub {
  font-family: var(--tlm-mono);
  font-size: 0.68rem;
  color: var(--tlm-text3);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-left: auto;
}
.tlm-card-actions {
  display: inline-flex;
  gap: 6px;
  margin-left: auto;
}

/* ─── Section grid responsive ────────────────────────────────────────────── */
.tlm-grid-2 {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
@media (min-width: 768px) { .tlm-grid-2 { grid-template-columns: 1fr 1fr; gap: 14px; } }

/* ─── Top commands list ─────────────────────────────────────────────────── */
.tlm-cmd-list { display: flex; flex-direction: column; gap: 6px; }
.tlm-cmd-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 9px 10px;
  border-radius: var(--tlm-radius-sm);
  background: var(--tlm-bg-deep);
  border: 1px solid var(--tlm-border-soft);
  cursor: pointer;
  min-height: 44px;
  transition: border-color .18s ease, background .18s ease, transform .18s ease;
  -webkit-tap-highlight-color: transparent;
}
.tlm-cmd-row:hover, .tlm-cmd-row:focus-visible {
  border-color: var(--tlm-border-hover);
  background: var(--tlm-accent-soft);
  transform: translateX(2px);
}
.tlm-cmd-row:focus-visible { outline: 2px solid var(--tlm-accent); outline-offset: 2px; }
.tlm-cmd-row:active { transform: scale(0.985); }
.tlm-cmd-name {
  font-family: var(--tlm-mono);
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--tlm-text);
  letter-spacing: 0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.tlm-cmd-bar-wrap {
  position: relative;
  height: 6px;
  background: var(--tlm-grid);
  border-radius: 3px;
  margin-top: 6px;
  overflow: hidden;
  grid-column: 1 / -1;
}
.tlm-cmd-bar {
  position: absolute;
  inset: 0 auto 0 0;
  background: linear-gradient(90deg, var(--tlm-accent), var(--tlm-accent-2));
  border-radius: 3px;
  width: 0;
  transition: width .8s cubic-bezier(.22,.85,.28,1);
}
.tlm-cmd-row:hover .tlm-cmd-bar {
  background: linear-gradient(90deg, var(--tlm-accent-2), #FCA5A5);
}
.tlm-cmd-meta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.tlm-cmd-count {
  font-family: var(--tlm-mono);
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--tlm-text);
  font-variant-numeric: tabular-nums;
}

/* ─── SVG charts ─────────────────────────────────────────────────────────── */
.tlm-chart-wrap {
  position: relative;
  width: 100%;
  margin-top: 4px;
}
.tlm-chart-svg {
  display: block;
  width: 100%;
  height: auto;
  overflow: visible;
}
.tlm-chart-grid line { stroke: var(--tlm-grid); stroke-width: 1; }
.tlm-chart-axis-label {
  fill: var(--tlm-text3);
  font-family: var(--tlm-mono);
  font-size: 9px;
  letter-spacing: 0.02em;
}
.tlm-chart-line {
  fill: none;
  stroke: url(#tlmAccentLine);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  filter: drop-shadow(0 0 4px rgba(220,38,38,0.32));
}
.tlm-chart-area { fill: url(#tlmAccentArea); opacity: 0.55; }
.tlm-chart-line-success { stroke: var(--tlm-success); }
.tlm-chart-area-success { fill: var(--tlm-success); opacity: 0.18; }
.tlm-chart-line-anim {
  stroke-dasharray: var(--tlm-path-len, 1000);
  stroke-dashoffset: var(--tlm-path-len, 1000);
  animation: tlmDraw 1.4s cubic-bezier(.22,.85,.28,1) .12s forwards;
}
@keyframes tlmDraw { to { stroke-dashoffset: 0; } }
.tlm-chart-dot {
  fill: var(--tlm-accent);
  stroke: var(--tlm-bg-deep);
  stroke-width: 2;
  cursor: pointer;
  transition: r .15s ease;
}
.tlm-chart-dot:hover, .tlm-chart-dot:focus { r: 6; }

.tlm-chart-bar {
  fill: url(#tlmAccentBar);
  rx: 3;
  ry: 3;
  transition: fill .18s ease, opacity .18s ease;
  cursor: pointer;
}
.tlm-chart-bar:hover { fill: url(#tlmAccentBarHover); }

/* ─── Donut ──────────────────────────────────────────────────────────────── */
.tlm-donut-wrap {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 14px;
  align-items: center;
}
@media (max-width: 480px) {
  .tlm-donut-wrap { grid-template-columns: 110px 1fr; gap: 10px; }
}
.tlm-donut-svg { width: 100%; max-width: 140px; height: auto; }
.tlm-donut-center {
  font-family: var(--tlm-serif);
  font-size: 22px;
  fill: var(--tlm-text);
  font-weight: 400;
}
.tlm-donut-center-sub {
  font-family: var(--tlm-mono);
  font-size: 8px;
  fill: var(--tlm-text3);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.tlm-donut-seg {
  transition: transform .22s ease, opacity .22s ease;
  transform-origin: center;
  cursor: pointer;
}
.tlm-donut-seg:hover { transform: scale(1.04); opacity: 0.9; }
.tlm-donut-seg.is-dim { opacity: 0.25; }

.tlm-legend { display: flex; flex-direction: column; gap: 5px; }
.tlm-legend-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
  border-radius: 8px;
  cursor: pointer;
  min-height: 36px;
  transition: background .15s ease;
  -webkit-tap-highlight-color: transparent;
}
.tlm-legend-item:hover { background: var(--tlm-grid); }
.tlm-legend-dot {
  width: 10px; height: 10px;
  border-radius: 3px;
  flex-shrink: 0;
}
.tlm-legend-label {
  flex: 1;
  font-family: var(--tlm-mono);
  font-size: 0.74rem;
  color: var(--tlm-text);
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.tlm-legend-value {
  font-family: var(--tlm-mono);
  font-size: 0.72rem;
  color: var(--tlm-text2);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}

/* ─── Horizontal bars (AutoCAD versions) ─────────────────────────────────── */
.tlm-hbar { display: flex; flex-direction: column; gap: 8px; }
.tlm-hbar-row {
  display: grid;
  grid-template-columns: minmax(80px, 130px) 1fr auto;
  align-items: center;
  gap: 10px;
  min-height: 36px;
}
.tlm-hbar-label {
  font-family: var(--tlm-mono);
  font-size: 0.74rem;
  color: var(--tlm-text);
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.tlm-hbar-track {
  position: relative;
  height: 22px;
  background: var(--tlm-grid);
  border-radius: 6px;
  overflow: hidden;
}
.tlm-hbar-fill {
  position: absolute;
  inset: 0 auto 0 0;
  background: linear-gradient(90deg, var(--tlm-accent), var(--tlm-accent-2));
  border-radius: 6px;
  width: 0;
  transition: width .8s cubic-bezier(.22,.85,.28,1);
}
.tlm-hbar-count {
  font-family: var(--tlm-mono);
  font-size: 0.74rem;
  font-weight: 700;
  color: var(--tlm-text);
  font-variant-numeric: tabular-nums;
}

/* ─── Online users (AutoCAD + web) ───────────────────────────────────────── */
.tlm-online-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
@media (min-width: 600px) { .tlm-online-grid { grid-template-columns: 1fr 1fr; gap: 12px; } }

.tlm-online-block {
  background: var(--tlm-bg-deep);
  border: 1px solid var(--tlm-border-soft);
  border-radius: var(--tlm-radius-sm);
  padding: 10px;
}
.tlm-online-head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--tlm-border-soft);
  font-size: 0.78rem;
  color: var(--tlm-text2);
  font-weight: 600;
}
.tlm-online-head i { color: var(--tlm-accent); }

.tlm-user-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px;
  margin-bottom: 4px;
  background: var(--tlm-bg);
  border: 1px solid var(--tlm-border-soft);
  border-radius: 8px;
  min-height: 44px;
  transition: border-color .18s ease;
}
.tlm-user-row:hover { border-color: var(--tlm-border-hover); }
.tlm-user-pulse {
  position: relative;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--tlm-success);
  flex-shrink: 0;
}
.tlm-user-pulse::after {
  content: "";
  position: absolute; inset: -3px;
  border-radius: 50%;
  background: var(--tlm-success);
  opacity: 0.4;
  animation: tlmPulse 1.8s ease-out infinite;
}
@keyframes tlmPulse {
  0%   { transform: scale(0.5); opacity: 0.5; }
  100% { transform: scale(2); opacity: 0; }
}
.tlm-user-pulse.web { background: var(--tlm-info); }
.tlm-user-pulse.web::after { background: var(--tlm-info); }
.tlm-user-info { flex: 1; min-width: 0; }
.tlm-user-name {
  font-weight: 600;
  font-size: 0.84rem;
  color: var(--tlm-text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.tlm-user-meta {
  font-family: var(--tlm-mono);
  font-size: 0.7rem;
  color: var(--tlm-text2);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.tlm-user-ago {
  font-family: var(--tlm-mono);
  font-size: 0.68rem;
  color: var(--tlm-text3);
  flex-shrink: 0;
  letter-spacing: 0.02em;
}

/* ─── User activity table → cards on mobile ──────────────────────────────── */
.tlm-user-activity { display: flex; flex-direction: column; gap: 8px; }
.tlm-ua-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  padding: 12px;
  background: var(--tlm-bg-deep);
  border: 1px solid var(--tlm-border-soft);
  border-radius: var(--tlm-radius-sm);
  transition: border-color .18s ease, transform .18s ease;
}
.tlm-ua-row:hover { border-color: var(--tlm-border-hover); transform: translateY(-1px); }
@media (min-width: 768px) {
  .tlm-ua-row {
    grid-template-columns: minmax(180px, 1fr) minmax(120px, 0.6fr) auto minmax(180px, 1fr);
    align-items: center;
  }
}
.tlm-ua-user { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.tlm-ua-name {
  font-weight: 600;
  font-size: 0.88rem;
  color: var(--tlm-text);
  letter-spacing: -0.01em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.tlm-ua-email {
  font-family: var(--tlm-mono);
  font-size: 0.7rem;
  color: var(--tlm-text3);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.tlm-ua-machine {
  font-family: var(--tlm-mono);
  font-size: 0.74rem;
  color: var(--tlm-text2);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.tlm-ua-count {
  font-family: var(--tlm-serif);
  font-size: 1.4rem;
  font-weight: 400;
  color: var(--tlm-accent);
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
}
.tlm-ua-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.tlm-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: var(--tlm-mono);
  font-size: 0.68rem;
  background: var(--tlm-grid);
  color: var(--tlm-text2);
  padding: 3px 7px;
  border-radius: var(--tlm-radius-pill);
  border: 1px solid var(--tlm-border-soft);
  letter-spacing: 0.02em;
}
.tlm-tag strong { color: var(--tlm-accent); font-weight: 700; }

/* ─── Errors list ────────────────────────────────────────────────────────── */
.tlm-err-list { display: flex; flex-direction: column; gap: 8px; }
.tlm-err-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  padding: 12px;
  background: var(--tlm-bg-deep);
  border: 1px solid var(--tlm-border-soft);
  border-left: 3px solid var(--tlm-danger);
  border-radius: var(--tlm-radius-sm);
  cursor: pointer;
  align-items: center;
  min-height: 44px;
  transition: border-color .18s ease, transform .18s ease, background .18s ease;
}
.tlm-err-row:hover { border-color: var(--tlm-border-hover); background: var(--tlm-danger-soft); transform: translateX(2px); }
.tlm-err-msg {
  font-family: var(--tlm-mono);
  font-size: 0.78rem;
  color: var(--tlm-text);
  word-break: break-word;
  overflow-wrap: anywhere;
  line-height: 1.4;
}
.tlm-err-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: var(--tlm-danger-soft);
  color: var(--tlm-danger);
  font-family: var(--tlm-mono);
  font-size: 0.74rem;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: var(--tlm-radius-pill);
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

/* ─── Search input ───────────────────────────────────────────────────────── */
.tlm-search {
  position: relative;
  flex: 1;
  min-width: 0;
}
.tlm-search input {
  width: 100%;
  font-family: var(--tlm-sans);
  font-size: 16px;
  padding: 10px 12px 10px 36px;
  background: var(--tlm-bg-deep);
  border: 1px solid var(--tlm-border);
  border-radius: var(--tlm-radius-sm);
  color: var(--tlm-text);
  min-height: 44px;
  transition: border-color .2s ease, background .2s ease;
  -webkit-appearance: none;
  appearance: none;
}
.tlm-search input::placeholder { color: var(--tlm-text3); }
.tlm-search input:focus {
  outline: none;
  border-color: var(--tlm-accent);
  background: var(--tlm-bg);
  box-shadow: 0 0 0 3px var(--tlm-accent-soft);
}
.tlm-search-icon {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--tlm-text3);
  font-size: 0.86rem;
  pointer-events: none;
}

/* ─── Bottom-sheet filters mobile ────────────────────────────────────────── */
.tlm-sheet-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.62);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 998;
  opacity: 0;
  pointer-events: none;
  transition: opacity .26s ease;
}
.tlm-sheet-overlay.is-open {
  opacity: 1;
  pointer-events: auto;
}
.tlm-sheet {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 999;
  background: var(--tlm-bg-glass);
  backdrop-filter: blur(28px) saturate(180%);
  -webkit-backdrop-filter: blur(28px) saturate(180%);
  border-top: 1px solid var(--tlm-border-strong);
  border-radius: 22px 22px 0 0;
  padding: 16px 16px max(20px, env(safe-area-inset-bottom));
  transform: translateY(100%);
  transition: transform .32s cubic-bezier(.22,.85,.28,1);
  max-height: 85vh;
  max-height: 85dvh;
  overflow-y: auto;
  box-shadow: 0 -16px 60px rgba(0, 0, 0, 0.5);
}
.tlm-sheet.is-open { transform: translateY(0); }
.tlm-sheet-handle {
  width: 40px;
  height: 4px;
  background: var(--tlm-border-strong);
  border-radius: 2px;
  margin: 0 auto 14px;
}
.tlm-sheet-title {
  font-size: 1rem;
  font-weight: 700;
  margin: 0 0 16px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.tlm-sheet-title i { color: var(--tlm-accent); }
.tlm-sheet-section {
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--tlm-border-soft);
}
.tlm-sheet-section:last-of-type { border-bottom: 0; }
.tlm-sheet-label {
  font-family: var(--tlm-mono);
  font-size: 0.7rem;
  color: var(--tlm-text2);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 8px;
  font-weight: 600;
}
.tlm-sheet-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.tlm-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: var(--tlm-bg-deep);
  border: 1px solid var(--tlm-border);
  color: var(--tlm-text);
  padding: 8px 12px;
  border-radius: var(--tlm-radius-pill);
  font-family: var(--tlm-mono);
  font-size: 0.74rem;
  font-weight: 600;
  cursor: pointer;
  min-height: 36px;
  transition: border-color .18s ease, background .18s ease, color .18s ease;
  -webkit-tap-highlight-color: transparent;
}
.tlm-pill:hover { border-color: var(--tlm-border-hover); background: var(--tlm-accent-soft); }
.tlm-pill.is-active {
  background: linear-gradient(135deg, var(--tlm-accent), var(--tlm-accent-2));
  border-color: transparent;
  color: #fff;
  box-shadow: 0 4px 12px rgba(220, 38, 38, 0.32);
}

/* ─── Drawer detail (right slide) ────────────────────────────────────────── */
.tlm-drawer {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: min(420px, 92vw);
  z-index: 999;
  background: var(--tlm-bg-glass);
  backdrop-filter: blur(28px) saturate(180%);
  -webkit-backdrop-filter: blur(28px) saturate(180%);
  border-left: 1px solid var(--tlm-border-strong);
  transform: translateX(100%);
  transition: transform .32s cubic-bezier(.22,.85,.28,1);
  overflow-y: auto;
  padding: 16px 16px max(20px, env(safe-area-inset-bottom));
  box-shadow: -16px 0 60px rgba(0, 0, 0, 0.42);
}
.tlm-drawer.is-open { transform: translateX(0); }
@media (max-width: 600px) {
  .tlm-drawer {
    width: 100%;
    border-left: 0;
    border-radius: 22px 22px 0 0;
    top: auto;
    height: 88vh;
    height: 88dvh;
    transform: translateY(100%);
  }
  .tlm-drawer.is-open { transform: translateY(0); }
}
.tlm-drawer-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-bottom: 14px;
  margin-bottom: 14px;
  border-bottom: 1px solid var(--tlm-border-soft);
}
.tlm-drawer-title {
  font-size: 1.05rem;
  font-weight: 700;
  margin: 0;
  flex: 1;
  letter-spacing: -0.01em;
  word-break: break-word;
}

/* ─── Tooltip ────────────────────────────────────────────────────────────── */
.tlm-tooltip {
  position: fixed;
  z-index: 1000;
  background: var(--tlm-bg-glass);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border: 1px solid var(--tlm-border-strong);
  border-radius: 10px;
  padding: 8px 10px;
  font-family: var(--tlm-mono);
  font-size: 0.74rem;
  color: var(--tlm-text);
  pointer-events: none;
  max-width: 240px;
  opacity: 0;
  transform: translateY(-4px);
  transition: opacity .16s ease, transform .16s ease;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.32);
}
.tlm-tooltip.is-visible { opacity: 1; transform: translateY(0); }
.tlm-tooltip-label { color: var(--tlm-text2); font-size: 0.68rem; margin-bottom: 2px; }
.tlm-tooltip-value { color: var(--tlm-accent); font-weight: 700; font-size: 0.86rem; }

/* ─── Skeleton ───────────────────────────────────────────────────────────── */
.tlm-skel {
  background: linear-gradient(90deg, var(--tlm-grid) 0%, var(--tlm-grid-strong) 50%, var(--tlm-grid) 100%);
  background-size: 200% 100%;
  animation: tlmShimmer 1.4s linear infinite;
  border-radius: 6px;
}
@keyframes tlmShimmer {
  from { background-position: 200% 0; }
  to   { background-position: -200% 0; }
}
.tlm-skel-card {
  background: var(--tlm-bg);
  border: 1px solid var(--tlm-border);
  border-radius: var(--tlm-radius);
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-height: 110px;
}

/* ─── Empty state ────────────────────────────────────────────────────────── */
.tlm-empty {
  text-align: center;
  padding: 28px 14px;
  color: var(--tlm-text3);
}
.tlm-empty-icon {
  font-size: 2.4rem;
  margin-bottom: 10px;
  color: var(--tlm-text3);
  opacity: 0.5;
}
.tlm-empty-title {
  font-size: 0.96rem;
  font-weight: 600;
  color: var(--tlm-text2);
  margin-bottom: 4px;
}
.tlm-empty-sub {
  font-family: var(--tlm-mono);
  font-size: 0.74rem;
  color: var(--tlm-text3);
}

/* ─── Reduced motion ─────────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .tlm-root, .tlm-kpi, .tlm-card, .tlm-cmd-row, .tlm-ua-row,
  .tlm-err-row, .tlm-user-row, .tlm-icon-btn, .tlm-pill,
  .tlm-cmd-bar, .tlm-hbar-fill, .tlm-chart-line-anim,
  .tlm-sheet, .tlm-drawer, .tlm-sheet-overlay, .tlm-tooltip,
  .tlm-user-pulse::after, .tlm-skel, .tlm-icon-btn.tlm-loading i {
    animation: none !important;
    transition: none !important;
  }
  .tlm-cmd-bar, .tlm-hbar-fill, .tlm-chart-line-anim {
    width: var(--tlm-final-width, 100%) !important;
    stroke-dashoffset: 0 !important;
  }
}

/* ─── Mobile/Tablet adjustments ──────────────────────────────────────────── */
@media (max-width: 480px) {
  .tlm-card { padding: 12px; }
  .tlm-kpi  { padding: 12px 12px 14px; }
  .tlm-card-title { font-size: 0.92rem; }
  .tlm-topbar { padding: 8px 10px; gap: 6px; border-radius: 12px; }
  .tlm-topbar-title { font-size: 0.86rem; }
  .tlm-range-btn { padding: 7px 9px; font-size: 0.7rem; }
  .tlm-cmd-row { padding: 8px 10px; }
  .tlm-online-grid { gap: 8px; }
}

/* ─── No-iOS-zoom on inputs ──────────────────────────────────────────────── */
@media (max-width: 767px) {
  .tlm-search input, .tlm-pill, .tlm-range-btn { font-size: max(13px, 0.78rem); }
  .tlm-search input { font-size: 16px; } /* exception: search keeps 16px */
}

/* ─── Light theme overrides ──────────────────────────────────────────────── */
[data-theme="light"] .tlm-topbar {
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.06);
}
[data-theme="light"] .tlm-cmd-bar,
[data-theme="light"] .tlm-hbar-fill {
  background: linear-gradient(90deg, #DC2626, #F87171);
}

/* ─── Pull-to-refresh hint (visual only) ─────────────────────────────────── */
.tlm-ptr {
  height: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--tlm-accent);
  font-family: var(--tlm-mono);
  font-size: 0.74rem;
  letter-spacing: 0.04em;
  overflow: hidden;
  transition: height .22s ease;
}
.tlm-ptr.is-active { height: 32px; }
.tlm-ptr i { animation: tlmSpin .9s linear infinite; margin-right: 6px; }


/* light-theme override block (auto-generated) */
[data-theme="light"] {
    --tlm-bg: rgba(255, 254, 248, 0.85);
    --tlm-bg-deep: rgba(255, 254, 248, 0.95);
    --tlm-bg-glass: rgba(255, 254, 248, 0.78);
    --tlm-border: rgba(20, 18, 12, 0.10);
    --tlm-border-soft: rgba(20, 18, 12, 0.06);
    --tlm-border-strong: rgba(20, 18, 12, 0.18);
    --tlm-border-hover: rgba(220, 38, 38, 0.30);
    --tlm-border-active: rgba(220, 38, 38, 0.55);
    --tlm-text: #1A1A1F;
    --tlm-text2: rgba(26, 26, 31, 0.72);
    --tlm-text3: rgba(26, 26, 31, 0.48);
    --tlm-accent-soft: rgba(220, 38, 38, 0.12);
    --tlm-accent-glow: rgba(220, 38, 38, 0.32);
    --tlm-success-soft: rgba(16, 185, 129, 0.12);
    --tlm-warn-soft: rgba(245, 158, 11, 0.12);
    --tlm-danger-soft: rgba(239, 68, 68, 0.12);
    --tlm-info-soft: rgba(59, 130, 246, 0.12);
    --tlm-purple-soft: rgba(139, 92, 246, 0.12);
    --tlm-grid: rgba(20, 18, 12, 0.08);
    --tlm-grid-strong: rgba(20, 18, 12, 0.16);
    --tlm-shadow: 0 8px 32px rgba(120, 80, 40, 0.18);
    --tlm-shadow-glow: 0 0 0 1px var(--tlm-border-active), 0 8px 28px rgba(220, 38, 38, 0.18);
}


/* ═════════════════════════════════════════════════════════════════════════
   light-theme hardcoded overrides
   tlm-kpi-value (L235) et tlm-topbar (L1027) déjà gérés via [data-theme="light"]
   inline plus haut dans le fichier → SKIP.
   ═════════════════════════════════════════════════════════════════════════ */

[data-theme="light"] .tlm-topbar {
    background: linear-gradient(180deg, rgba(255, 254, 248, 0.92), rgba(255, 254, 248, 0.74));
}

[data-theme="light"] .tlm-sheet-overlay {
    background: rgba(20, 18, 12, 0.45);
}

[data-theme="light"] .tlm-sheet {
    box-shadow: 0 -16px 60px rgba(120, 80, 40, 0.28);
}

[data-theme="light"] .tlm-drawer {
    box-shadow: -16px 0 60px rgba(120, 80, 40, 0.24);
}

[data-theme="light"] .tlm-tooltip {
    box-shadow: 0 8px 24px rgba(120, 80, 40, 0.22);
}

/* ═══════════════════════════════════════════════════════════════════════════
   scroll-x guard 2026-05-03
   Cause root: 8 white-space:nowrap (lignes 159/353/501/527/620/626/661/667/673/739),
   plusieurs avec overflow:hidden+ellipsis OK. .tlm-donut-wrap a
   grid-template-columns: 140px 1fr (ligne 448) puis 110px 1fr ≤768 (ligne 453).
   140px label peut être limite à 360px. On rend safe.
   ═══════════════════════════════════════════════════════════════════════════ */
.tlm-wrap,
.tlm-shell,
.tlm-pagehead,
.tlm-kpi-grid,
.tlm-kpi-card,
.tlm-card,
.tlm-card-body,
.tlm-grid-2,
.tlm-table-wrap,
.tlm-donut-wrap,
.tlm-donut-legend,
.tlm-donut-row {
    max-width: 100%;
    min-width: 0;
}
.tlm-card { overflow: hidden; }
.tlm-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    max-width: 100%;
}

/* KPI values potentiellement longues (versions, counts) */
.tlm-kpi-value,
.tlm-kpi-label { max-width: 100%; word-break: break-word; }

/* Donut legend : sur très petit, label-cell shrink */
@media (max-width: 420px) {
    .tlm-donut-wrap { grid-template-columns: 90px 1fr !important; }
    .tlm-donut-svg { width: 90px !important; height: 90px !important; }
}

/* SVG donut responsive */
.tlm-donut-svg { max-width: 100%; height: auto; }

/* Cells with nowrap + ellipsis : assurer max-width parent */
.tlm-table td,
.tlm-table th { max-width: 240px; }
@media (max-width: 768px) {
    .tlm-table td,
    .tlm-table th { max-width: 160px; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   design refresh 2026-05-03 — telemetry hero + tel-wrap scope guards
   /* design refresh 2026-05-03 */
   ═══════════════════════════════════════════════════════════════════════════ */

/* Tel-wrap inherits all .mon-* hero/gauge/funnel/logfeed styles defined in
   admin-charts-v9.css (loaded before this file). We just add scope-specific
   tweaks and a CSS export-button highlight. */

.tel-wrap .mon-pagehead { margin-bottom: 22px; }
.tel-wrap .mon-pagehead-actions .mon-refresh#tel-csv-btn {
    background: linear-gradient(135deg, rgba(16,185,129,0.10), rgba(16,185,129,0.04));
    border-color: rgba(16,185,129,0.35);
    color: var(--tlm-success, #10b981);
}
.tel-wrap .mon-pagehead-actions .mon-refresh#tel-csv-btn:hover {
    background: linear-gradient(135deg, rgba(16,185,129,0.18), rgba(16,185,129,0.08));
    border-color: rgba(16,185,129,0.55);
    transform: translateY(-1px);
}
.tel-wrap .mon-pagehead-actions .mon-refresh#tel-csv-btn i { color: var(--tlm-success, #10b981); }

[data-theme="light"] .tel-wrap .mon-pagehead-actions .mon-refresh#tel-csv-btn {
    background: linear-gradient(135deg, rgba(16,185,129,0.10), rgba(16,185,129,0.04));
    color: #047857;
    border-color: rgba(16,185,129,0.40);
}
[data-theme="light"] .tel-wrap .mon-pagehead-actions .mon-refresh#tel-csv-btn i { color: #047857; }

/* Containment safety net for tel-wrap */
.tel-wrap, .tel-wrap .mon-hero, .tel-wrap .mon-funnel, .tel-wrap .mon-grid-2, .tel-wrap .mon-stats-grid {
    max-width: 100%;
    min-width: 0;
}
