/* Stats.PM — admin SSR styles
   Utilise uniquement les variables sémantiques de variables.css.
   Le thème Ocean est forcé via data-theme="ocean" sur <html>. */

/* Material Symbols Outlined — self-hébergé (zéro pistage CDN).
   Variable font, axes opsz/wght/FILL/GRAD inclus. */
@font-face {
  font-family: 'Material Symbols Outlined';
  font-style: normal;
  font-weight: 100 700;
  font-display: swap;
  src: url('../fonts/material-symbols-outlined.woff2') format('woff2');
}

.material-symbols-outlined {
  font-family: 'Material Symbols Outlined';
  font-weight: normal;
  font-style: normal;
  font-size: 18px; /* défaut local plus modeste que les 24px de Google */
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  display: inline-block;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  font-feature-settings: 'liga';
  -webkit-font-smoothing: antialiased;
}

* { box-sizing: border-box; }

html, body {
  margin: 0; padding: 0;
  background: var(--bg-opaque, var(--bg-primary, #fff));
  color: var(--text-primary, #1f2328);
  font-family: "Trebuchet MS", "Lucida Sans Unicode", "Lucida Grande", sans-serif;
  font-size: 15px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a { color: var(--link); text-decoration: none; transition: color 0.15s ease; }
a:hover { color: var(--link-hover); text-decoration: underline; }

/* ---------- LAYOUT (sidebar gauche + main) ---------- */

body { display: flex; min-height: 100vh; }
body.no-scroll { overflow: hidden; }

.layout {
  flex: 1;
  min-width: 0;
  max-width: 1200px;
  margin: 0 auto;
  padding: 2em 1.5em 5em;
}

.sidebar {
  width: 240px;
  flex-shrink: 0;
  background: var(--sidebar-bg);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  padding: 12px;
  position: sticky;
  top: 0;
  align-self: flex-start;
  height: 100vh;
  overflow-y: auto;
  z-index: 30;
  gap: 16px;
}

.sidebar-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 4px 12px;
  border-bottom: 1px solid var(--border);
  margin: 0;
}
.sidebar-brand {
  display: inline-flex;
  align-items: center;
  gap: 0.55em;
  text-decoration: none;
  font-weight: 700;
  color: var(--text-primary);
  font-size: 1em;
  letter-spacing: 0.01em;
  min-width: 0;
}
.sidebar-brand:hover { text-decoration: none; color: var(--text-primary); }
.sidebar-brand img { display: block; flex-shrink: 0; }
.sidebar-app-name {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sidebar-version {
  font-family: inherit;
  font-size: 0.7em;
  font-weight: 500;
  padding: 0.18em 0.5em;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--border) 80%, transparent);
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
  letter-spacing: 0.02em;
}
.sidebar-version:hover {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color: var(--accent);
  border-color: color-mix(in srgb, var(--accent) 35%, transparent);
}

.sidebar-close {
  display: none;
  margin-left: auto;
  width: 1.9em;
  height: 1.9em;
  border: none;
  background: transparent;
  color: var(--text-muted);
  font-size: 1.2em;
  border-radius: var(--radius);
  cursor: pointer;
  line-height: 1;
}
.sidebar-close:hover { background: var(--bg-tertiary); color: var(--text-primary); }

.sidebar-mobile-toggle {
  display: none;
  position: fixed;
  top: 0.6em;
  left: 0.6em;
  z-index: 40;
  width: 2.4em;
  height: 2.4em;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: var(--sidebar-bg);
  color: var(--text-primary);
  font-size: 1.1em;
  cursor: pointer;
  box-shadow: 0 2px 8px var(--shadow);
}

.sidebar-nav {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* ---------- Sidebar amendify-like (sections + nav-btn) ---------- */

.sidebar { font-size: 13px; }

.sidebar-section {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin: 0;
  padding: 0;
  border: none;
}
.sidebar-section[open] > .section-title { color: var(--text-secondary); }

.section-title {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-muted);
  list-style: none;
  cursor: pointer;
  user-select: none;
  padding: 0;
  background: none;
  border: none;
  transition: color 0.15s;
}
.section-title::-webkit-details-marker { display: none; }
.section-title:hover { color: var(--text-secondary); }

.section-count {
  font-size: 10px;
  font-weight: 700;
  padding: 1px 5px;
  border-radius: 8px;
  background: color-mix(in srgb, currentColor 15%, transparent);
  margin-left: 4px;
  font-variant-numeric: tabular-nums;
}
.section-chevron {
  margin-left: auto;
  font-size: 16px !important;
  transition: transform 0.2s ease;
  transform: rotate(-90deg);
  color: var(--text-muted);
}
.sidebar-section[open] > .section-title .section-chevron {
  transform: rotate(0deg);
}

.nav-buttons {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.nav-btn {
  padding: 6px 10px;
  border: 1px solid transparent;
  border-radius: var(--radius);
  background: transparent;
  color: var(--text-secondary);
  font-size: 13px;
  font-family: inherit;
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
  text-align: left;
  display: flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  min-width: 0;
}
.nav-btn .material-symbols-outlined {
  font-size: 18px;
  flex-shrink: 0;
  font-variation-settings: 'wght' 400;
}
.nav-btn:hover {
  background: var(--bg-tertiary);
  color: var(--text-primary);
  text-decoration: none;
}
.nav-btn.active {
  background: color-mix(in srgb, var(--accent) 15%, transparent);
  color: var(--accent);
  font-weight: 600;
}
.nav-btn-secondary {
  border-color: var(--border);
}
.nav-btn-secondary:hover {
  border-color: var(--accent);
}
.nav-btn-muted {
  opacity: 0.55;
  cursor: default;
}
.nav-btn-muted:hover { background: transparent; color: var(--text-secondary); opacity: 0.7; }
.nav-btn-indented { padding-left: 1.6em; }

.nav-label {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}
.nav-badge {
  font-size: 11px;
  font-weight: 600;
  padding: 1px 6px;
  border-radius: 10px;
  background: var(--bg-tertiary);
  color: var(--text-muted);
  flex-shrink: 0;
  font-variant-numeric: tabular-nums;
}
.nav-favicon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  border-radius: 3px;
  object-fit: contain;
}
.nav-group-header {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-muted);
  padding: 8px 10px 2px;
  user-select: none;
}

/* ---------- Action buttons ---------- */
.action-btn {
  padding: 6px 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg-primary);
  color: var(--text-secondary);
  font-size: 13px;
  font-family: inherit;
  cursor: pointer;
  transition: all 0.15s;
  text-align: left;
  white-space: nowrap;
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
}
.action-btn .material-symbols-outlined {
  font-size: 18px;
  flex-shrink: 0;
}
.action-btn:hover {
  border-color: var(--accent);
  color: var(--text-primary);
}
.action-btn-danger { color: color-mix(in srgb, var(--error-color) 80%, var(--text-secondary)); }
.action-btn-danger:hover {
  border-color: var(--error-color);
  color: var(--error-color);
}

/* ---------- Settings toggle (footer) ---------- */
.settings-toggle {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 0;
  border: none;
  background: none;
  color: var(--text-muted);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  cursor: pointer;
  font-family: inherit;
  list-style: none;
  transition: color 0.15s;
}
.settings-toggle::-webkit-details-marker { display: none; }
.settings-toggle:hover { color: var(--text-secondary); }
.settings-toggle .material-symbols-outlined { font-size: 16px; }
.toggle-chevron { margin-left: auto; transition: transform 0.2s ease; }
.sidebar-settings[open] .toggle-chevron { transform: rotate(180deg); }

.user-info {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 0;
}
.user-avatar {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--accent);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  flex-shrink: 0;
}
.user-name {
  font-size: 13px;
  color: var(--text-primary);
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
}
.sidebar-logout-form { margin: 0; }

.sidebar-site-context {
  display: flex;
  align-items: center;
  gap: 0.7em;
  padding: 0.75em 0.85em;
  margin-bottom: 0.85em;
  border-radius: 10px;
  background:
    linear-gradient(135deg,
      color-mix(in srgb, var(--site-accent) 16%, transparent) 0%,
      color-mix(in srgb, var(--site-accent) 6%, transparent) 100%);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--site-accent) 35%, transparent);
}
.sidebar-site-context-fav {
  width: 32px;
  height: 32px;
  border-radius: 7px;
  padding: 3px;
  background: color-mix(in srgb, var(--site-accent) 16%, var(--bg-opaque));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--site-accent) 30%, transparent);
  flex-shrink: 0;
  object-fit: contain;
}
.sidebar-site-context-dot {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--site-accent);
  flex-shrink: 0;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--site-accent) 20%, transparent);
}
.sidebar-site-context-text {
  display: flex;
  flex-direction: column;
  gap: 0.15em;
  min-width: 0;
  flex: 1;
}
.sidebar-site-context-label {
  font-weight: 700;
  font-size: 0.95em;
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  letter-spacing: -0.005em;
}
.sidebar-site-context-back {
  font-size: 0.72em;
  color: var(--text-muted);
  text-decoration: none;
  transition: color 0.12s;
}
.sidebar-site-context-back:hover { color: var(--accent); text-decoration: none; }
/* Anciens .sidebar-link / .sidebar-accordion / .sidebar-sublink* / .sidebar-action / .sidebar-secondary
   / .sidebar-divider / .sidebar-group-header / .sidebar-user / .sidebar-settings-chevron / .sidebar-settings-body
   supprimés après le redesign amendify-like (2026-05-08). Le markup a basculé
   sur .nav-btn / .section-title / .nav-buttons / .action-btn / .settings-toggle. */

.sidebar-spacer { flex: 1; min-height: 0.5em; }
.sidebar-logout-form { margin: 0; }

.sidebar-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 25;
  backdrop-filter: blur(2px);
}

@media (max-width: 900px) {
  body { display: block; }
  .sidebar {
    position: fixed;
    top: 0; left: 0; bottom: 0;
    height: 100vh;
    transform: translateX(-100%);
    transition: transform 0.2s ease;
    width: 280px;
    max-width: 88vw;
    box-shadow: 4px 0 20px var(--shadow);
  }
  .sidebar.open { transform: translateX(0); }
  .sidebar-close { display: inline-flex; align-items: center; justify-content: center; }
  .sidebar-mobile-toggle { display: inline-flex; align-items: center; justify-content: center; }
  .sidebar.open + .sidebar-backdrop,
  .sidebar-backdrop:not([hidden]) { display: block; }
  .layout {
    padding-top: 3.6em;
    padding-left: 0.85em;
    padding-right: 0.85em;
  }
}

/* ---------- RESPONSIVE — adaptations smartphone ---------- */

@media (max-width: 720px) {
  /* Page-head : tout en colonne, plus serré */
  .page-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.75em;
  }
  .page-head h2 { font-size: 1.25em; }
  .crumb { font-size: 0.78em; }

  /* Filter rows : passages à la ligne propres */
  .filter-rows {
    padding: 0.7em 0.8em;
    gap: 0.7em;
  }
  .filter-row {
    flex-direction: column;
    align-items: stretch;
    gap: 0.4em;
  }
  .filter-label {
    margin-right: 0;
    font-size: 0.7em;
  }
  .filter-row > a.preset { flex: 0 0 auto; }
  .filter-dates {
    flex-wrap: wrap;
    width: 100%;
  }
  .filter-dates input[type="date"] { flex: 1; min-width: 8em; }

  /* Tabs : full width avec scroll horizontal si besoin */
  .dashboard-tabs {
    padding: 0.3em;
    gap: 0.2em;
  }
  .dashboard-tab {
    padding: 0.6em 0.7em;
    font-size: 0.85em;
    gap: 0.4em;
    flex: 0 0 auto;
  }
  .dashboard-tab span:not(.material-symbols-outlined) {
    /* On garde le label mais on peut le réduire */
    font-size: 0.95em;
  }
  .dashboard-tab .material-symbols-outlined { font-size: 16px; }

  /* KPI grid : full width 1 colonne */
  .kpi-grid { grid-template-columns: 1fr; gap: 0.7em; }
  .kpi-value { font-size: 1.7em; }

  /* Cards : moins de padding, bord à bord */
  .card {
    padding: 1em 0.9em;
    border-radius: 8px;
    margin-bottom: 1em;
  }

  /* Cards-row : empile en colonne */
  .cards-row { grid-template-columns: 1fr; gap: 0; }

  /* Audience grid : 1 colonne */
  .audience-grid { grid-template-columns: 1fr; }
  .tag-grid { grid-template-columns: 1fr; }

  /* Tables : scroll horizontal interne sans casser le layout */
  table.stats {
    display: block;
    overflow-x: auto;
    white-space: nowrap;
  }
  table.stats thead, table.stats tbody, table.stats tr { display: table; width: 100%; }
  table.stats td.path, table.stats td.short {
    max-width: 12em;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  /* Outbound : colonnes sur 1 ligne mobile */
  .outbound-table th.num, .outbound-table td.num { width: 4.5em; }
  .link-target-text { max-width: 14ch; }

  /* Chart : un peu moins haut + label X plus serré */
  .bar-chart { height: 130px; }
  .chart-monthly .bar-chart { height: 160px; }

  /* Heatmap : labels heure plus rares pour pas trop charger */
  .heatmap { grid-template-columns: 2em repeat(24, 1fr); }
  .heatmap-hour-label { font-size: 0.6em; }
  .heatmap-day-label { font-size: 0.65em; padding-right: 0.2em; }

  /* Tag values : taille label ajustée */
  .tag-value-label { font-size: 0.85em; }

  /* Composition : legend sur 1 colonne */
  .composition-legend { grid-template-columns: 1fr; }

  /* Forms : champs en colonne */
  .form-grid { grid-template-columns: 1fr; padding: 1em; }
  .form-span-2 { grid-column: span 1; }

  /* Site-card : padding réduit */
  .site-card { padding: 1em 1.1em; }
  .site-card-title { font-size: 1.05em; }
  .site-card-value { font-size: 1.6em; }
  .site-grid { grid-template-columns: 1fr; gap: 0.85em; }

  /* Mobile toggle button : un peu plus visible */
  .sidebar-mobile-toggle { top: 0.5em; left: 0.5em; }

  /* Modals : full width sur mobile */
  .changelog-panel,
  .webhook-panel { width: 100%; max-width: 100%; }
  .changelog-overlay, .webhook-overlay { padding: 1em 0.5em; }
}

/* ---------- CHANGELOG MODAL ---------- */

.changelog-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100;
  backdrop-filter: blur(4px);
  padding: 2em 1em;
}
.changelog-overlay[hidden] { display: none; }
.changelog-panel {
  background: var(--popup-bg);
  border: 1px solid var(--border);
  border-radius: 12px;
  width: 720px;
  max-width: 100%;
  max-height: 85vh;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.changelog-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.9em 1.1em;
  border-bottom: 1px solid var(--border);
  background: var(--popup-header-bg);
}
.changelog-title {
  font-size: 0.95em;
  font-weight: 600;
  color: var(--text-primary);
}
.changelog-title .muted { font-weight: 400; }
.changelog-close {
  width: 1.9em;
  height: 1.9em;
  border: none;
  background: transparent;
  color: var(--text-muted);
  border-radius: var(--radius);
  cursor: pointer;
  font-size: 1.2em;
  line-height: 1;
}
.changelog-close:hover { background: var(--bg-tertiary); color: var(--text-primary); }
.changelog-body {
  padding: 1.1em 1.4em 1.4em;
  overflow-y: auto;
  font-size: 0.92em;
  line-height: 1.6;
  color: var(--text-primary);
}
.changelog-body h1 {
  font-size: 1.2em;
  font-weight: 700;
  margin: 0 0 0.6em;
  padding-bottom: 0.4em;
  border-bottom: 1px solid var(--border);
}
.changelog-body h2 {
  font-size: 1em;
  font-weight: 700;
  margin: 1.2em 0 0.4em;
  color: var(--accent);
  letter-spacing: 0.01em;
}
.changelog-body h3 {
  font-size: 0.92em;
  font-weight: 600;
  margin: 0.9em 0 0.3em;
  color: var(--text-secondary);
}
.changelog-body ul { padding-left: 1.4em; margin: 0.4em 0; }
.changelog-body li { margin: 0.2em 0; }
.changelog-body code {
  background: var(--bg-tertiary);
  padding: 0.05em 0.4em;
  border-radius: 3px;
  font-size: 0.88em;
  font-family: monospace;
}
.changelog-body a { color: var(--link); }
.changelog-body a:hover { color: var(--link-hover); }
.changelog-body hr {
  border: none;
  border-top: 1px solid var(--border);
  margin: 1em 0;
}
.changelog-body p { margin: 0.5em 0; }

/* ---------- WEBHOOK BUG / IDÉE MODAL (port de commun/WebhookModal.vue) ---------- */

.webhook-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 110;
  backdrop-filter: blur(4px);
  padding: 2em 1em;
}
.webhook-overlay[hidden] { display: none; }
.webhook-panel {
  background: var(--popup-bg);
  border: 1px solid var(--border);
  border-radius: 12px;
  width: 460px;
  max-width: 100%;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.webhook-header {
  display: flex;
  align-items: center;
  gap: 0.6em;
  padding: 0.95em 1.1em;
  background: var(--popup-header-bg);
  border-bottom: 1px solid var(--border);
}
.webhook-header-icon {
  font-size: 1.1em;
  color: var(--accent);
  flex-shrink: 0;
}
.webhook-header-title {
  font-size: 0.95em;
  font-weight: 700;
  color: var(--text-primary);
  flex-shrink: 0;
}
.webhook-header-desc {
  flex: 1;
  font-size: 0.72em;
  color: var(--text-muted);
  line-height: 1.4;
}
.webhook-close {
  width: 1.9em;
  height: 1.9em;
  border: none;
  background: transparent;
  color: var(--text-muted);
  border-radius: var(--radius);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.webhook-close .material-symbols-outlined { font-size: 20px; }
.webhook-close:hover { background: var(--bg-tertiary); color: var(--text-primary); }

.webhook-body {
  padding: 1em 1.2em 1.2em;
  display: flex;
  flex-direction: column;
  gap: 0.8em;
}
.webhook-radios { display: flex; gap: 0.5em; }
.webhook-radio {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4em;
  padding: 0.55em 0.75em;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-size: 0.82em;
  font-weight: 500;
  color: var(--text-secondary);
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.webhook-radio input[type="radio"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.webhook-radio .material-symbols-outlined { font-size: 18px; }
.webhook-radio:hover {
  border-color: color-mix(in srgb, var(--accent) 45%, var(--border));
  color: var(--text-primary);
}
.webhook-radio.selected {
  border-color: var(--accent);
  background: var(--accent);
  color: #fff;
}
.webhook-field {
  display: flex;
  flex-direction: column;
  gap: 0.3em;
}
.webhook-label {
  font-size: 0.72em;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.webhook-input,
.webhook-textarea {
  padding: 0.55em 0.7em;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg-opaque);
  color: var(--text-primary);
  font: inherit;
  font-size: 0.92em;
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.webhook-input:focus,
.webhook-textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 22%, transparent);
}
.webhook-textarea { resize: vertical; min-height: 4em; }

.webhook-feedback {
  font-size: 0.85em;
  padding: 0.6em 0.8em;
  border-radius: var(--radius);
}
.webhook-feedback.webhook-error {
  color: var(--error-color);
  background: color-mix(in srgb, var(--error-color) 12%, transparent);
}
.webhook-feedback.webhook-success {
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  font-weight: 600;
  text-align: center;
}

.webhook-footer {
  display: flex;
  justify-content: flex-end;
  gap: 0.5em;
  padding-top: 0.2em;
}
.webhook-btn-cancel,
.webhook-btn-send {
  padding: 0.5em 1em;
  border-radius: var(--radius);
  font: inherit;
  font-size: 0.88em;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.webhook-btn-cancel {
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text-secondary);
}
.webhook-btn-cancel:hover {
  border-color: var(--accent);
  color: var(--accent);
}
.webhook-btn-send {
  border: 1px solid var(--accent);
  background: var(--accent);
  color: #fff;
  font-weight: 600;
}
.webhook-btn-send:hover { background: var(--accent-hover); border-color: var(--accent-hover); }
.webhook-btn-send:disabled { opacity: 0.6; cursor: not-allowed; }

/* ---------- PAGE HEAD ---------- */

.page-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 1.5em;
  margin-bottom: 1.5em;
  flex-wrap: wrap;
}
.page-head h2 { margin: 0 0 0.2em; font-size: 1.5em; font-weight: 700; letter-spacing: -0.01em; }
.page-head .muted { margin: 0; }

.head-actions { display: flex; align-items: center; gap: 0.6em; flex-wrap: wrap; }
.rollup-form { margin: 0; }
.optout-toggle { margin: 0; }
.optout-toggle .toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.6em;
  padding: 0.55em 1em 0.55em 0.7em;
  border-radius: 999px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  color: var(--text-primary);
  cursor: pointer;
  user-select: none;
  font-size: 0.9em;
  line-height: 1;
  transition: background 0.15s, border-color 0.15s;
}
.optout-toggle .toggle:hover { background: var(--bg-tertiary); }
.optout-toggle input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 2.2em;
  height: 1.2em;
  border-radius: 999px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border);
  position: relative;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  flex: none;
}
.optout-toggle input[type="checkbox"]::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 0.15em;
  width: 0.85em;
  height: 0.85em;
  border-radius: 50%;
  background: var(--bg-primary);
  transform: translateY(-50%);
  transition: left 0.15s, background 0.15s;
  box-shadow: 0 1px 2px var(--shadow);
}
.optout-toggle input[type="checkbox"]:checked {
  background: var(--accent);
  border-color: var(--accent);
}
.optout-toggle input[type="checkbox"]:checked::after {
  left: calc(100% - 1em);
  background: #fff;
}
.optout-toggle .toggle:has(input:checked) {
  border-color: var(--accent);
  color: var(--text-primary);
}

/* ---------- SITE GRID (dashboard) ---------- */

.site-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.25em;
}
@media (max-width: 720px) {
  .site-grid { grid-template-columns: 1fr; }
}
.site-card {
  /* --site-accent défini inline via style="..." quand le site a une couleur
     dédiée. Fallback : --accent du thème. */
  --site-accent: var(--accent);
  display: flex;
  flex-direction: column;
  gap: 1em;
  padding: 1.4em 1.5em 1.2em;
  background:
    radial-gradient(120% 90% at 100% 0%,
      color-mix(in srgb, var(--site-accent) 9%, transparent) 0%,
      transparent 55%),
    var(--sidebar-bg);
  border: 1px solid var(--border);
  border-radius: 12px;
  text-decoration: none;
  color: inherit;
  position: relative;
  overflow: hidden;
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
  box-shadow: 0 1px 2px var(--shadow);
}
.site-card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  /* Barre latérale 3 px à pleine intensité — l'œil perçoit la même épaisseur
     quelle que soit la luminance de la couleur (fix : un opacity réduit
     escamotait visuellement les couleurs sombres comme #ac1d50). */
  box-shadow: inset 3px 0 0 var(--site-accent);
  transition: box-shadow 0.18s ease;
}
.site-card:hover::before {
  box-shadow: inset 4px 0 0 var(--site-accent);
}
.site-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--site-accent) 45%, var(--border));
  box-shadow:
    0 8px 24px var(--shadow),
    0 0 0 1px color-mix(in srgb, var(--site-accent) 25%, transparent);
  text-decoration: none;
}
.site-card:hover::before { opacity: 1; }
.site-card:hover .site-card-cta { color: var(--site-accent); transform: translateX(3px); }

.site-card-quiet { opacity: 0.65; }
.site-card-quiet::before { background: var(--text-muted); }
.site-card-quiet:hover { opacity: 0.95; }

.site-card-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1em;
}
.site-card-head {
  display: flex;
  align-items: center;
  gap: 0.7em;
  min-width: 0;
}
.site-card-head > div {
  display: flex;
  flex-direction: column;
  gap: 0.1em;
  min-width: 0;
}
.site-card-dot {
  width: 0.7em;
  height: 0.7em;
  border-radius: 50%;
  background: var(--site-accent);
  flex-shrink: 0;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--site-accent) 18%, transparent);
}
/* Favicon en "tile" : 40px de côté, fond légèrement teinté de l'accent du
   site, anneau plein 2 px qui rappelle la couleur du site, padding interne
   pour laisser respirer le glyphe quand la favicon est carrée pleine. */
.site-card-favicon {
  width: 40px;
  height: 40px;
  border-radius: 8px;
  flex-shrink: 0;
  object-fit: contain;
  padding: 4px;
  background: color-mix(in srgb, var(--site-accent) 14%, var(--bg-opaque));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--site-accent) 40%, transparent);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.site-card:hover .site-card-favicon {
  transform: scale(1.05);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--site-accent) 70%, transparent);
}
.site-card-head { gap: 0.85em; }

/* Favicon dans le <h2> de la page détail — taille raisonnable (28 px),
   alignement vertical au texte, même tile-look que la card. */
.site-title-favicon {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  padding: 3px;
  background: color-mix(in srgb, var(--accent) 14%, var(--bg-opaque));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 40%, transparent);
  vertical-align: -8px;
  margin-right: 0.45em;
  object-fit: contain;
}
.site-card-title {
  margin: 0;
  font-size: 1.15em;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--text-primary);
}
.site-card-slug {
  font-family: "Trebuchet MS", "Lucida Sans Unicode", "Lucida Grande", sans-serif;
  font-size: 0.78em;
  color: var(--text-muted);
}

.site-card-primary {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0;
  flex-shrink: 0;
  text-align: right;
}
.site-card-value {
  font-size: 1.85em;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
  line-height: 1.05;
}
.site-card-unit {
  font-size: 0.7em;
  color: var(--text-muted);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-top: 0.15em;
}

.site-card-trends {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4em;
}
/* Pills de tendance : minimalistes, juste un fin contour + couleur.
   La direction est portée par la flèche et le signe %. */
.site-card .trend {
  background: transparent;
  border: 1px solid color-mix(in srgb, var(--site-accent) 25%, var(--border));
  font-size: 0.78em;
  padding: 0.25em 0.7em;
}
.site-card .trend-up {
  color: var(--site-accent);
  border-color: color-mix(in srgb, var(--site-accent) 40%, transparent);
}
.site-card .trend-down {
  color: color-mix(in srgb, var(--site-accent) 70%, var(--text-muted));
  border-color: color-mix(in srgb, var(--site-accent) 22%, transparent);
}
.site-card .trend-flat,
.site-card .trend-na {
  color: var(--text-muted);
  border-color: color-mix(in srgb, var(--text-muted) 18%, transparent);
}

.site-card-chart {
  display: flex;
  flex-direction: column;
  gap: 0.5em;
  position: relative;
}
.site-card-chart-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5em;
  font-size: 0.78em;
  color: var(--text-muted);
}
.spark-max {
  font-variant-numeric: tabular-nums;
  font-size: 0.85em;
  color: var(--text-muted);
  letter-spacing: 0.02em;
}
.spark-sep { color: var(--text-muted); opacity: 0.5; }
/* Gridlines horizontales discrètes (25 / 50 / 75 % du max) */
.site-card-spark .spark-grid {
  stroke: color-mix(in srgb, var(--text-muted) 25%, transparent);
  stroke-width: 0.5;
  stroke-dasharray: 1.5 2;
}
.site-card-spark {
  width: 100%;
  height: 64px;
  display: block;
  overflow: visible;
}
/* Couleurs sémantiques du graphe : direction de l'évolution YoY.
   Indépendant de --site-accent (qui reste pour le branding du site). */
.site-card-spark { --chart-color: var(--text-secondary); }
.site-card-spark[data-trend="up"]   { --chart-color: var(--oc-green,  #859900); }
.site-card-spark[data-trend="down"] { --chart-color: var(--error-color, #f66760); }
.site-card-spark[data-trend="flat"] { --chart-color: var(--text-secondary); }
.site-card-spark[data-trend="na"]   { --chart-color: var(--text-muted); }

.site-card-spark polyline {
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.site-card-spark .spark-prev {
  stroke: var(--text-muted);
  stroke-width: 1.2;
  opacity: 0.45;
}
.site-card-spark .spark-prev.spark-flat {
  stroke-dasharray: 3 2;
  opacity: 0.5;
}
/* Zone "à venir" du mois en cours (jours non encore écoulés). */
.site-card-spark .spark-future {
  fill: var(--text-muted);
  opacity: 0.05;
}
/* Marqueur "aujourd'hui" : colonne verticale + petite tête. Détaché du tracé
   pour ne pas afficher une chute artificielle (la journée est partielle). */
.site-card-spark .spark-today-column {
  stroke: var(--text-secondary);
  stroke-width: 2;
  stroke-linecap: round;
  opacity: 0.55;
}
.site-card-spark .spark-today {
  fill: var(--text-primary);
  stroke: var(--bg-opaque, var(--bg-primary));
  stroke-width: 0.8;
}
.site-card:hover .site-card-spark .spark-today-column { opacity: 0.9; }

/* Segments du mois courant : couleur sémantique jour-à-jour
   (vert > même jour an passé, rouge <, neutre sinon). */
.site-card-spark .spark-seg {
  stroke-width: 1.8;
  stroke-linecap: round;
  fill: none;
}
.site-card-spark .spark-seg.seg-up   { stroke: var(--oc-green, #859900); }
.site-card-spark .spark-seg.seg-down { stroke: var(--error-color, #f66760); }
.site-card-spark .spark-seg.seg-flat { stroke: var(--text-secondary); }
.site-card-spark .spark-seg.seg-na   { stroke: var(--text-muted); opacity: 0.55; }
.site-card:hover .site-card-spark .spark-seg { stroke-width: 2.3; }
.site-card:hover .site-card-spark .spark-prev { opacity: 0.65; }

.site-card-chart-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4em 1em;
  font-size: 0.78em;
  color: var(--text-muted);
}
.spark-legend {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
}
.spark-legend .spark-dot {
  display: inline-block;
  width: 0.7em;
  height: 0.7em;
  border-radius: 50%;
}
/* Pastille de la légende = couleur sémantique du tracé courant */
.site-card-chart-legend[data-trend="up"]   .spark-legend-cur .spark-dot { background: var(--oc-green, #859900); }
.site-card-chart-legend[data-trend="down"] .spark-legend-cur .spark-dot { background: var(--error-color, #f66760); }
.site-card-chart-legend[data-trend="flat"] .spark-legend-cur .spark-dot,
.site-card-chart-legend[data-trend="na"]   .spark-legend-cur .spark-dot { background: var(--text-secondary); }
.spark-legend-prev .spark-dot { background: var(--text-muted); opacity: 0.6; }
.spark-hint {
  margin-left: 0.3em;
  padding: 0.05em 0.45em;
  border-radius: 999px;
  background: color-mix(in srgb, var(--text-muted) 18%, transparent);
  color: var(--text-muted);
  font-size: 0.85em;
  font-weight: 500;
  text-transform: lowercase;
  letter-spacing: 0.02em;
  cursor: help;
}
.site-card-spark-empty {
  height: 36px;
  display: flex;
  align-items: center;
  font-size: 0.82em;
  border-top: 1px dashed color-mix(in srgb, var(--border) 60%, transparent);
  padding-top: 0.5em;
}

.site-card-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.2em 1.2em;
  font-size: 0.85em;
  color: var(--text-secondary);
  border-top: 1px solid color-mix(in srgb, var(--border) 50%, transparent);
  padding-top: 0.7em;
}
.site-card-meta strong {
  color: var(--text-primary);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}

.site-card-cta {
  margin-left: auto;
  font-size: 0.88em;
  color: var(--text-secondary);
  font-weight: 600;
  white-space: nowrap;
  transition: color 0.15s ease, transform 0.15s ease;
}

/* ---------- KPI ---------- */

.kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1em;
  margin-bottom: 1.75em;
}
.kpi {
  background: var(--sidebar-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.1em 1.25em;
  display: flex;
  flex-direction: column;
  gap: 0.35em;
  position: relative;
  overflow: hidden;
}
.kpi::before {
  content: '';
  position: absolute;
  inset: 0 auto 0 0;
  width: 3px;
  background: var(--accent);
  opacity: 0.7;
}
.kpi.kpi-muted::before { background: var(--text-muted); opacity: 0.4; }
.kpi-label {
  font-size: 0.78em;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  font-weight: 600;
}
.kpi-value {
  font-size: 2em;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
}
.kpi.kpi-muted .kpi-value { color: var(--text-secondary); }
.kpi-sub { font-size: 0.82em; color: var(--text-muted); }

/* ---------- CARD ---------- */

.card {
  background: var(--sidebar-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.4em 1.6em;
  margin-bottom: 1.5em;
  box-shadow: 0 1px 2px var(--shadow);
}
@media (max-width: 768px) {
  .card { border-radius: 0; border-left: none; border-right: none; padding: 1.1em 1em; }
}
.card-title {
  margin: 0 0 1em;
  font-size: 1.05em;
  font-weight: 600;
  color: var(--text-primary);
  letter-spacing: 0.01em;
}

h1, h2, h3 { color: var(--text-primary); font-weight: 600; }
h2 { margin-top: 0; font-size: 1.25em; }
h3 { font-size: 1.05em; }

.muted { color: var(--text-muted); }
.kv { display: flex; gap: 2em; flex-wrap: wrap; margin: 0.5em 0 1em; }
.kv > div { display: flex; flex-direction: column; gap: 0.2em; }
.kv .label { color: var(--text-muted); font-size: 0.78em; text-transform: uppercase; letter-spacing: 0.05em; font-weight: 600; }
.kv .value { font-size: 1.6em; font-weight: 700; color: var(--text-primary); font-variant-numeric: tabular-nums; letter-spacing: -0.01em; }

/* ---------- TABLES ---------- */

table.stats {
  width: 100%;
  border-collapse: collapse;
}
table.stats th, table.stats td {
  text-align: left;
  padding: 0.7em 0.75em;
  border-bottom: 1px solid color-mix(in srgb, var(--border) 60%, transparent);
}
table.stats thead th {
  font-weight: 600;
  color: var(--text-muted);
  font-size: 0.75em;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  border-bottom-color: var(--border);
}
table.stats td.num, table.stats th.num {
  text-align: right;
  font-variant-numeric: tabular-nums;
}
table.stats tbody tr:last-child td { border-bottom: none; }
table.stats tbody tr {
  transition: background 0.12s ease;
}
table.stats tbody tr:hover {
  background: color-mix(in srgb, var(--text-primary) 5%, transparent);
}
table.stats tr.row-quiet td:not(.row-action) { opacity: 0.55; }
table.stats td.path, table.stats td.short {
  font-family: "Trebuchet MS", "Lucida Sans Unicode", "Lucida Grande", sans-serif;
  font-size: 0.88em;
  word-break: break-all;
}
table.stats .row-action { width: 1px; white-space: nowrap; text-align: right; }

.site-cell { display: flex; flex-direction: column; gap: 0.1em; }
.site-cell .slug { font-size: 0.82em; font-family: "Trebuchet MS", "Lucida Sans Unicode", "Lucida Grande", sans-serif; }

/* ---------- SPARKLINE ---------- */

table.stats .spark-col { width: 100px; text-align: center; }
.spark {
  width: 90px;
  height: 28px;
  display: inline-block;
  vertical-align: middle;
}
.spark polyline {
  fill: none;
  stroke: var(--accent);
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}
table.stats tr:hover .spark polyline { stroke-width: 2; }

/* ---------- FILTERS / FORMS ---------- */

form.filters {
  display: flex;
  gap: 0.85em;
  flex-wrap: wrap;
  align-items: end;
  margin-bottom: 1.25em;
  padding-bottom: 1.25em;
  border-bottom: 1px solid color-mix(in srgb, var(--border) 60%, transparent);
}
form.filters label {
  display: flex;
  flex-direction: column;
  gap: 0.3em;
  font-size: 0.82em;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 600;
}
form.filters input, form.filters select {
  padding: 0.5em 0.7em;
  background: var(--bg-opaque);
  color: var(--text-primary);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font: inherit;
  font-size: 0.95em;
  letter-spacing: 0;
  text-transform: none;
  font-weight: 400;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
form.filters input:focus, form.filters select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 25%, transparent);
}

/* ---------- BUTTONS ---------- */

.btn {
  display: inline-block;
  padding: 0.5em 1em;
  background: var(--accent);
  color: #fff;
  border: 1px solid transparent;
  border-radius: var(--radius);
  font: inherit;
  font-size: 0.92em;
  font-weight: 500;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  transition: background 0.15s ease, transform 0.05s ease;
}
.btn:hover { background: var(--accent-hover); color: #fff; text-decoration: none; }
.btn:active { transform: translateY(1px); }
.btn-sm { padding: 0.32em 0.85em; font-size: 0.85em; }
.btn-ghost {
  background: transparent;
  color: var(--text-primary);
  border-color: var(--border);
}
.btn-ghost:hover {
  background: color-mix(in srgb, var(--accent) 15%, transparent);
  border-color: var(--accent);
  color: var(--accent);
}
.btn-danger {
  background: transparent;
  color: var(--error-color, #f66760);
  border-color: color-mix(in srgb, var(--error-color, #f66760) 50%, transparent);
}
.btn-danger:hover {
  background: color-mix(in srgb, var(--error-color, #f66760) 18%, transparent);
  border-color: var(--error-color, #f66760);
  color: var(--error-color, #f66760);
}

/* ---------- FLASH ---------- */

.flash {
  padding: 0.75em 1em;
  margin-bottom: 1.25em;
  border-radius: var(--radius);
  border-left: 3px solid var(--accent);
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--text-primary);
  font-size: 0.92em;
}
.flash-error {
  border-left-color: var(--error-color, #f66760);
  background: color-mix(in srgb, var(--error-color, #f66760) 12%, transparent);
}
.flash-success { border-left-color: var(--accent); }

/* ---------- FORMULAIRES (création / édition) ---------- */

.form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1em 1.25em;
  margin-top: 1em;
  padding: 1.25em 1.4em;
  background: color-mix(in srgb, var(--bg-opaque) 40%, transparent);
  border: 1px solid color-mix(in srgb, var(--border) 70%, transparent);
  border-radius: var(--radius);
}
.form-grid label {
  display: flex;
  flex-direction: column;
  gap: 0.35em;
}
.form-label {
  font-size: 0.78em;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 600;
  color: var(--text-muted);
}
.form-label code { text-transform: none; letter-spacing: 0; }
.form-req { color: var(--accent); margin-left: 0.2em; }
.form-grid input[type="text"],
.form-grid input[type="url"],
.form-grid input[type="date"],
.form-grid input[type="number"],
.form-grid select,
.form-grid textarea {
  padding: 0.55em 0.75em;
  background: var(--bg-opaque);
  color: var(--text-primary);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font: inherit;
  font-size: 0.95em;
  width: 100%;
  box-sizing: border-box;
  appearance: none;
  -webkit-appearance: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}
/* Chevron custom pour les <select> sur fond Ocean */
.form-grid select {
  background-image:
    linear-gradient(45deg, transparent 50%, var(--text-secondary) 50%),
    linear-gradient(135deg, var(--text-secondary) 50%, transparent 50%);
  background-position:
    calc(100% - 17px) 50%,
    calc(100% - 12px) 50%;
  background-size: 5px 5px;
  background-repeat: no-repeat;
  padding-right: 2em;
  cursor: pointer;
}
.form-grid input[type="date"] {
  /* Force le picker SVG du navigateur à se teinter sur fond foncé */
  color-scheme: dark;
}
.form-grid input:focus,
.form-grid select:focus,
.form-grid textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 25%, transparent);
}
.form-hint {
  font-size: 0.78em;
  color: var(--text-muted);
}
.form-actions {
  grid-column: 1 / -1;
  display: flex;
  justify-content: flex-end;
  gap: 0.6em;
  align-items: center;
}
.form-span-2 { grid-column: span 2; }
@media (max-width: 700px) { .form-span-2 { grid-column: span 1; } }

.new-outbound { margin-top: 0.5em; }
.new-outbound > summary {
  cursor: pointer;
  list-style: none;
  user-select: none;
  display: inline-block;
}
.new-outbound > summary::-webkit-details-marker { display: none; }
.new-outbound[open] > summary { display: none; }
.new-outbound .form-grid { margin-top: 0; }

/* ---------- OUTBOUND : groupes par catégorie + table compacte ---------- */

.outbound-group { padding: 0; overflow: hidden; }
.outbound-group .group-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1em;
  padding: 0.9em 1.5em;
  background: color-mix(in srgb, var(--accent) 8%, transparent);
  border-bottom: 1px solid color-mix(in srgb, var(--border) 70%, transparent);
}
.group-title {
  margin: 0;
  font-size: 1em;
  font-weight: 600;
  color: var(--text-primary);
  display: flex;
  align-items: center;
  gap: 0.6em;
}
.group-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.6em;
  height: 1.6em;
  padding: 0 0.5em;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 25%, transparent);
  color: var(--accent);
  font-size: 0.78em;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}
.group-stats {
  display: flex;
  gap: 1.25em;
  font-size: 0.85em;
  color: var(--text-secondary);
  font-variant-numeric: tabular-nums;
}
.group-stat strong { color: var(--text-primary); font-weight: 600; }
.group-stat-muted strong { color: var(--text-muted); }

.outbound-table {
  /* table inside outbound-group : retirer le radius haut puisque la group-head a déjà un fond */
}
.outbound-table thead th {
  padding-top: 0.85em;
  padding-bottom: 0.5em;
}
.outbound-table th:first-child, .outbound-table td:first-child { padding-left: 1.5em; }
.outbound-table th:last-child, .outbound-table td:last-child { padding-right: 1.5em; }

/* Colonnes "num" plus serrées : on n'a besoin que de 4-5 chiffres + padding */
.outbound-table th.num, .outbound-table td.num {
  width: 6.5em;
  white-space: nowrap;
}
.outbound-table .row-action {
  width: 1px;        /* shrink-to-fit */
  white-space: nowrap;
}

.link-cell {
  display: flex;
  flex-direction: column;
  gap: 0.2em;
  min-width: 0;
}
.link-meta {
  display: inline-flex;
  align-items: center;
  gap: 0.6em;
  font-size: 0.78em;
  line-height: 1.3;
  flex-wrap: wrap;
}
.link-type {
  display: inline-block;
  padding: 0.05em 0.55em;
  border-radius: 3px;
  background: color-mix(in srgb, var(--accent) 16%, transparent);
  color: var(--accent);
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  font-size: 0.85em;
}
.link-author {
  color: var(--text-secondary);
  font-style: italic;
}
.link-label {
  color: var(--text-primary);
  font-weight: 600;
  font-size: 1em;
  line-height: 1.3;
}
.link-short {
  font-family: "Trebuchet MS", "Lucida Sans Unicode", "Lucida Grande", sans-serif;
  font-size: 0.78em;
  color: var(--text-muted);
  text-decoration: none;
  margin-top: 0.05em;
}
.link-short:hover { color: var(--accent); text-decoration: none; }

.link-target {
  display: inline-flex;
  align-items: center;
  gap: 0.35em;
  max-width: 100%;
  font-family: "Trebuchet MS", "Lucida Sans Unicode", "Lucida Grande", sans-serif;
  font-size: 0.84em;
  color: var(--text-secondary);
  text-decoration: none;
}
.link-target:hover { color: var(--accent); text-decoration: none; }
.link-target-text {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 38ch;
}
.link-target-icon {
  font-size: 0.85em;
  color: var(--text-muted);
  flex-shrink: 0;
}
.link-target:hover .link-target-icon { color: var(--accent); }

/* ---------- TABLES TRIABLES ---------- */
table.sortable th.sortable-th {
  cursor: pointer;
  user-select: none;
  position: relative;
  padding-right: 1.6em;
  transition: color 0.15s ease;
}
table.sortable th.sortable-th:hover { color: var(--text-primary); }
table.sortable th.sortable-th:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: 2px;
}
table.sortable th.sortable-th::after {
  content: '↕';
  position: absolute;
  right: 0.55em;
  top: 50%;
  transform: translateY(-50%);
  opacity: 0.3;
  font-size: 0.95em;
  font-weight: 400;
  transition: opacity 0.15s ease, color 0.15s ease;
}
table.sortable th.sortable-th:hover::after { opacity: 0.7; }
table.sortable th.sort-asc::after  { content: '↑'; opacity: 1; color: var(--accent); }
table.sortable th.sort-desc::after { content: '↓'; opacity: 1; color: var(--accent); }

.outbound-table .row-action .row-actions {
  display: flex;
  gap: 0.4em;
  justify-content: flex-end;
  flex-wrap: nowrap;
  align-items: center;
}
.outbound-table .row-action .row-actions form { margin: 0; }

/* ---------- ICON BUTTONS (édition / suppression compacts) ---------- */

.row-actions-icons {
  flex-direction: column;
  gap: 0.3em !important;
  align-items: stretch !important;
}
.icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.9em;
  height: 1.9em;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: transparent;
  color: var(--text-secondary);
  cursor: pointer;
  text-decoration: none;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.icon-btn:hover {
  background: color-mix(in srgb, var(--accent) 15%, transparent);
  border-color: var(--accent);
  color: var(--accent);
  text-decoration: none;
}
.icon-btn-danger { color: color-mix(in srgb, var(--error-color, #f66760) 80%, var(--text-secondary)); }
.icon-btn-danger:hover {
  background: color-mix(in srgb, var(--error-color, #f66760) 18%, transparent);
  border-color: var(--error-color, #f66760);
  color: var(--error-color, #f66760);
}
.icon-btn svg { display: block; }

@media (max-width: 768px) {
  .outbound-group .group-head { flex-direction: column; align-items: flex-start; gap: 0.5em; }
  .outbound-table th:nth-child(3),
  .outbound-table td:nth-child(3) { display: none; }   /* masque "Cumul" en mobile */
  .outbound-table th:nth-child(5),
  .outbound-table td:nth-child(5) { display: none; }   /* masque "Uniques" en mobile */
  .link-target-text { max-width: 22ch; }
}

form.filters button {
  padding: 0.5em 1.2em;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: var(--radius);
  cursor: pointer;
  font: inherit;
  font-weight: 500;
  align-self: end;
}
form.filters button:hover { background: var(--accent-hover); }

/* ---------- DASHBOARD TOOLBAR (filtres période + granularité) ----------
   Layout : 2 lignes, label gauche fixe (uppercase tiny), segmented control
   à droite. Le date-picker est sur la même ligne que la période, à droite.
   Segmented control : track partagé subtil, chip actif en accent plein.
*/

.dashboard-toolbar {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 0.6em 1em;
  padding: 0.7em 1em;
  margin: 0 0 1.5em;
  background: color-mix(in srgb, var(--bg-opaque) 55%, transparent);
  border: 1px solid color-mix(in srgb, var(--border) 70%, transparent);
  border-radius: 12px;
}
.toolbar-row {
  display: contents; /* enfants directs du grid → 3 colonnes */
}
.toolbar-label {
  font-size: 0.68em;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
  user-select: none;
  white-space: nowrap;
}

/* Segmented control : un seul track, chips inline, séparateurs invisibles */
.toolbar-segments {
  display: inline-flex;
  align-items: stretch;
  background: color-mix(in srgb, var(--text-primary) 5%, transparent);
  border-radius: 8px;
  padding: 3px;
  gap: 0;
  min-width: 0;
  overflow-x: auto;
  scrollbar-width: thin;
}
.toolbar-segment {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.38em 0.85em;
  border: 1px solid transparent;
  border-radius: 6px;
  background: transparent;
  color: var(--text-secondary);
  font-size: 0.82em;
  font-weight: 500;
  text-decoration: none;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.12s, color 0.12s;
  flex: 0 0 auto;
}
.toolbar-segment:hover {
  background: color-mix(in srgb, var(--text-primary) 6%, transparent);
  color: var(--text-primary);
  text-decoration: none;
}
.toolbar-segment.is-active {
  background: var(--bg-opaque);
  color: var(--accent);
  font-weight: 600;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.18), inset 0 0 0 1px color-mix(in srgb, var(--accent) 30%, transparent);
}

.toolbar-dates {
  display: inline-flex;
  align-items: center;
  gap: 0.3em;
  margin: 0;
  padding: 3px 3px 3px 0.55em;
  background: var(--bg-opaque);
  border: 1px solid var(--border);
  border-radius: 8px;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.toolbar-dates:focus-within {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 22%, transparent);
}
.toolbar-dates input[type="date"] {
  padding: 0.32em 0.4em;
  background: transparent;
  color: var(--text-primary);
  border: none;
  border-radius: 6px;
  font: inherit;
  font-size: 0.82em;
  color-scheme: dark;
  outline: none;
  width: 10.5em;
}
.toolbar-dates-sep { color: var(--text-muted); font-size: 0.85em; }
.toolbar-apply {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.7em;
  height: 1.7em;
  border-radius: 5px;
  border: none;
  background: var(--accent);
  color: #fff;
  cursor: pointer;
  transition: background 0.12s, transform 0.05s;
  flex-shrink: 0;
}
.toolbar-apply:hover { background: var(--accent-hover); }
.toolbar-apply:active { transform: scale(0.95); }
.toolbar-apply .material-symbols-outlined { font-size: 18px; }

.toolbar-hint {
  font-size: 0.75em;
  color: var(--text-muted);
  font-style: italic;
  white-space: nowrap;
}

.toolbar-segment.is-disabled {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}

/* Bloc filtres : Page + Tag côte à côte sur la même ligne grid (cols 2-3). */
.toolbar-filters {
  grid-column: 2 / -1;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5em;
  min-width: 0;
}
.toolbar-filter {
  display: inline-flex;
  align-items: center;
  gap: 0.35em;
  flex: 1 1 18em;
  min-width: 0;
  padding: 2px 2px 2px 0.55em;
  background: var(--bg-opaque);
  border: 1px solid var(--border);
  border-radius: 8px;
  margin: 0;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.toolbar-filter:focus-within,
.toolbar-filter:hover {
  border-color: color-mix(in srgb, var(--accent) 55%, var(--border));
}
.toolbar-filter:focus-within {
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 20%, transparent);
}
.toolbar-filter.is-active {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 10%, var(--bg-opaque));
}
.toolbar-filter-icon {
  font-size: 16px;
  line-height: 1;
  color: var(--text-muted);
  flex-shrink: 0;
}
.toolbar-filter.is-active .toolbar-filter-icon { color: var(--accent); }
.toolbar-filter-select {
  flex: 1;
  min-width: 0;
  padding: 0.32em 0.4em;
  background: transparent;
  color: var(--text-primary);
  border: none;
  font: inherit;
  font-size: 0.82em;
  color-scheme: dark;
  outline: none;
  cursor: pointer;
  text-overflow: ellipsis;
}
.toolbar-filter-clear {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.7em;
  height: 1.7em;
  border-radius: 5px;
  background: transparent;
  color: var(--text-muted);
  text-decoration: none;
  flex-shrink: 0;
  transition: background 0.12s, color 0.12s;
}
.toolbar-filter-clear:hover {
  background: color-mix(in srgb, var(--accent) 22%, transparent);
  color: var(--accent);
}
.toolbar-filter.is-active .toolbar-filter-clear { color: var(--accent); }
.toolbar-filter-clear .material-symbols-outlined { font-size: 16px; }

.path-link {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px dashed transparent;
  transition: border-color 0.12s, color 0.12s;
}
.path-link:hover {
  color: var(--accent);
  border-bottom-color: var(--accent);
}
table.stats tr.is-active-path {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
}
table.stats tr.is-active-path .path-link {
  color: var(--accent);
  font-weight: 600;
}

.tag-value-link {
  color: inherit;
  text-decoration: none;
  cursor: pointer;
}
.tag-value-link:hover {
  color: var(--accent);
  text-decoration: underline;
}
.tag-value-row.is-active-tag {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
}
.tag-value-row.is-active-tag .tag-value-link {
  color: var(--accent);
  font-weight: 600;
}

@media (max-width: 720px) {
  /* Mobile : on lâche le grid 3-cols et `display: contents` (qui mélangeait
     les labels d'une ligne avec les contrôles de la suivante). Chaque
     toolbar-row devient un bloc flex-column simple : label en haut,
     contrôles en dessous, le tout pleine largeur. */
  .dashboard-toolbar {
    display: flex;
    flex-direction: column;
    padding: 0.7em 0.85em;
    border-radius: 10px;
    gap: 0.9em;
    /* Cruciaux pour qu'un enfant `overflow-x: auto` puisse vraiment scroller
       au lieu de pousser le parent au-delà du viewport. */
    width: 100%;
    max-width: 100%;
    min-width: 0;
    overflow: hidden;
  }
  .toolbar-row {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.4em;
    min-width: 0;
    max-width: 100%;
  }
  .toolbar-label {
    margin-top: 0;
  }
  /* Le segmented control devient un bloc scrollable horizontalement. */
  .toolbar-segments {
    display: flex;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    overflow-x: auto;
    flex-wrap: nowrap;
    -webkit-overflow-scrolling: touch;
  }
  .toolbar-dates {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    flex-wrap: wrap;
  }
  .toolbar-dates input[type="date"] { flex: 1; min-width: 7em; width: auto; }
  .toolbar-hint { white-space: normal; }
  /* Annule le span grid des filtres (pas de grid en mobile). */
  .toolbar-filters {
    grid-column: auto;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    flex-direction: column;
  }
  .toolbar-filter { flex: 1 1 auto; width: 100%; max-width: 100%; min-width: 0; }
  .toolbar-filter-select { min-width: 0; }
}

/* Anciens .filter-rows / .filter-row / .filter-label / .filter-dates / .preset / .presets
   supprimés après le redesign en .dashboard-toolbar / .toolbar-* (2026-05-08). */

/* ---------- BAR CHART (page détail) ---------- */

.chart-frame {
  position: relative;
  margin: 0.5em 0 1em;
}
.chart-yaxis-max {
  position: absolute;
  top: 0.45em;
  left: 0.7em;
  font-size: 0.7em;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  pointer-events: none;
  z-index: 1;
  font-weight: 600;
}
.bar-chart {
  display: flex;
  align-items: stretch;
  gap: 2px;
  height: 160px;
  padding: 0.7em 0.6em 0.4em;
  background: color-mix(in srgb, var(--bg-opaque) 50%, transparent);
  border-radius: var(--radius);
  border: 1px solid color-mix(in srgb, var(--border) 60%, transparent);
  position: relative;
}
/* Référence YoY (ligne pointillée) tracée par-dessus les bars,
   alignée sur les bar-slots via preserveAspectRatio=none. */
.bar-chart-overlay {
  position: absolute;
  top: 0.7em;
  left: 0.6em;
  /* SVG ignore right/bottom + width:auto et fallback sur sa viewBox intrinsèque,
     d'où l'usage de calc explicite ici. */
  width: calc(100% - 1.2em);
  height: calc(100% - 1.1em);
  pointer-events: none;
}
.bar-chart-overlay .yoy-line {
  fill: none;
  stroke: var(--text-secondary);
  stroke-width: 1.2;
  stroke-dasharray: 3 2;
  opacity: 0.35;
  vector-effect: non-scaling-stroke;
}
/* Marqueurs par jour de la valeur an passé : tirets courts (~30 % de la
   largeur d'une bar), centrés et bien séparés pour qu'on lise chacun comme
   un point de mesure indépendant et pas comme un tracé continu. */
.bar-chart-overlay .yoy-tick {
  stroke: var(--text-primary);
  stroke-width: 3;
  vector-effect: non-scaling-stroke;
  stroke-linecap: round;
  opacity: 0.85;
}
/* Moyennes horizontales sur la période. Couleur accent pour la courante,
   couleur muted pour la précédente. */
.bar-chart-overlay .avg-line {
  stroke-width: 1.5;
  vector-effect: non-scaling-stroke;
  opacity: 0.85;
}
.bar-chart-overlay .avg-line-cur {
  stroke: var(--accent);
}
.bar-chart-overlay .avg-line-prev {
  stroke: var(--text-muted);
  stroke-dasharray: 5 3;
  opacity: 0.55;
}
/* Variantes "uniques" : couleur secondaire (bleu froid), même style mais
   tracés un peu plus fins pour ne pas concurrencer les lignes hits. */
.bar-chart-overlay .avg-line-cur-uni {
  stroke: #38bdf8;
  stroke-width: 1.2;
  opacity: 0.85;
}
.bar-chart-overlay .avg-line-prev-uni {
  stroke: #38bdf8;
  stroke-width: 1.2;
  stroke-dasharray: 5 3;
  opacity: 0.45;
}
.bar-chart-overlay .yoy-tick-uni {
  stroke: #38bdf8;
  stroke-width: 2;
  opacity: 0.75;
}
.bar-chart-campaigns {
  position: absolute;
  top: 0.7em;
  left: 0.6em;
  width: calc(100% - 1.2em);
  height: calc(100% - 1.1em);
  pointer-events: none;
  z-index: 0;
}
.bar-chart-campaigns .campaign-band {
  opacity: 0.12;
  pointer-events: auto;
  cursor: help;
  transition: opacity 0.15s;
}
.bar-chart-campaigns .campaign-band:hover { opacity: 0.28; }
.bar-legend-campaign {
  display: inline-block;
  width: 0.9em; height: 0.9em;
  vertical-align: -0.1em;
  margin-right: 0.4em;
  background: #bc8cff;
  opacity: 0.4;
  border-radius: 2px;
}
.chart-monthly .bar-chart { height: 200px; gap: 3px; }

.bar-chart .bar-slot {
  flex: 1 1 0;
  display: flex;
  align-items: flex-end;
  position: relative;
  min-width: 0;
}
.bar-chart .bar-slot-major::before {
  content: '';
  position: absolute;
  left: -2px;
  top: 0; bottom: 0;
  width: 1px;
  background: color-mix(in srgb, var(--text-muted) 25%, transparent);
}

.bar-chart .bar {
  flex: 1;
  border-radius: 3px 3px 0 0;
  min-height: 2px;
  position: relative;
  transition: filter 0.15s ease, transform 0.05s ease;
}
.bar-chart .bar:hover { filter: brightness(1.18); transform: translateY(-1px); }

/* Barres empilées : complément (hits−uniques) en haut + uniques en bas.
   Pour bien voir la distinction sur fond sombre, on utilise deux teintes
   distinctes (claire / pleine) et une fine séparation. Le wrapper passe en
   opacity:1 pour ne pas écraser les opacités des enfants. */
.bar-chart .bar.bar-stacked {
  display: flex;
  flex-direction: column;
  background: none !important;
  opacity: 1 !important;
  overflow: hidden;
}
.bar-chart .bar.bar-stacked .bar-complement,
.bar-chart .bar.bar-stacked .bar-uniques {
  width: 100%;
  transition: filter 0.15s ease;
}
/* La portion uniques (bas) reçoit la couleur YoY pleine.
   La portion complément (haut) reçoit une version éclaircie de la même teinte
   via color-mix avec le fond (très différencié sur fond sombre). */
.bar-chart .bar.bar-stacked.bar-yoy-up    .bar-uniques    { background: var(--oc-green, #859900); }
.bar-chart .bar.bar-stacked.bar-yoy-up    .bar-complement { background: color-mix(in srgb, var(--oc-green, #859900) 35%, var(--bg-opaque)); }
.bar-chart .bar.bar-stacked.bar-yoy-down  .bar-uniques    { background: var(--error-color, #f66760); }
.bar-chart .bar.bar-stacked.bar-yoy-down  .bar-complement { background: color-mix(in srgb, var(--error-color, #f66760) 35%, var(--bg-opaque)); }
.bar-chart .bar.bar-stacked.bar-yoy-flat  .bar-uniques    { background: var(--text-secondary); }
.bar-chart .bar.bar-stacked.bar-yoy-flat  .bar-complement { background: color-mix(in srgb, var(--text-secondary) 35%, var(--bg-opaque)); }
.bar-chart .bar.bar-stacked.bar-yoy-na    .bar-uniques    { background: var(--text-muted); }
.bar-chart .bar.bar-stacked.bar-yoy-na    .bar-complement { background: color-mix(in srgb, var(--text-muted) 35%, var(--bg-opaque)); }
/* Séparation : 1px en bas du complément (en haut du uniques visuellement). */
.bar-chart .bar.bar-stacked .bar-uniques {
  box-shadow: inset 0 1px 0 0 rgba(255, 255, 255, 0.18);
}
.bar-chart .bar.bar-stacked:hover .bar-complement { filter: brightness(1.2); }
.bar-chart .bar.bar-stacked:hover .bar-uniques    { filter: brightness(1.1); }

/* Couleur des barres = direction YoY (vs même jour/mois an passé) */
.bar-chart .bar.bar-yoy-up {
  background: var(--oc-green, #859900);
  opacity: 0.85;
}
.bar-chart .bar.bar-yoy-down {
  background: var(--error-color, #f66760);
  opacity: 0.85;
}
.bar-chart .bar.bar-yoy-flat {
  background: var(--text-secondary);
  opacity: 0.6;
}
.bar-chart .bar.bar-yoy-na {
  background: var(--text-muted);
  opacity: 0.4;
}
.bar-chart .bar.bar-yoy-up:hover,
.bar-chart .bar.bar-yoy-down:hover { opacity: 1; }
.bar-chart .bar.bar-yoy-flat:hover { opacity: 0.85; }
.bar-chart .bar.bar-yoy-na:hover { opacity: 0.65; }
.bar-chart .bar.bar-estimated {
  background: color-mix(in srgb, var(--text-secondary) 35%, var(--surface));
  background-image: repeating-linear-gradient(
    -45deg,
    transparent 0,
    transparent 3px,
    color-mix(in srgb, var(--text-primary) 35%, transparent) 3px,
    color-mix(in srgb, var(--text-primary) 35%, transparent) 6px
  );
  opacity: 0.95;
}
.bar-chart .bar.bar-estimated:hover { opacity: 1; }
/* Mois estimé en stacked : le wrapper a `background: none !important` donc on
   peint la teinte muted + hachures sur les enfants. Le split uniques/hits
   reste visible (uniques solide en bas, complément plus pâle au-dessus) ;
   la trame diagonale signale que tout est estimé. */
.bar-chart .bar.bar-stacked.bar-estimated .bar-uniques {
  background: color-mix(in srgb, var(--text-secondary) 55%, var(--surface));
  background-image: repeating-linear-gradient(
    -45deg,
    transparent 0,
    transparent 3px,
    color-mix(in srgb, var(--text-primary) 35%, transparent) 3px,
    color-mix(in srgb, var(--text-primary) 35%, transparent) 6px
  );
}
.bar-chart .bar.bar-stacked.bar-estimated .bar-complement {
  background: color-mix(in srgb, var(--text-secondary) 25%, var(--surface));
  background-image: repeating-linear-gradient(
    -45deg,
    transparent 0,
    transparent 3px,
    color-mix(in srgb, var(--text-primary) 20%, transparent) 3px,
    color-mix(in srgb, var(--text-primary) 20%, transparent) 6px
  );
}

.chart-xaxis {
  display: flex;
  gap: 2px;
  padding: 0.3em 0.6em 0;
  font-size: 0.7em;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
  height: 1.5em;
  position: relative;
}
.chart-monthly .chart-xaxis { gap: 3px; }
.chart-xaxis .xaxis-slot {
  flex: 1 1 0;
  position: relative;
  min-width: 0;
}
.chart-xaxis .xaxis-major-label {
  position: absolute;
  top: 0;
  left: 0;
  white-space: nowrap;
  padding-left: 2px;
  color: var(--text-secondary);
  font-weight: 600;
  letter-spacing: 0.02em;
}

.bar-legend-yoy-up,
.bar-legend-yoy-down,
.bar-legend-yoy-flat,
.bar-legend-yoy-na {
  display: inline-block;
  width: 0.9em; height: 0.9em;
  vertical-align: -0.1em;
  margin-right: 0.4em;
  border-radius: 2px;
}
.bar-legend-yoy-up   { background: var(--oc-green, #859900); }
.bar-legend-yoy-down { background: var(--error-color, #f66760); }
.bar-legend-yoy-flat { background: var(--text-secondary); opacity: 0.6; }
.bar-legend-yoy-na   { background: var(--text-muted); opacity: 0.4; }
/* Légende empilée : pavé avec top translucide / bottom plein. */
.bar-legend-stack {
  display: inline-flex;
  flex-direction: column;
  width: 0.9em; height: 0.9em;
  vertical-align: -0.1em;
  margin-right: 0.4em;
  border-radius: 2px;
  overflow: hidden;
}
.bar-legend-stack-top, .bar-legend-stack-bottom {
  flex: 1;
  background: var(--text-secondary);
}
.bar-legend-stack-top { opacity: 0.4; }
.bar-legend-stack-bottom { opacity: 1; }
/* ---------- CAMPAGNES ---------- */
.campaign-name {
  display: inline-flex;
  align-items: center;
  gap: 0.55em;
  font-weight: 600;
  color: var(--text-primary);
  text-decoration: none;
}
.campaign-link:hover {
  text-decoration: none;
  color: var(--site-accent, var(--accent));
}
.campaign-link:hover .campaign-dot {
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--site-accent, var(--accent)) 18%, transparent);
}
.campaign-dot {
  display: inline-block;
  width: 0.7em;
  height: 0.7em;
  border-radius: 50%;
  background: var(--site-accent, var(--accent));
  flex-shrink: 0;
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--site-accent, var(--accent)) 12%, transparent);
  transition: box-shadow 0.15s ease;
}
.campaign-name-text { font-weight: 600; }
.campaign-notes {
  margin-top: 0.15em;
  margin-left: 1.25em; /* aligner sous le texte, pas sous le dot */
  font-size: 0.82em;
  line-height: 1.35;
}
.campaign-site-link {
  color: var(--text-secondary);
  text-decoration: none;
  font-size: 0.92em;
}
.campaign-site-link:hover { color: var(--accent); text-decoration: none; }
.campaign-period {
  display: inline-flex;
  align-items: center;
  gap: 0.45em;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  font-size: 0.92em;
}
.campaign-period-arrow {
  color: var(--text-muted);
  font-size: 0.85em;
}
.campaign-days-badge {
  display: inline-block;
  padding: 0.15em 0.55em;
  border-radius: 999px;
  background: color-mix(in srgb, var(--text-muted) 18%, transparent);
  color: var(--text-secondary);
  font-size: 0.78em;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
}
.campaign-hits {
  font-size: 1em;
  font-weight: 700;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
}
.campaigns-table { table-layout: auto; }
.campaigns-table .col-check { width: 1px; padding-right: 0; }
.campaigns-table .col-check input[type="checkbox"] {
  width: 1.05em;
  height: 1.05em;
  accent-color: var(--accent);
  cursor: pointer;
  vertical-align: middle;
}
.campaigns-table tbody tr {
  position: relative;
}
.campaigns-table tbody tr:hover {
  background: color-mix(in srgb, var(--row-accent, var(--accent)) 7%, transparent);
}
.campaigns-table .row-actions {
  display: inline-flex;
  flex-direction: row;
  gap: 0.35em;
  flex-wrap: nowrap;
}

.campaigns-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1em;
  flex-wrap: wrap;
  margin-bottom: 1em;
}
.campaigns-footer {
  display: flex;
  justify-content: flex-end;
  margin-top: 1em;
  padding-top: 1em;
  border-top: 1px solid color-mix(in srgb, var(--border) 50%, transparent);
}
.btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.btn:disabled:hover { background: var(--accent); }
.btn-ghost:disabled:hover { background: transparent; }

.new-campaign-card { margin-bottom: 1.5em; }
.new-campaign-card[hidden] { display: none; }
.visually-hidden {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}
.campaign-chart-wrap {
  display: flex;
  flex-direction: column;
  gap: 0.6em;
  position: relative;
}
.campaign-chart-hover {
  position: absolute;
  left: 0.6em;
  right: 0.6em;
  top: 0.6em;
  height: calc(220px - 1.2em);
  pointer-events: none;
}
.campaign-chart-hover .hover-col {
  position: absolute;
  top: 0;
  bottom: 0;
  pointer-events: auto;
  cursor: crosshair;
}
.campaign-chart-hover .hover-col:hover {
  background: color-mix(in srgb, var(--text-primary) 6%, transparent);
}
.campaign-chart {
  width: 100%;
  height: 220px;
  background: color-mix(in srgb, var(--bg-opaque) 50%, transparent);
  border: 1px solid color-mix(in srgb, var(--border) 60%, transparent);
  border-radius: var(--radius);
  padding: 0.6em;
  box-sizing: border-box;
}
.campaign-chart .grid {
  stroke: color-mix(in srgb, var(--text-muted) 25%, transparent);
  stroke-width: 0.3;
  stroke-dasharray: 1.5 2;
}
.campaign-chart .series-line {
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
  vector-effect: non-scaling-stroke;
}
.campaign-chart-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5em 1.4em;
  font-size: 0.85em;
}
.cmp-legend { display: inline-flex; align-items: center; gap: 0.4em; }
.cmp-dot {
  display: inline-block;
  width: 0.7em;
  height: 0.7em;
  border-radius: 50%;
  flex-shrink: 0;
}

.bar-legend-yoy-line {
  display: inline-block;
  width: 0.9em; height: 0.9em;
  vertical-align: -0.1em;
  margin-right: 0.4em;
  background:
    linear-gradient(transparent 40%,
      var(--text-secondary) 40%,
      var(--text-secondary) 60%,
      transparent 60%);
  background-size: 4px 100%;
  background-repeat: repeat-x;
  opacity: 0.6;
}
/* Marqueur "valeur an passé par jour" : trois petits ticks horizontaux. */
.bar-legend-yoy-tick {
  display: inline-block;
  width: 0.9em; height: 0.9em;
  vertical-align: -0.1em;
  margin-right: 0.4em;
  background:
    linear-gradient(transparent 45%,
      var(--text-primary) 45%,
      var(--text-primary) 60%,
      transparent 60%);
  background-size: 4px 100%;
  background-repeat: repeat-x;
  opacity: 0.75;
}
/* Légendes des moyennes : trait horizontal continu (cur) ou pointillé (prev). */
.bar-legend-avg-cur,
.bar-legend-avg-prev {
  display: inline-block;
  width: 0.9em; height: 0.9em;
  vertical-align: -0.1em;
  margin-right: 0.4em;
  background:
    linear-gradient(transparent 45%,
      var(--accent) 45%,
      var(--accent) 55%,
      transparent 55%);
}
.bar-legend-avg-prev {
  background:
    linear-gradient(transparent 45%,
      var(--text-muted) 45%,
      var(--text-muted) 55%,
      transparent 55%);
  background-size: 5px 100%;
  background-repeat: repeat-x;
  opacity: 0.7;
}
/* Variantes "uniques" : même picto que les legendes hits mais en bleu froid. */
.bar-legend-yoy-tick-uni {
  background:
    linear-gradient(transparent 45%,
      #38bdf8 45%, #38bdf8 60%, transparent 60%) !important;
  background-size: 4px 100% !important;
  background-repeat: repeat-x !important;
}
.bar-legend-avg-cur-uni {
  background:
    linear-gradient(transparent 45%,
      #38bdf8 45%, #38bdf8 55%, transparent 55%) !important;
}
.bar-legend-avg-prev-uni {
  background:
    linear-gradient(transparent 45%,
      #38bdf8 45%, #38bdf8 55%, transparent 55%) !important;
  background-size: 5px 100% !important;
  background-repeat: repeat-x !important;
  opacity: 0.55 !important;
}
.bar-legend-estimated {
  display: inline-block;
  width: 0.9em;
  height: 0.9em;
  vertical-align: -0.1em;
  margin-right: 0.4em;
  border-radius: 2px;
  background: var(--text-muted);
  background-image: repeating-linear-gradient(
    -45deg,
    transparent,
    transparent 3px,
    color-mix(in srgb, var(--accent) 35%, transparent) 3px,
    color-mix(in srgb, var(--accent) 35%, transparent) 5px
  );
}
.chart-legend {
  font-size: 0.82em;
  margin: 0.5em 0 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5em 1.4em;
  color: var(--text-muted);
}
.chart-legend + .chart-legend { margin-top: 0.25em; }
.chart-legend li { display: inline-flex; align-items: center; }
/* Disclaimer estimation uniques : un poil plus visible, cursor help pour
   indiquer qu'il y a une explication au survol (title HTML natif). */
.chart-legend .legend-disclaimer {
  gap: 0.3em;
  color: var(--text-secondary);
  cursor: help;
  border-bottom: 1px dashed color-mix(in srgb, var(--text-secondary) 50%, transparent);
  padding-bottom: 1px;
}
.chart-legend .legend-disclaimer .material-symbols-outlined {
  font-size: 1.1em;
  opacity: 0.8;
}
/* Ajustement manuel d'hits sur un post / mention média : visible mais discret,
   tooltip avec la raison au survol. */
.rs-post-totals .rs-post-offset {
  display: inline;
  font-size: 0.85em;
  color: var(--text-secondary);
  font-style: italic;
  margin-left: 0.3em;
  cursor: help;
  border-bottom: 1px dashed color-mix(in srgb, var(--text-secondary) 40%, transparent);
}
.rs-post-advanced {
  margin-top: 0.8em;
  padding: 0.5em 0.8em;
  background: color-mix(in srgb, var(--text-muted) 8%, transparent);
  border-radius: 6px;
}
.rs-post-advanced summary {
  cursor: pointer;
  font-size: 0.85em;
  color: var(--text-secondary);
  display: flex;
  align-items: center;
  gap: 0.3em;
  user-select: none;
}
.rs-post-advanced[open] { padding-bottom: 0.8em; }

/* ---------- TOP SITES RÉFÉRENTS : onglets Liste / Camembert ---------- */
.referrers-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1em;
  margin-bottom: 0.8em;
  flex-wrap: wrap;
}
.referrers-tabs {
  display: inline-flex;
  background: color-mix(in srgb, var(--text-primary) 5%, transparent);
  border-radius: 8px;
  padding: 3px;
  gap: 0;
}
.referrers-tab {
  border: none;
  background: transparent;
  color: var(--text-secondary);
  font: inherit;
  font-size: 0.82em;
  font-weight: 500;
  padding: 0.32em 0.85em;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.12s, color 0.12s;
}
.referrers-tab:hover { color: var(--text-primary); }
.referrers-tab.is-active {
  background: var(--bg-opaque);
  color: var(--accent);
  font-weight: 600;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.18), inset 0 0 0 1px color-mix(in srgb, var(--accent) 30%, transparent);
}
.referrers-pane { display: none; }
.referrers-pane.is-active { display: block; }

/* ---------- DONUT SUNBURST (2 anneaux : réseaux + détail) ---------- */
.pie-toggles {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5em 1em;
  margin: 0 0 0.8em;
  font-size: 0.85em;
}
.pie-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  cursor: pointer;
  user-select: none;
  color: var(--text-secondary);
  transition: color 0.12s;
}
.pie-toggle:hover { color: var(--text-primary); }
.pie-toggle input[type="checkbox"] { accent-color: var(--accent); cursor: pointer; }
.pie-toggle code {
  background: color-mix(in srgb, var(--text-primary) 6%, transparent);
  padding: 0.05em 0.4em;
  border-radius: 3px;
}

.pie-chart-wrap {
  display: grid;
  grid-template-columns: minmax(320px, 480px) 1fr;
  gap: 2.5em;
  align-items: start;
  min-width: 0;
}
.pie-chart-wrap > * { min-width: 0; }
@media (max-width: 900px) {
  .pie-chart-wrap { grid-template-columns: 1fr; gap: 1.2em; }
}
@media (max-width: 480px) {
  .pie-chart-wrap { grid-template-columns: minmax(0, 1fr); }
}
.pie-chart-side {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.8em;
}
.pie-chart {
  width: 100%;
  max-width: 480px;
  height: auto;
  aspect-ratio: 1;
}
.pie-chart .pie-track {
  fill: none;
  stroke: color-mix(in srgb, var(--text-primary) 5%, transparent);
}
.pie-chart .pie-track-inner { stroke-width: 11; }
.pie-chart .pie-track-outer { stroke-width: 8; }
.pie-chart .pie-seg {
  fill: none;
  transform: rotate(-90deg);
  transform-origin: 50% 50%;
  transition: stroke-width 0.12s, opacity 0.12s;
}
.pie-chart .pie-seg-inner { stroke-width: 11; }
.pie-chart .pie-seg-outer {
  stroke-width: 8;
  opacity: var(--shade, 0.7);
}
.pie-chart .pie-seg-inner:hover { stroke-width: 13; }
.pie-chart .pie-seg-outer:hover { opacity: 1; }
.pie-chart .pie-center-value {
  font-size: 10px;
  font-weight: 700;
  fill: var(--text-primary);
}
.pie-chart .pie-center-label {
  font-size: 5px;
  fill: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.pie-chart-help {
  font-size: 0.72em;
  text-align: center;
  margin: 0;
  line-height: 1.4;
  max-width: 220px;
}

/* Légende : chaque entrée a une ligne « leader » pointillée entre le label
   et les chiffres pour ne pas se tromper de ligne. */
.pie-legend {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.15em;
}
.pie-legend-item {
  padding: 0.55em 0.6em;
  border-radius: 6px;
  transition: background 0.12s;
}
.pie-legend-item:hover {
  background: color-mix(in srgb, var(--text-primary) 4%, transparent);
}
.pie-legend-item + .pie-legend-item {
  border-top: 1px solid color-mix(in srgb, var(--text-primary) 6%, transparent);
}
.pie-legend-main {
  display: flex;
  align-items: baseline;
  gap: 0.55em;
  font-size: 0.92em;
  min-width: 0;
}
.pie-legend-dot {
  width: 11px;
  height: 11px;
  border-radius: 3px;
  display: inline-block;
  flex-shrink: 0;
  transform: translateY(1px);
}
.pie-legend-label {
  color: var(--text-primary);
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}
.pie-legend-leader {
  flex: 1;
  border-bottom: 1px dotted color-mix(in srgb, var(--text-muted) 50%, transparent);
  align-self: end;
  margin: 0 0.4em 0.2em;
  min-width: 1em;
}
.pie-legend-pct {
  font-variant-numeric: tabular-nums;
  color: var(--text-primary);
  font-weight: 700;
  white-space: nowrap;
  min-width: 3.5em;
  text-align: right;
}
.pie-legend-hits {
  font-variant-numeric: tabular-nums;
  color: var(--text-muted);
  font-size: 0.85em;
  white-space: nowrap;
  min-width: 3em;
  text-align: right;
}

/* Sous-éléments (détail logiciel ou hostnames) */
.pie-legend-subs {
  list-style: none;
  margin: 0.3em 0 0;
  padding: 0 0 0 1.6em;
  display: flex;
  flex-direction: column;
  gap: 0.1em;
}
.pie-legend-sub-item {
  display: flex;
  align-items: baseline;
  gap: 0.45em;
  font-size: 0.82em;
  color: var(--text-secondary);
  min-width: 0;
  overflow: hidden;
}
.pie-legend-sub-item > span:not(.pie-legend-sub-tick) {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}
.pie-legend-sub-tick {
  display: inline-block;
  width: 6px;
  height: 1px;
  background: color-mix(in srgb, var(--text-muted) 55%, transparent);
  flex-shrink: 0;
  transform: translateY(-2px);
}
.pie-legend-sub-label {
  font-family: monospace;
  font-size: 0.95em;
  color: var(--text-secondary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 18em;
}
.pie-legend-sub-pct {
  font-variant-numeric: tabular-nums;
  color: var(--text-secondary);
  font-weight: 500;
  white-space: nowrap;
  min-width: 3.2em;
  text-align: right;
}
.pie-legend-sub-hits {
  font-variant-numeric: tabular-nums;
  color: var(--text-muted);
  font-size: 0.85em;
  white-space: nowrap;
  min-width: 2.5em;
  text-align: right;
}


/* ---------- CARDS-ROW (2 col responsive) ---------- */

.cards-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5em;
}
@media (max-width: 900px) {
  .cards-row { grid-template-columns: 1fr; gap: 0; }
}
.cards-row .card { margin-bottom: 1.5em; }

.empty-soft {
  border: none;
  background: color-mix(in srgb, var(--bg-opaque) 30%, transparent);
  text-align: left;
  padding: 1.2em 1.4em;
}
.empty-soft p { margin: 0 0 0.4em; }
.empty-soft p:last-child { margin: 0; }

.stats-compact th, .stats-compact td { padding: 0.5em 0.6em; }
.stats-compact { font-size: 0.92em; }

.small { font-size: 0.85em; }

.page-head .slug {
  font-family: "Trebuchet MS", "Lucida Sans Unicode", "Lucida Grande", sans-serif;
  font-size: 0.7em;
  font-weight: 400;
  letter-spacing: 0;
  vertical-align: 0.1em;
  margin-left: 0.3em;
}

/* ---------- INSTALL PAGE ---------- */

/* TOC sticky */
.toc {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3em;
  padding: 0.6em 0.8em;
  margin-bottom: 1.5em;
  background: var(--sidebar-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  position: sticky;
  top: 0.5em;
  z-index: 5;
  backdrop-filter: blur(8px);
}
.toc-link {
  padding: 0.35em 0.85em;
  border-radius: var(--radius);
  font-size: 0.85em;
  color: var(--text-secondary);
  text-decoration: none;
  transition: background 0.15s, color 0.15s;
}
.toc-link:hover {
  background: color-mix(in srgb, var(--text-primary) 7%, transparent);
  color: var(--text-primary);
  text-decoration: none;
}
.toc-link.active {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  color: var(--accent);
  font-weight: 600;
}
@media (max-width: 768px) {
  .toc { position: static; }
}

/* Affichage en onglets : seule la section active est visible (si JS dispo) */
[data-tabs-enabled] .section { display: none; }
[data-tabs-enabled] .section.active {
  display: block;
  animation: section-fade-in 0.18s ease-out;
}
@keyframes section-fade-in {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Section avec head numéroté */
.section {
  scroll-margin-top: 8em;
}
.section-head {
  display: flex;
  align-items: flex-start;
  gap: 1em;
  margin-bottom: 1em;
}
.section-num {
  flex-shrink: 0;
  width: 2.4em;
  height: 2.4em;
  border-radius: 50%;
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  color: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.15em;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
}
.section-num-accent {
  background: var(--accent);
  color: #fff;
}
.section-title {
  margin: 0 0 0.15em;
  font-size: 1.2em;
  font-weight: 700;
  letter-spacing: -0.01em;
}
.section-head .muted { margin: 0; font-size: 0.92em; }



.bullets, .steps {
  margin: 0.5em 0 0.25em;
  padding-left: 1.2em;
}
.bullets li, .steps li {
  margin: 0.4em 0;
  line-height: 1.55;
}
.bullets.compact li { margin: 0.2em 0; }
.steps li { padding-left: 0.3em; }
.steps {
  counter-reset: step-counter;
  list-style: none;
  padding-left: 0;
}
.steps li {
  counter-increment: step-counter;
  position: relative;
  padding-left: 2.4em;
  min-height: 1.8em;
}
.steps li::before {
  content: counter(step-counter);
  position: absolute;
  left: 0;
  top: 0.05em;
  width: 1.7em;
  height: 1.7em;
  border-radius: 50%;
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  color: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 0.85em;
  font-variant-numeric: tabular-nums;
}

.subhead {
  margin: 1.5em 0 0.5em;
  font-size: 0.78em;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--text-muted);
}
.subhead:first-of-type { margin-top: 0.3em; }

.step-badge {
  display: inline-block;
  font-size: 0.7em;
  padding: 0.2em 0.7em;
  border-radius: 999px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-weight: 600;
  vertical-align: 0.18em;
  margin-left: 0.5em;
  background: color-mix(in srgb, var(--accent) 22%, transparent);
  color: var(--accent);
}
.step-badge-optional {
  background: color-mix(in srgb, var(--text-muted) 25%, transparent);
  color: var(--text-secondary);
}

.code-frame {
  position: relative;
  margin: 0.75em 0 0.5em;
  background: var(--bg-opaque);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.code-frame pre {
  margin: 0;
  padding: 1em 1.1em;
  padding-right: 4.5em;
  overflow-x: auto;
  font-family: monospace;
  font-size: 0.84em;
  line-height: 1.6;
  color: var(--text-primary);
  white-space: pre-wrap;
  word-break: break-all;
}
.copy-btn {
  position: absolute;
  top: 0.55em;
  right: 0.6em;
  padding: 0.3em 0.75em;
  font-size: 0.78em;
  font-weight: 500;
  background: color-mix(in srgb, var(--text-primary) 8%, transparent);
  color: var(--text-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  cursor: pointer;
  font-family: inherit;
  transition: all 0.15s ease;
}
.copy-btn:hover {
  background: color-mix(in srgb, var(--accent) 15%, transparent);
  border-color: var(--accent);
  color: var(--accent);
}
.copy-btn-ok {
  background: color-mix(in srgb, var(--accent) 25%, transparent) !important;
  border-color: var(--accent) !important;
  color: var(--accent) !important;
}

code {
  font-family: monospace;
  font-size: 0.88em;
  padding: 0.08em 0.4em;
  background: color-mix(in srgb, var(--text-primary) 8%, transparent);
  border-radius: 4px;
  color: var(--text-primary);
}

/* Snippet personnalisable (inputs + code-frame) */
.snippet {
  margin: 0.75em 0 1em;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--bg-opaque);
  --code-bg: #061626;
}
.snippet .code-frame {
  margin: 0;
  border: none;
  border-top: 1px solid color-mix(in srgb, var(--border) 70%, transparent);
  border-radius: 0;
  background: var(--code-bg);
}
.snippet .code-frame pre {
  background: var(--code-bg);
  color: var(--oc-fg, #ebebeb);
}
.snippet .copy-btn {
  background: color-mix(in srgb, #ffffff 6%, transparent);
  border-color: color-mix(in srgb, #ffffff 18%, transparent);
  color: color-mix(in srgb, #ffffff 75%, transparent);
}
.snippet .copy-btn:hover {
  background: color-mix(in srgb, var(--accent) 20%, transparent);
  border-color: var(--accent);
  color: var(--accent);
}
.snippet-vars {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 0.7em 1em;
  padding: 0.85em 1em;
  background: color-mix(in srgb, var(--accent) 5%, transparent);
}
.snippet-var {
  display: flex;
  flex-direction: column;
  gap: 0.3em;
}
.snippet-var-label {
  font-size: 0.72em;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 600;
  color: var(--text-muted);
}
.snippet-var-label code {
  text-transform: none;
  letter-spacing: 0;
  font-size: 0.95em;
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color: var(--accent);
}
.snippet-var input[type="text"] {
  padding: 0.45em 0.65em;
  background: var(--bg-opaque);
  color: var(--text-primary);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font: inherit;
  font-size: 0.9em;
  font-family: monospace;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.snippet-var input[type="text"]:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 25%, transparent);
}
/* ===========================================================
   Coloration syntaxique HTML — mini surligneur JS (~45 lignes).
   ============================================================ */
.snippet-out {
  font-family: monospace;
}

/* Couleurs des tokens HTML, accordées au thème Ocean.
   Inspirées d'un palette type "Solarized dark". */
.snippet-out .hl-tag   { color: #6ad6dc; font-weight: 500; }       /* balises img, a, script… */
.snippet-out .hl-attr  { color: #d4802a; }                          /* src, alt, href, defer… */
.snippet-out .hl-str   { color: #b8ccd0; }                          /* "…" */
.snippet-out .hl-punct { color: color-mix(in srgb, #b8ccd0 55%, transparent); }
.snippet-out .hl-tok {
  background: color-mix(in srgb, var(--accent) 30%, transparent);
  color: #ffffff;
  padding: 0 0.25em;
  border-radius: 3px;
  font-weight: 500;
  text-shadow: 0 0 6px color-mix(in srgb, var(--accent) 40%, transparent);
}

/* Hint row sous le quick-start */
.hint-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.75em;
  margin-top: 1em;
}
.hint {
  padding: 0.7em 0.9em;
  background: color-mix(in srgb, var(--bg-opaque) 40%, transparent);
  border: 1px solid color-mix(in srgb, var(--border) 60%, transparent);
  border-radius: var(--radius);
  font-size: 0.9em;
  display: flex;
  flex-direction: column;
  gap: 0.15em;
}
.hint strong { color: var(--text-primary); }

/* Callouts (info, warning) */
.callout {
  padding: 0.85em 1em;
  margin: 1em 0;
  border-radius: var(--radius);
  border-left: 3px solid var(--accent);
  background: color-mix(in srgb, var(--accent) 7%, transparent);
}
.callout strong { display: inline-block; margin-bottom: 0.2em; color: var(--text-primary); }
.callout p { margin: 0.2em 0 0; }
.callout ul { margin: 0.4em 0 0; }
.callout-muted {
  border-left-color: var(--text-muted);
  background: color-mix(in srgb, var(--text-muted) 8%, transparent);
}
.callout-warn {
  border-left-color: var(--warning-color, #d4802a);
  background: color-mix(in srgb, var(--warning-color, #d4802a) 8%, transparent);
}
.callout-warn strong { color: var(--warning-color, #d4802a); }

/* Tag badge inline (dans le texte de la doc) */
.tag-badge-inline {
  font-family: "Trebuchet MS", "Lucida Sans Unicode", "Lucida Grande", sans-serif;
  font-size: 0.85em;
  padding: 0.1em 0.55em;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  color: var(--accent);
  font-weight: 500;
}

/* Tableau de référence */
.ref-table {
  width: 100%;
  border-collapse: collapse;
  margin: 0.5em 0;
  font-size: 0.92em;
}
.ref-table th {
  text-align: left;
  font-size: 0.75em;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  font-weight: 600;
  padding: 0.55em 0.7em;
  border-bottom: 1px solid var(--border);
}
.ref-table td {
  padding: 0.6em 0.7em;
  border-bottom: 1px solid color-mix(in srgb, var(--border) 50%, transparent);
  vertical-align: top;
}
.ref-table tr:last-child td { border-bottom: none; }
.ref-table td code { word-break: break-all; }

/* Pills "obligatoire" / "recommandé" pour le ref-table */
.pill {
  display: inline-block;
  padding: 0.1em 0.6em;
  border-radius: 999px;
  font-size: 0.78em;
  font-weight: 600;
  letter-spacing: 0.02em;
  background: color-mix(in srgb, var(--text-muted) 25%, transparent);
  color: var(--text-secondary);
  white-space: nowrap;
}
.pill-required {
  background: color-mix(in srgb, var(--accent) 25%, transparent);
  color: var(--accent);
}

/* HTTP verb badge */
.http-verb {
  display: inline-block;
  padding: 0.15em 0.6em;
  border-radius: 4px;
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  color: var(--accent);
  font-family: "Trebuchet MS", "Lucida Sans Unicode", "Lucida Grande", sans-serif;
  font-size: 0.78em;
  font-weight: 600;
  letter-spacing: 0.06em;
}

/* Privacy grid (key-value) */
.privacy-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1em;
  margin: 1em 0;
}
.privacy-item {
  padding: 1em 1.1em;
  background: color-mix(in srgb, var(--bg-opaque) 45%, transparent);
  border: 1px solid color-mix(in srgb, var(--border) 60%, transparent);
  border-radius: var(--radius);
}
.privacy-item-wide { grid-column: 1 / -1; }
.privacy-label {
  display: block;
  font-size: 0.72em;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  font-weight: 600;
  color: var(--accent);
  margin-bottom: 0.4em;
}
.privacy-item p { margin: 0; font-size: 0.92em; line-height: 1.55; }

/* Quote block (mention type) */
.quote {
  padding: 1em 1.2em;
  margin: 0.5em 0;
  border-left: 3px solid var(--accent);
  background: color-mix(in srgb, var(--accent) 6%, transparent);
  border-radius: 0 var(--radius) var(--radius) 0;
  font-style: italic;
  color: var(--text-secondary);
  line-height: 1.6;
}
.quote a { color: var(--accent); font-style: normal; }
.bar-chart .bar[title]:hover::after {
  content: attr(title);
  position: absolute;
  bottom: calc(100% + 6px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--popup-bg);
  border: 1px solid var(--border);
  padding: 0.4em 0.7em;
  font-size: 0.78em;
  white-space: nowrap;
  border-radius: var(--radius);
  z-index: 5;
  box-shadow: 0 4px 14px var(--shadow);
  font-variant-numeric: tabular-nums;
  pointer-events: none;
}

/* ---------- BREADCRUMB / TAGS / EMPTY ---------- */

.crumb {
  font-size: 0.85em;
  color: var(--text-muted);
  margin-bottom: 1em;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.crumb a { color: var(--text-muted); }
.crumb a:hover { color: var(--text-primary); }

.tag-badge {
  display: inline-block;
  padding: 0.18em 0.65em;
  border-radius: 999px;
  font-size: 0.85em;
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  color: var(--accent);
  font-weight: 500;
  letter-spacing: 0.01em;
}
a.tag-badge:hover { background: color-mix(in srgb, var(--accent) 30%, transparent); text-decoration: none; }

/* ---------- TAG SUMMARIES (site-detail) ---------- */

.tag-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 0.9em 1.1em;
}
.tag-card {
  display: flex;
  flex-direction: column;
  gap: 0.55em;
  padding: 0.85em 1em 0.95em;
  background: color-mix(in srgb, var(--bg-opaque) 45%, transparent);
  border: 1px solid color-mix(in srgb, var(--border) 65%, transparent);
  border-radius: 10px;
  transition: border-color 0.15s ease, background 0.15s ease;
}
.tag-card:hover {
  border-color: color-mix(in srgb, var(--accent) 35%, var(--border));
  background: color-mix(in srgb, var(--accent) 4%, var(--bg-opaque) 50%);
}
.tag-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6em;
  flex-wrap: wrap;
}
.tag-card-meta {
  font-size: 0.78em;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
}
.tag-card-meta strong {
  color: var(--text-primary);
  font-weight: 600;
}
.tag-values {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.18em;
}
.tag-value-row {
  position: relative;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 0.7em;
  padding: 0.3em 0.6em;
  border-radius: 6px;
  font-size: 0.86em;
  line-height: 1.35;
  cursor: default;
  isolation: isolate;
  transition: background 0.12s ease;
}
.tag-value-row:hover { background: color-mix(in srgb, var(--text-primary) 5%, transparent); }
.tag-value-bar {
  position: absolute;
  inset: 0 auto 0 0;
  z-index: -1;
  border-radius: 5px;
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  pointer-events: none;
  transition: background 0.15s ease;
}
.tag-value-row:hover .tag-value-bar {
  background: color-mix(in srgb, var(--accent) 22%, transparent);
}
.tag-value-label {
  color: var(--text-primary);
  font-family: "Trebuchet MS", "Lucida Sans Unicode", "Lucida Grande", sans-serif;
  font-size: 0.92em;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}
.tag-value-num {
  color: var(--text-secondary);
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  font-size: 0.88em;
}

/* ---------- AUDIENCE (browser / OS / device / langue) ---------- */

.audience-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 0.9em 1.1em;
}
.audience-block {
  display: flex;
  flex-direction: column;
  gap: 0.5em;
  padding: 0.85em 1em 0.95em;
  background: color-mix(in srgb, var(--bg-opaque) 45%, transparent);
  border: 1px solid color-mix(in srgb, var(--border) 65%, transparent);
  border-radius: 10px;
}
.audience-title {
  margin: 0 0 0.2em;
  font-size: 0.78em;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
}

/* ---------- Dashboard tabs ---------- */

/* Palette d'accent par onglet — diversifie le langage couleur tout en
   restant cohérent avec le thème ocean. */
:root {
  --tab-overview:   var(--accent);        /* cyan */
  --tab-audience:   #b16286;              /* magenta */
  --tab-engagement: #d4802a;              /* orange */
  --tab-content:    #859900;              /* vert */
}

.dashboard-tabs {
  display: flex;
  gap: 0.3em;
  margin-bottom: 1.5em;
  padding: 0.4em;
  background: color-mix(in srgb, var(--bg-opaque) 50%, transparent);
  border: 1px solid color-mix(in srgb, var(--border) 70%, transparent);
  border-radius: 12px;
  overflow-x: auto;
  scrollbar-width: thin;
}
.dashboard-tab {
  flex: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55em;
  padding: 0.7em 1em;
  border: none;
  border-radius: 8px;
  background: transparent;
  color: var(--text-secondary);
  font: inherit;
  font-size: 0.95em;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s, color 0.15s;
  --tab-color: var(--accent);
}
.dashboard-tab[data-tab="overview"]   { --tab-color: var(--tab-overview); }
.dashboard-tab[data-tab="audience"]   { --tab-color: var(--tab-audience); }
.dashboard-tab[data-tab="engagement"] { --tab-color: var(--tab-engagement); }
.dashboard-tab[data-tab="content"]    { --tab-color: var(--tab-content); }

.dashboard-tab .material-symbols-outlined {
  font-size: 18px;
  color: var(--text-muted);
  transition: color 0.15s;
}
.dashboard-tab:hover {
  background: color-mix(in srgb, var(--text-primary) 6%, transparent);
  color: var(--text-primary);
}
.dashboard-tab:hover .material-symbols-outlined { color: var(--tab-color); }
.dashboard-tab.is-active {
  background: color-mix(in srgb, var(--tab-color) 18%, transparent);
  color: var(--tab-color);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--tab-color) 35%, transparent);
}
.dashboard-tab.is-active .material-symbols-outlined { color: var(--tab-color); }

.dashboard-pane {
  display: none;
}
.dashboard-pane.is-active { display: block; }

/* Couleur d'accent contextuel par pane : --tab-accent fait écho à la
   palette de l'onglet courant et est repris par les KPI / titres / barres. */
.dashboard-pane[data-pane="overview"]   { --tab-accent: var(--tab-overview); }
.dashboard-pane[data-pane="audience"]   { --tab-accent: var(--tab-audience); }
.dashboard-pane[data-pane="engagement"] { --tab-accent: var(--tab-engagement); }
.dashboard-pane[data-pane="content"]    { --tab-accent: var(--tab-content); }

.dashboard-pane .card-title { color: var(--tab-accent, var(--text-primary)); }

/* KPI tile par catégorie (bar latérale colorée) */
.kpi-tab-overview::before   { background: var(--tab-overview)   !important; }
.kpi-tab-audience::before   { background: var(--tab-audience)   !important; }
.kpi-tab-engagement::before { background: var(--tab-engagement) !important; }
.kpi-tab-content::before    { background: var(--tab-content)    !important; }

/* ---------- Bouton export CSV ---------- */
.card-head-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1em;
  margin-bottom: 1em;
}
.card-head-actions .card-title { margin: 0; }
.btn-export {
  display: inline-flex;
  align-items: center;
  gap: 0.35em;
  padding: 0.35em 0.7em;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: transparent;
  color: var(--text-muted);
  font: inherit;
  font-size: 0.78em;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s;
}
.btn-export:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 8%, transparent);
}
.btn-export .material-symbols-outlined { font-size: 14px; }

/* ---------- Coverage note (badge "données partielles") ---------- */
.coverage-note {
  display: flex;
  align-items: flex-start;
  gap: 0.7em;
  padding: 0.85em 1em;
  margin-bottom: 1em;
  border-radius: 8px;
  background: color-mix(in srgb, var(--warning-color) 12%, transparent);
  border-left: 3px solid var(--warning-color);
  font-size: 0.88em;
  color: var(--text-primary);
  line-height: 1.5;
}
.coverage-note .material-symbols-outlined {
  font-size: 18px;
  color: var(--warning-color);
  flex-shrink: 0;
  margin-top: 1px;
}

/* ---------- Composition trafic (barre 4 segments) ---------- */
.composition-bar {
  display: flex;
  height: 32px;
  border-radius: 8px;
  overflow: hidden;
  background: color-mix(in srgb, var(--text-muted) 8%, transparent);
  margin: 0.5em 0 1em;
}
.composition-seg {
  height: 100%;
  transition: opacity 0.15s, filter 0.15s;
}
.composition-seg:hover { filter: brightness(1.15); }
.composition-seg-direct   { background: var(--tab-overview); }
.composition-seg-search   { background: var(--tab-audience); }
.composition-seg-social   { background: var(--tab-engagement); }
.composition-seg-external { background: var(--tab-content); }
.composition-legend {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0.4em 1em;
}
.composition-legend-item {
  display: grid;
  grid-template-columns: 0.7em 1fr auto auto;
  align-items: center;
  gap: 0.55em;
  font-size: 0.88em;
  font-variant-numeric: tabular-nums;
}
.composition-legend-item.is-empty { opacity: 0.4; }
.composition-legend-dot {
  width: 0.7em;
  height: 0.7em;
  border-radius: 50%;
}
.composition-legend-label { color: var(--text-secondary); }
.composition-legend-pct { font-weight: 700; color: var(--text-primary); }
.composition-legend-hits { font-size: 0.85em; }

/* ---------- Heatmap heure × jour ---------- */
.heatmap {
  display: grid;
  grid-template-columns: 2.4em repeat(24, 1fr);
  gap: 2px;
  margin: 0.5em 0;
}
.heatmap-corner { background: transparent; }
.heatmap-hour-label,
.heatmap-day-label {
  font-size: 0.7em;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
  display: flex;
  align-items: center;
  justify-content: center;
}
.heatmap-day-label { justify-content: flex-end; padding-right: 0.3em; font-weight: 600; }
.heatmap-cell {
  aspect-ratio: 1;
  border-radius: 3px;
  background: color-mix(in srgb, var(--text-muted) 8%, transparent);
  transition: transform 0.12s, filter 0.12s;
  cursor: default;
}
.heatmap-cell:hover { transform: scale(1.3); filter: brightness(1.3); z-index: 2; position: relative; }
/* Intensité (0..10) → opacity de la couleur d'accent de l'onglet audience */
.heatmap-cell[data-intensity="0"]  { background: color-mix(in srgb, var(--text-muted) 6%, transparent); }
.heatmap-cell[data-intensity="1"]  { background: color-mix(in srgb, var(--tab-audience) 8%, transparent); }
.heatmap-cell[data-intensity="2"]  { background: color-mix(in srgb, var(--tab-audience) 16%, transparent); }
.heatmap-cell[data-intensity="3"]  { background: color-mix(in srgb, var(--tab-audience) 24%, transparent); }
.heatmap-cell[data-intensity="4"]  { background: color-mix(in srgb, var(--tab-audience) 32%, transparent); }
.heatmap-cell[data-intensity="5"]  { background: color-mix(in srgb, var(--tab-audience) 42%, transparent); }
.heatmap-cell[data-intensity="6"]  { background: color-mix(in srgb, var(--tab-audience) 52%, transparent); }
.heatmap-cell[data-intensity="7"]  { background: color-mix(in srgb, var(--tab-audience) 64%, transparent); }
.heatmap-cell[data-intensity="8"]  { background: color-mix(in srgb, var(--tab-audience) 76%, transparent); }
.heatmap-cell[data-intensity="9"]  { background: color-mix(in srgb, var(--tab-audience) 88%, transparent); }
.heatmap-cell[data-intensity="10"] { background: var(--tab-audience); }

/* ---------- Heatmap horaire (24 colonnes) ---------- */
.hourchart {
  display: flex;
  align-items: flex-end;
  gap: 2px;
  height: 100px;
  padding: 0.5em 0.4em 0.2em;
  background: color-mix(in srgb, var(--bg-opaque) 50%, transparent);
  border-radius: var(--radius);
  border: 1px solid color-mix(in srgb, var(--border) 60%, transparent);
}
.hourchart-col {
  flex: 1 1 0;
  display: flex;
  align-items: flex-end;
  min-width: 0;
  cursor: default;
}
.hourchart-bar {
  width: 100%;
  background: var(--accent);
  opacity: 0.75;
  border-radius: 2px 2px 0 0;
  min-height: 2px;
  transition: opacity 0.12s ease, filter 0.12s ease;
}
.hourchart-col:hover .hourchart-bar {
  opacity: 1;
  filter: brightness(1.15);
}
.hourchart-bar-empty {
  background: var(--text-muted);
  opacity: 0.25;
}
.hourchart-axis {
  display: flex;
  justify-content: space-between;
  padding: 0.3em 0.6em 0;
  font-size: 0.7em;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
}

.empty {
  padding: 2.5em 1.5em;
  text-align: center;
  color: var(--text-muted);
  border: 1px dashed var(--border);
  border-radius: var(--radius);
}

/* ---------- TREND PILLS ---------- */

.kpi-trends {
  display: flex;
  flex-direction: column;
  gap: 0.25em;
  margin-top: 0.4em;
}
.trend {
  display: inline-flex;
  align-items: baseline;
  gap: 0.4em;
  font-size: 0.85em;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.01em;
}
.trend .trend-arrow { font-size: 0.78em; line-height: 1; }
.trend .trend-pct { font-weight: 600; }
.trend .trend-label { color: var(--text-muted); font-size: 0.92em; }
.trend.trend-up { color: var(--accent); }
.trend.trend-up .trend-arrow { color: var(--accent); }
.trend.trend-down { color: var(--error-color); }
.trend.trend-down .trend-arrow { color: var(--error-color); }
.trend.trend-flat { color: var(--text-secondary); }
.trend.trend-na { color: var(--text-muted); }
.trend.trend-na .trend-pct { font-weight: 400; }

.trend-inline {
  display: inline-flex;
  align-items: center;
  gap: 0.25em;
  padding: 0.15em 0.55em;
  border-radius: 999px;
  font-size: 0.82em;
}
.trend-inline.trend-up { background: color-mix(in srgb, var(--accent) 14%, transparent); }
.trend-inline.trend-down { background: color-mix(in srgb, var(--error-color) 14%, transparent); }
.trend-inline.trend-flat,
.trend-inline.trend-na {
  background: color-mix(in srgb, var(--text-muted) 12%, transparent);
}

/* ---------- CHART TOOLTIP (custom, hover) ---------- */
.chart-tooltip {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1000;
  pointer-events: none;
  max-width: 22em;
  padding: 0.55em 0.8em;
  background: var(--bg-primary);
  color: var(--text-primary);
  border: 1px solid var(--border);
  border-radius: 6px;
  box-shadow: 0 4px 16px var(--shadow), 0 1px 3px var(--shadow);
  font-size: 0.85em;
  line-height: 1.35;
  white-space: pre-line;
  opacity: 0;
  transform: translate(0, 0);
  transition: opacity 0.08s ease-out;
}
.chart-tooltip.chart-tooltip-visible { opacity: 1; }
.chart-tooltip::first-line { font-weight: 600; }

/* Élargir la zone de hover : tout le slot capte l'événement (pas seulement la
   petite barre haute de quelques pixels) */
.bar-slot { cursor: crosshair; }

/* ---------- INTÉGRATION MATOMO (site-detail) ---------- */
.site-integration {
  margin: 0.8em 0 1.2em;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg-secondary);
}
.site-integration > summary {
  display: flex;
  align-items: center;
  gap: 0.6em;
  padding: 0.65em 1em;
  cursor: pointer;
  list-style: none;
  font-weight: 500;
  color: var(--text-primary);
}
.site-integration > summary::-webkit-details-marker { display: none; }
.site-integration > summary .material-symbols-outlined { font-size: 18px; }
.site-integration[open] > summary { border-bottom: 1px solid var(--border); }
.site-integration-body { padding: 0.9em 1em 1em; }
.site-integration-body .kv-list {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 0.4em 1em;
  margin: 0.8em 0;
}
.site-integration-body .kv-list dt {
  color: var(--text-secondary);
  font-size: 0.88em;
}
.site-integration-body .kv-list dd {
  margin: 0;
  word-break: break-all;
}
.site-integration-body .kv-list dd code {
  font-size: 0.88em;
  user-select: all;
}
.site-integration-actions {
  display: flex;
  gap: 0.6em;
  margin-top: 0.9em;
}

/* ---------- FORMULAIRES SITE (création + édition) ---------- */
.site-create-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1em;
  margin: 0.8em 0 1.2em;
}
@media (max-width: 720px) {
  .site-create-row { grid-template-columns: 1fr; }
}
.site-create-row .site-integration { margin: 0; }
.site-form {
  display: flex;
  flex-direction: column;
  gap: 0.7em;
}
.site-form label {
  display: flex;
  flex-direction: column;
  gap: 0.25em;
}
.site-form label.form-check {
  flex-direction: row;
  align-items: center;
  gap: 0.5em;
}
.site-form .form-label {
  font-size: 0.88em;
  color: var(--text-secondary);
}
.site-form input[type="text"] {
  padding: 0.45em 0.65em;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg-primary);
  color: var(--text-primary);
  font: inherit;
}
.site-form input[type="text"]:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 25%, transparent);
}

/* Zone dangereuse dans la carte Paramètres */
.site-integration-sep {
  border: 0;
  border-top: 1px solid var(--border);
  margin: 1.2em 0 1em;
}
.site-integration-danger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1em;
  flex-wrap: wrap;
}
.site-integration-danger p { margin: 0.2em 0 0; }

/* ===== Publications RS (onglet dédié) ===== */
.rs-post-form {
  display: flex;
  flex-direction: column;
  gap: 0.8em;
  padding: 1em;
  background: color-mix(in srgb, var(--accent) 4%, var(--surface));
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-bottom: 1.4em;
}
.rs-post-form-row {
  display: flex;
  gap: 0.8em;
  flex-wrap: wrap;
}
.rs-post-form-row label {
  display: flex;
  flex-direction: column;
  gap: 0.3em;
  font-size: 0.85em;
  color: var(--muted);
  flex: 0 1 auto;
}
.rs-post-form-row label.grow { flex: 1 1 280px; }
.rs-post-form-row input,
.rs-post-form-row select {
  font: inherit;
  padding: 0.45em 0.65em;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
  color: var(--text);
  min-width: 200px;
}
.rs-post-form-row input:focus,
.rs-post-form-row select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 25%, transparent);
}
.rs-post-form-actions {
  display: flex;
  justify-content: flex-end;
}
.rs-post-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1em;
}
.rs-post-item {
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 0.9em 1em;
  background: var(--surface);
}
.rs-post-head {
  display: flex;
  align-items: center;
  gap: 0.8em;
  flex-wrap: wrap;
}
.rs-post-net {
  display: inline-block;
  color: #fff;
  font-weight: 600;
  font-size: 0.8em;
  padding: 0.2em 0.6em;
  border-radius: 4px;
  text-shadow: 0 1px 1px rgba(0,0,0,0.25);
}
.rs-post-date {
  font-weight: 500;
}
.rs-post-totals {
  margin-left: auto;
  font-size: 0.95em;
}
.rs-post-delete {
  margin: 0;
}
.rs-post-delete button {
  background: transparent;
  border: 1px solid transparent;
  color: var(--muted);
  cursor: pointer;
  padding: 0.25em;
  border-radius: 4px;
  display: inline-flex;
  align-items: center;
}
.rs-post-delete button:hover {
  color: #c0392b;
  border-color: color-mix(in srgb, #c0392b 30%, transparent);
  background: color-mix(in srgb, #c0392b 8%, transparent);
}
.rs-post-meta {
  margin-top: 0.5em;
  font-size: 0.9em;
  display: flex;
  gap: 1em;
  flex-wrap: wrap;
  align-items: center;
}
.rs-post-charts {
  margin-top: 0.9em;
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 1.2em;
}
.rs-post-chart-label {
  font-size: 0.82em;
  color: var(--muted);
  margin-bottom: 0.3em;
}
.rs-post-bars {
  width: 100%;
  height: 90px;
  display: block;
}
.rs-post-bars-labels {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
  font-size: 0.72em;
  text-align: center;
  color: var(--muted);
  margin-top: 0.3em;
}
.rs-post-bars-labels strong {
  color: var(--text);
  font-size: 1.1em;
}
.rs-post-spark {
  width: 100%;
  height: 60px;
  display: block;
}
.rs-post-empty {
  padding: 1em;
  text-align: center;
  border: 1px dashed var(--border);
  border-radius: 6px;
}
@media (max-width: 640px) {
  .rs-post-charts { grid-template-columns: 1fr; }
  .rs-post-totals { margin-left: 0; width: 100%; }
}

/* ===== Comptes RS surveillés ===== */
.rs-acct-form { display: flex; flex-direction: column; gap: 0.8em; }
.rs-acct-form-row { display: flex; gap: 0.8em; flex-wrap: wrap; }
.rs-acct-form-row label {
  display: flex; flex-direction: column; gap: 0.3em;
  font-size: 0.85em; color: var(--muted); flex: 0 1 auto;
}
.rs-acct-form-row label.grow { flex: 1 1 280px; }
.rs-acct-form-row input,
.rs-acct-form-row select {
  font: inherit; padding: 0.45em 0.65em;
  border: 1px solid var(--border); border-radius: 6px;
  background: var(--surface); color: var(--text); min-width: 200px;
}
.rs-acct-fanout {
  padding: 0.7em 0.9em;
  background: color-mix(in srgb, var(--accent) 4%, var(--surface));
  border: 1px solid var(--border); border-radius: 6px;
}
.rs-acct-fanout-label { margin: 0 0 0.5em; font-size: 0.85em; color: var(--muted); }
.rs-acct-fanout-options { display: flex; flex-wrap: wrap; gap: 0.4em; }
.rs-acct-fanout-chip {
  display: inline-flex; align-items: center; gap: 0.35em;
  padding: 0.25em 0.7em; border: 1px solid var(--border);
  border-radius: 999px; background: var(--surface);
  font-size: 0.85em; cursor: pointer; user-select: none;
}
.rs-acct-fanout-chip:has(input:checked) {
  background: color-mix(in srgb, var(--accent) 15%, var(--surface));
  border-color: var(--accent);
}
.rs-acct-fanout-chip input { margin: 0; }
.rs-acct-net-badge {
  display: inline-block; padding: 0.15em 0.55em; border-radius: 4px;
  font-size: 0.8em; font-weight: 600; color: #fff;
  background: #888;
}
.rs-acct-net-fediverse { background: #6364ff; }
.rs-acct-net-bluesky { background: #1185fe; }
.rs-acct-net-reddit { background: #ff4500; }
.rs-acct-fanout-pill {
  display: inline-block; padding: 0.1em 0.5em;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  border-radius: 3px; font-size: 0.78em; margin-right: 0.25em;
}
.rs-acct-status { display: inline-flex; align-items: center; gap: 0.3em; font-size: 0.85em; }
.rs-acct-status .material-symbols-outlined { font-size: 1.1em; }
.rs-acct-status-ok { color: #2ecc71; }
.rs-acct-status-error { color: #c0392b; }
.rs-acct-status-off { color: var(--muted); }
.btn-link {
  background: transparent; border: none; color: var(--muted);
  cursor: pointer; padding: 0.25em; border-radius: 4px;
  display: inline-flex; align-items: center;
}
.btn-link:hover { color: var(--accent); background: color-mix(in srgb, var(--accent) 8%, transparent); }

.rs-post-source {
  display: inline-flex; align-items: center; gap: 0.25em;
  font-size: 0.75em; padding: 0.12em 0.5em; border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: var(--text);
}
.rs-post-source-auto { background: color-mix(in srgb, #2ecc71 18%, transparent); }
.rs-post-source-backfill { background: color-mix(in srgb, #f59e0b 18%, transparent); }
.rs-post-content {
  margin: 0.6em 0 0; padding: 0.5em 0.8em;
  font-size: 0.9em; color: var(--muted);
  border-left: 3px solid var(--border);
  background: color-mix(in srgb, var(--accent) 3%, transparent);
  border-radius: 0 4px 4px 0;
  white-space: pre-wrap; word-break: break-word;
}

/* ===== Filtres Publications RS ===== */
.rs-post-filters {
  display: flex; flex-direction: column; gap: 0.5em;
  margin-bottom: 1em; padding: 0.7em 0.9em;
  background: color-mix(in srgb, var(--accent) 3%, var(--surface));
  border: 1px solid var(--border); border-radius: 8px;
}
.rs-post-filters-row {
  display: flex; align-items: center; gap: 0.5em; flex-wrap: wrap;
}
.rs-post-filters-label {
  font-size: 0.85em; color: var(--muted); margin-right: 0.4em;
}
.rs-post-filter-chip {
  display: inline-flex; align-items: center; gap: 0.35em;
  padding: 0.25em 0.75em; border: 1px solid var(--border);
  border-radius: 999px; background: var(--surface); color: var(--text);
  font: inherit; font-size: 0.85em; cursor: pointer;
}
.rs-post-filter-chip:hover { border-color: var(--accent); }
.rs-post-filter-chip.is-active {
  background: color-mix(in srgb, var(--chip-color, var(--accent)) 15%, var(--surface));
  border-color: var(--chip-color, var(--accent));
}
.rs-post-filter-chip.is-all.is-active {
  background: color-mix(in srgb, var(--accent) 15%, var(--surface));
  border-color: var(--accent);
}
.rs-post-filter-dot {
  width: 0.7em; height: 0.7em; border-radius: 50%; display: inline-block;
}
.rs-post-filter-count {
  font-size: 0.75em; color: var(--muted); margin-left: 0.15em;
  padding-left: 0.4em; border-left: 1px solid var(--border);
}
.rs-post-filter-toggle {
  display: inline-flex; align-items: center; gap: 0.4em;
  font-size: 0.85em; color: var(--text); cursor: pointer;
}

/* =====================================================================
   Modernisation Comptes RS / Publications RS (v1.5.4)
   ===================================================================== */

/* ---- Page hero (en-tête avec icône) ---- */
.rs-page-hero {
  display: flex; align-items: center; gap: 1.2em;
  padding: 1.5em 1.6em;
  margin-bottom: 1.4em;
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--accent) 8%, var(--surface)),
    color-mix(in srgb, var(--accent) 3%, var(--surface)));
  border: 1px solid color-mix(in srgb, var(--accent) 20%, var(--border));
  border-radius: 14px;
  position: relative;
  overflow: hidden;
}
.rs-page-hero::after {
  content: ''; position: absolute; top: -40%; right: -10%;
  width: 240px; height: 240px;
  background: radial-gradient(circle, color-mix(in srgb, var(--accent) 15%, transparent) 0%, transparent 70%);
  pointer-events: none;
}
.rs-page-hero-icon {
  flex: 0 0 56px; width: 56px; height: 56px;
  border-radius: 14px;
  background: var(--hero-color, var(--accent));
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 6px 18px color-mix(in srgb, var(--hero-color, var(--accent)) 35%, transparent);
  position: relative; z-index: 1;
}
.rs-page-hero-icon .material-symbols-outlined {
  font-size: 30px; color: #fff;
}
.rs-page-hero-text { flex: 1 1 auto; min-width: 0; }
.rs-page-hero-text h2 { margin: 0 0 0.2em; font-size: 1.4em; }
.rs-page-hero-text p { margin: 0; color: var(--muted); line-height: 1.5; }
.rs-page-hero-actions {
  display: flex; gap: 0.5em; flex-wrap: wrap;
  position: relative; z-index: 1;
}
@media (max-width: 720px) {
  .rs-page-hero { flex-direction: column; align-items: flex-start; padding: 1.1em; }
  .rs-page-hero-actions { width: 100%; }
}

/* ---- Form fields modernisés ---- */
.rs-field {
  display: flex; flex-direction: column; gap: 0.35em;
  font-size: 0.85em; color: var(--muted);
  flex: 0 1 auto;
}
.rs-field.grow { flex: 1 1 280px; }
.rs-field-label {
  display: inline-flex; align-items: center; gap: 0.35em;
  font-weight: 500;
}
.rs-field-label .material-symbols-outlined {
  font-size: 1.05em; color: var(--accent);
}
.rs-field input,
.rs-field select {
  font: inherit;
  padding: 0.55em 0.8em;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface);
  color: var(--text);
  min-width: 200px;
  transition: border-color 120ms, box-shadow 120ms, transform 80ms;
}
.rs-field input:focus,
.rs-field select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 18%, transparent);
}
.rs-field input::placeholder { color: color-mix(in srgb, var(--muted) 60%, transparent); }

/* ---- Chips réseau (cocher pour activer un réseau avec sa brand color) ---- */
.net-chip {
  --net-color: #888;
  display: inline-flex; align-items: center; gap: 0.4em;
  padding: 0.45em 0.85em;
  border: 1.5px solid color-mix(in srgb, var(--net-color) 35%, var(--border));
  border-radius: 999px;
  background: var(--surface);
  font-size: 0.88em;
  cursor: pointer;
  user-select: none;
  transition: all 140ms ease;
  position: relative;
}
.net-chip:hover {
  border-color: var(--net-color);
  transform: translateY(-1px);
  box-shadow: 0 3px 10px color-mix(in srgb, var(--net-color) 18%, transparent);
}
.net-chip input { position: absolute; opacity: 0; pointer-events: none; }
.net-chip-dot {
  width: 0.7em; height: 0.7em; border-radius: 50%;
  background: var(--net-color);
  flex-shrink: 0;
  transition: transform 140ms;
}
.net-chip-label { font-weight: 500; }
.net-chip-check {
  font-size: 1.1em; opacity: 0; width: 0; overflow: hidden;
  transition: opacity 140ms, width 140ms;
  color: var(--net-color);
}
.net-chip:has(input:checked) {
  background: color-mix(in srgb, var(--net-color) 14%, var(--surface));
  border-color: var(--net-color);
  color: var(--text);
}
.net-chip:has(input:checked) .net-chip-dot {
  transform: scale(1.3);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--net-color) 25%, transparent);
}
.net-chip:has(input:checked) .net-chip-check {
  opacity: 1; width: 1.1em;
}

/* ---- Bloc fanout (header + chips) ---- */
.rs-acct-fanout {
  padding: 0.95em 1.1em;
  background: color-mix(in srgb, var(--accent) 3%, var(--surface));
  border: 1px solid var(--border);
  border-radius: 12px;
}
.rs-acct-fanout-label {
  display: flex; align-items: center; gap: 0.4em; flex-wrap: wrap;
  margin: 0 0 0.7em; font-size: 0.92em; font-weight: 500;
}
.rs-acct-fanout-label .material-symbols-outlined {
  color: var(--accent); font-size: 1.15em;
}
.rs-acct-fanout-options {
  display: flex; flex-wrap: wrap; gap: 0.4em;
}

/* ---- Badge réseau coloré ---- */
.net-badge {
  display: inline-flex; align-items: center;
  padding: 0.25em 0.75em;
  border-radius: 6px;
  color: #fff;
  font-size: 0.78em; font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: lowercase;
  text-shadow: 0 1px 1px rgba(0,0,0,0.2);
}
/* Snapchat jaune → texte foncé */
.net-badge[style*="#fffc00"] { color: #1a1a1a; text-shadow: none; }

/* Pill colorée petite (fanout list dans une card) */
.net-pill {
  --net-color: #888;
  display: inline-flex; align-items: center; gap: 0.3em;
  padding: 0.15em 0.55em;
  font-size: 0.78em;
  border-radius: 5px;
  background: color-mix(in srgb, var(--net-color) 14%, transparent);
  color: var(--text);
  border: 1px solid color-mix(in srgb, var(--net-color) 30%, transparent);
}
.net-pill-dot {
  width: 0.55em; height: 0.55em; border-radius: 50%;
  background: var(--net-color);
}

/* ---- Card "Ajouter un compte" ---- */
.rs-add-card {
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 2%, var(--surface)) 0%, var(--surface) 100%);
}

/* ---- Grille de cards compte ---- */
.rs-acct-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 1em;
}
.rs-acct-card {
  --net-color: #888;
  display: flex; flex-direction: column; gap: 0.6em;
  padding: 1em 1.1em;
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 4px solid var(--net-color);
  border-radius: 10px;
  position: relative;
  transition: transform 120ms, box-shadow 120ms, border-color 120ms;
}
.rs-acct-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 14px color-mix(in srgb, var(--net-color) 12%, transparent);
}
.rs-acct-card.is-disabled { opacity: 0.6; }
.rs-acct-card.has-error { border-left-color: #c0392b; }
.rs-acct-card-top {
  display: flex; align-items: center; justify-content: space-between; gap: 0.5em;
}
.rs-acct-handle {
  font-size: 0.95em;
  padding: 0.35em 0.6em;
  background: color-mix(in srgb, var(--net-color) 5%, transparent);
  border-radius: 6px;
  word-break: break-all;
  border: 1px solid color-mix(in srgb, var(--net-color) 20%, transparent);
  align-self: flex-start;
  max-width: 100%;
}
.rs-acct-fanout-list {
  display: flex; align-items: center; gap: 0.35em; flex-wrap: wrap;
  padding: 0.45em 0;
  border-top: 1px dashed var(--border);
  border-bottom: 1px dashed var(--border);
}
.rs-acct-fanout-arrow {
  font-size: 1em !important; color: var(--muted);
}
.rs-acct-card-meta {
  display: inline-flex; align-items: center; gap: 0.4em;
  font-size: 0.82em; color: var(--muted);
}
.rs-acct-card-meta .material-symbols-outlined {
  font-size: 1.05em;
}
.rs-acct-card-actions {
  display: flex; gap: 0.3em; margin-top: auto;
  padding-top: 0.6em;
  border-top: 1px solid var(--border);
}
.rs-acct-card-actions form { display: contents; }

/* ---- Icon button (action sur une card) ---- */
.icon-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 8px;
  color: var(--muted);
  cursor: pointer;
  transition: all 120ms;
  font: inherit;
}
.icon-btn:hover {
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  border-color: color-mix(in srgb, var(--accent) 25%, transparent);
  color: var(--accent);
}
.icon-btn .material-symbols-outlined { font-size: 1.15em; }
.icon-btn-danger:hover {
  background: color-mix(in srgb, #c0392b 12%, transparent);
  border-color: color-mix(in srgb, #c0392b 30%, transparent);
  color: #c0392b;
}

/* ---- Status badges modernes ---- */
.rs-acct-status {
  display: inline-flex; align-items: center; gap: 0.3em;
  padding: 0.2em 0.55em;
  border-radius: 999px;
  font-size: 0.78em; font-weight: 500;
}
.rs-acct-status .material-symbols-outlined { font-size: 1.1em; }
.rs-acct-status-ok {
  background: color-mix(in srgb, #2ecc71 14%, transparent);
  color: #1e8a4a;
  border: 1px solid color-mix(in srgb, #2ecc71 30%, transparent);
}
.rs-acct-status-error {
  background: color-mix(in srgb, #c0392b 14%, transparent);
  color: #c0392b;
  border: 1px solid color-mix(in srgb, #c0392b 30%, transparent);
}
.rs-acct-status-off {
  background: color-mix(in srgb, var(--muted) 15%, transparent);
  color: var(--muted);
  border: 1px solid color-mix(in srgb, var(--muted) 25%, transparent);
}

/* ---- Card info (astuce) ---- */
.rs-info-card {
  display: flex; gap: 1em; align-items: flex-start;
  border-left: 4px solid var(--accent);
}
.rs-info-icon {
  flex: 0 0 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  background: color-mix(in srgb, var(--accent) 15%, transparent);
  border-radius: 10px;
}
.rs-info-icon .material-symbols-outlined { color: var(--accent); font-size: 22px; }
.inline-icon { vertical-align: middle; font-size: 1.05em !important; color: var(--accent); }

/* ---- Form actions ---- */
.rs-post-form-actions {
  display: flex; justify-content: flex-end; gap: 0.5em;
}

/* ---- Cleanup : neutralise les anciennes classes qu'on a remplacées ---- */
.rs-acct-fanout-chip { /* compatibilité, ne pas styler ; remplacée par .net-chip */ }

/* ---- Form moderne, container global ---- */
.rs-acct-form { display: flex; flex-direction: column; gap: 1em; }
.rs-acct-form-row { display: flex; gap: 0.8em; flex-wrap: wrap; }

/* ---- Publications RS : card form plus moderne ---- */
.rs-post-form {
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 4%, var(--surface)) 0%, var(--surface) 100%);
  border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--border));
  border-radius: 12px;
  padding: 1.1em 1.2em;
}


/* =====================================================================
   Graphiques Publications RS modernisés (HTML+CSS, hover, axe horaire)
   ===================================================================== */

.rs-post-charts {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 1.2em;
  margin-top: 0.8em;
}
.rs-post-chart-label {
  display: inline-flex; align-items: center; gap: 0.35em;
  font-size: 0.82em; color: var(--muted);
  margin-bottom: 0.5em;
}
.rs-post-chart-label .material-symbols-outlined {
  font-size: 1.05em; color: var(--accent);
}

/* ----- Chart par jour (J+0 → J+6) ----- */
.rs-day-chart {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
  align-items: stretch;
}
.rs-day-col {
  display: flex; flex-direction: column; align-items: center;
  cursor: default;
  min-width: 0;
}
.rs-day-value {
  font-size: 0.78em; font-weight: 600;
  color: var(--text);
  margin-bottom: 0.2em;
  min-height: 1.1em;
}
.rs-day-track {
  width: 100%;
  height: 70px;
  background: color-mix(in srgb, var(--accent) 4%, transparent);
  border-radius: 4px 4px 0 0;
  display: flex; align-items: flex-end;
  overflow: hidden;
  transition: background 120ms;
}
.rs-day-col:hover .rs-day-track {
  background: color-mix(in srgb, var(--accent) 8%, transparent);
}
.rs-day-bar {
  width: 100%;
  min-height: 1px;
  opacity: 0.85;
  border-radius: 3px 3px 0 0;
  transition: opacity 120ms;
}
.rs-day-col:hover .rs-day-bar { opacity: 1; }
.rs-day-label {
  font-size: 0.72em;
  color: var(--muted);
  margin-top: 0.3em;
}

/* ----- Chart heure par heure (24 h) ----- */
.rs-hour-chart {
  display: flex;
  align-items: flex-end;
  gap: 1px;
  height: 60px;
  padding: 0 1px;
  border-bottom: 1px solid var(--border);
}
.rs-hour-col {
  flex: 1; min-width: 0;
  height: 100%;
  display: flex; align-items: flex-end;
  cursor: default;
  position: relative;
}
.rs-hour-col:hover::before {
  content: '';
  position: absolute; inset: 0;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  pointer-events: none;
  border-radius: 2px;
}
.rs-hour-bar {
  width: 100%;
  min-height: 1px;
  opacity: 0.7;
  border-radius: 2px 2px 0 0;
  transition: opacity 120ms;
}
.rs-hour-col:hover .rs-hour-bar { opacity: 1; }
.rs-hour-axis {
  display: flex; justify-content: space-between;
  font-size: 0.7em;
  color: var(--muted);
  margin-top: 0.3em;
  padding: 0 1px;
}

/* ----- Mobile : empilage + plus de respiration tactile ----- */
@media (max-width: 720px) {
  .rs-post-charts {
    grid-template-columns: 1fr;
    gap: 0.9em;
  }
  .rs-day-chart { gap: 3px; }
  .rs-day-track { height: 60px; }
  .rs-day-value { font-size: 0.72em; }
  .rs-hour-chart { height: 48px; }
  .rs-hour-axis { font-size: 0.65em; }
  /* Cards comptes : full-width sur mobile */
  .rs-acct-grid { grid-template-columns: 1fr; }
  .rs-acct-card-actions { justify-content: flex-end; }
  /* Header rs : pile actions sous le texte */
  .rs-page-hero { gap: 0.9em; }
  .rs-page-hero-icon { flex: 0 0 44px; width: 44px; height: 44px; }
  .rs-page-hero-icon .material-symbols-outlined { font-size: 24px; }
  /* Form chips : touch-friendly */
  .net-chip {
    padding: 0.55em 0.95em;
    font-size: 0.9em;
  }
  .net-chip-dot { width: 0.8em; height: 0.8em; }
  .rs-acct-fanout { padding: 0.85em 1em; }
  /* Bloc filtres : empilé */
  .rs-post-filters-row { gap: 0.35em; }
  .rs-post-filter-chip { font-size: 0.82em; }
  /* Liste publications RS : adapte les colonnes */
  .rs-post-head { gap: 0.6em; }
  .rs-post-totals {
    width: 100%; margin-left: 0;
    padding-top: 0.4em;
    border-top: 1px dashed var(--border);
  }
  .rs-post-delete { margin-left: auto; }
}

/* ----- Anciennes classes (back-compat, masque les rendus obsolètes) ----- */
.rs-post-bars, .rs-post-spark, .rs-post-bars-labels { display: none; }


/* ===== Marqueurs verticaux sur les charts (autres posts dans la fenêtre) ===== */
.rs-day-chart-wrap, .rs-hour-chart-wrap {
  position: relative;
}
.rs-chart-marker {
  position: absolute;
  top: 0;
  width: 0;
  pointer-events: auto;
  z-index: 2;
  cursor: help;
}
.rs-chart-marker::before {
  content: '';
  position: absolute;
  top: 0; left: -1px;
  width: 2px; height: 100%;
  background: #c0392b;
  opacity: 0.55;
  border-radius: 1px;
  transition: opacity 120ms;
}
.rs-chart-marker::after {
  content: '';
  position: absolute;
  top: -4px; left: -4px;
  width: 10px; height: 10px;
  background: #c0392b;
  border: 2px solid var(--surface);
  border-radius: 50%;
  box-shadow: 0 0 0 1px #c0392b;
  transition: transform 120ms;
}
.rs-chart-marker:hover::before { opacity: 0.95; }
.rs-chart-marker:hover::after { transform: scale(1.2); }

/* Marqueur sur chart 7 j : couvre toute la hauteur de la track (≈ 110px avec
   valeurs + barre + label), mais on stoppe avant le label inférieur. */
.rs-chart-marker-day {
  height: calc(100% - 1.5em);
  top: 0;
}
/* Marqueur sur chart 24h : juste la hauteur de la barre (60px) */
.rs-chart-marker-hour {
  height: 100%;
}

@media (max-width: 720px) {
  .rs-chart-marker::after {
    width: 8px; height: 8px; top: -3px; left: -3px;
  }
}

/* =====================================================================
   Checkboxes modernes (style par défaut, via :where pour spécificité=0
   → toutes les checkbox custom existantes (.net-chip, .optout-toggle, …)
   gardent leur skin via leur propre règle plus spécifique).
   ===================================================================== */
:where(input[type="checkbox"]) {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  width: 18px;
  height: 18px;
  margin: 0;
  border: 1.5px solid var(--border);
  border-radius: 5px;
  background: var(--surface);
  cursor: pointer;
  position: relative;
  display: inline-block;
  vertical-align: -4px;
  flex-shrink: 0;
  transition: border-color 0.15s, background-color 0.15s, box-shadow 0.15s;
}
:where(input[type="checkbox"]):hover {
  border-color: color-mix(in srgb, var(--accent) 60%, var(--border));
}
:where(input[type="checkbox"]):focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 30%, transparent);
}
:where(input[type="checkbox"]):checked {
  background: var(--accent);
  border-color: var(--accent);
}
:where(input[type="checkbox"]):checked::after {
  content: '';
  position: absolute;
  left: 5px;
  top: 1px;
  width: 5px;
  height: 10px;
  border: solid #fff;
  border-width: 0 2.2px 2.2px 0;
  transform: rotate(42deg);
}
:where(input[type="checkbox"]):disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* ===== Période & filtres rétractable ===== */
.dashboard-toolbar-wrap {
  margin: 0.8em 0 1.2em;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg-secondary);
}
.dashboard-toolbar-summary {
  display: flex;
  align-items: center;
  gap: 0.6em;
  padding: 0.7em 1em;
  cursor: pointer;
  list-style: none;
  font-weight: 500;
  color: var(--text-primary);
}
.dashboard-toolbar-summary::-webkit-details-marker { display: none; }
.dashboard-toolbar-summary > .material-symbols-outlined { font-size: 18px; color: var(--accent); }
.dashboard-toolbar-summary-label { white-space: nowrap; }
.dashboard-toolbar-summary-current {
  flex: 1;
  font-weight: 400;
  font-size: 0.88em;
  color: var(--text-secondary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}
.dashboard-toolbar-summary-current strong {
  color: var(--text-primary);
  font-weight: 600;
}
.dashboard-toolbar-summary-current code {
  background: color-mix(in srgb, var(--text-primary) 6%, transparent);
  padding: 0 0.35em;
  border-radius: 3px;
  font-size: 0.9em;
}
.dashboard-toolbar-summary-chevron {
  transition: transform 0.15s;
}
.dashboard-toolbar-wrap[open] .dashboard-toolbar-summary-chevron {
  transform: rotate(180deg);
}
.dashboard-toolbar-wrap[open] .dashboard-toolbar-summary {
  border-bottom: 1px solid var(--border);
}
.dashboard-toolbar-wrap .dashboard-toolbar {
  padding: 0.8em 1em 1em;
  margin: 0;
}

@media (max-width: 720px) {
  .dashboard-toolbar-summary { padding: 0.65em 0.8em; }
  .dashboard-toolbar-summary-current { font-size: 0.82em; }
}

/* ===== Backfill avec datetime "depuis" (popover details) ===== */
.rs-acct-backfill {
  position: relative;
  display: inline-block;
}
.rs-acct-backfill > summary {
  list-style: none;
}
.rs-acct-backfill > summary::-webkit-details-marker { display: none; }
.rs-acct-backfill-form {
  position: absolute;
  z-index: 30;
  top: calc(100% + 0.3em);
  right: 0;
  min-width: 280px;
  padding: 0.8em;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: 0 6px 22px color-mix(in srgb, var(--text-primary) 18%, transparent);
  display: flex;
  flex-direction: column;
  gap: 0.6em;
}
.rs-acct-backfill-label {
  display: flex;
  flex-direction: column;
  gap: 0.3em;
  font-size: 0.85em;
  color: var(--muted);
}
.rs-acct-backfill-label input {
  font: inherit;
  padding: 0.4em 0.6em;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--bg);
  color: var(--text);
}
.rs-acct-backfill-form .btn-sm {
  align-self: flex-end;
  display: inline-flex;
  align-items: center;
  gap: 0.25em;
}

/* ===== Vue Comparer les campagnes (v1.5.12) ===== */
.cmp-ref-form {
  display: flex; align-items: center; gap: 0.8em; flex-wrap: wrap;
}
.cmp-ref-field {
  display: flex; flex-direction: column; gap: 0.3em;
  min-width: 280px;
}
.cmp-ref-field select {
  font: inherit;
  padding: 0.5em 0.7em;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
  color: var(--text);
}
.cmp-ref-badge {
  display: inline-block;
  padding: 0.05em 0.45em;
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  color: var(--accent);
  border-radius: 3px;
  font-size: 0.78em;
  font-weight: 600;
  margin-left: 0.3em;
}
.cmp-row-ref { background: color-mix(in srgb, var(--accent) 4%, transparent); }
.cmp-report-btn {
  display: inline-flex !important; align-items: center; gap: 0.3em;
  white-space: nowrap;
}
.cmp-report-btn .material-symbols-outlined { font-size: 1.05em; }

.cmp-report-promo {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 1.2em;
  align-items: center;
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--accent) 8%, var(--surface)),
    color-mix(in srgb, var(--accent) 3%, var(--surface)));
  border: 1px solid color-mix(in srgb, var(--accent) 22%, var(--border));
}
.cmp-report-promo-icon {
  width: 56px; height: 56px;
  border-radius: 14px;
  background: var(--accent);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 6px 18px color-mix(in srgb, var(--accent) 35%, transparent);
}
.cmp-report-promo-icon .material-symbols-outlined { color: #fff; font-size: 32px; }
.cmp-report-promo-body .card-title { margin: 0 0 0.25em; }
.cmp-report-promo-body p { margin: 0; }
.cmp-report-promo-action .btn { display: inline-flex; align-items: center; gap: 0.35em; }
@media (max-width: 720px) {
  .cmp-report-promo { grid-template-columns: 1fr; text-align: center; }
  .cmp-report-promo-icon { margin: 0 auto; }
}

/* ===== Section "Impact RS" sur la vue Comparer ===== */
.rsimpact-list {
  list-style: none; margin: 1em 0 0; padding: 0;
  display: flex; flex-direction: column; gap: 0.7em;
}
.rsimpact-row {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 1em;
  align-items: center;
}
.rsimpact-head {
  display: flex; flex-direction: column; gap: 0.2em;
}
.rsimpact-badge {
  display: inline-block;
  padding: 0.2em 0.6em;
  border-radius: 5px;
  color: #fff;
  font-size: 0.78em;
  font-weight: 600;
  text-shadow: 0 1px 1px rgba(0,0,0,0.25);
  align-self: flex-start;
}
.rsimpact-badge[style*="#fffc00"] { color: #1a1a1a; text-shadow: none; }
.rsimpact-total { font-size: 0.85em; color: var(--muted); }
.rsimpact-total strong { color: var(--text); font-size: 1.05em; }
.rsimpact-frize {
  display: flex; align-items: flex-end; gap: 1px;
  height: 48px;
  background: color-mix(in srgb, var(--text-primary) 3%, transparent);
  border-radius: 4px;
  padding: 2px;
  position: relative;
}
.rsimpact-col {
  flex: 1; min-width: 0;
  height: 100%;
  display: flex; align-items: flex-end;
  position: relative;
  cursor: default;
}
.rsimpact-col:hover { background: color-mix(in srgb, var(--accent) 10%, transparent); }
.rsimpact-bar {
  width: 100%; min-height: 1px; opacity: 0.85;
  border-radius: 1px 1px 0 0;
}
.rsimpact-post-marker {
  position: absolute;
  top: -2px; left: 50%;
  transform: translateX(-50%);
  width: 7px; height: 7px;
  background: #c0392b;
  border: 1.5px solid var(--surface);
  border-radius: 50%;
  box-shadow: 0 0 0 1px #c0392b;
  z-index: 2;
}
.rsimpact-post-marker[data-multi]::after {
  content: attr(data-multi);
  position: absolute;
  top: -6px; left: 50%;
  transform: translateX(-50%);
  font-size: 0.65em;
  font-weight: 700;
  color: #c0392b;
}
.rsimpact-axis {
  display: flex; justify-content: space-between;
  font-size: 0.72em; color: var(--muted);
  margin-top: 0.4em;
  padding-left: 190px;
}
.rsimpact-legend {
  margin: 0.6em 0 0;
  display: inline-flex; align-items: center; gap: 0.4em;
}
.rsimpact-marker-legend {
  display: inline-block;
  width: 7px; height: 7px;
  background: #c0392b; border-radius: 50%;
  box-shadow: 0 0 0 1px #c0392b;
}

/* Camembert (vue liste horizontale plutôt qu'un vrai donut) */
.rsimpact-cam-list {
  list-style: none; margin: 0.8em 0 0; padding: 0;
  display: flex; flex-direction: column; gap: 0.4em;
}
.rsimpact-cam-row {
  display: grid;
  grid-template-columns: 160px 1fr 5em 6em;
  gap: 0.6em;
  align-items: center;
  font-size: 0.9em;
}
.rsimpact-cam-label {
  display: inline-flex; align-items: center; gap: 0.4em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.rsimpact-cam-dot {
  width: 11px; height: 11px; border-radius: 3px; flex-shrink: 0;
}
.rsimpact-cam-bar-wrap {
  height: 16px;
  background: color-mix(in srgb, var(--text-primary) 4%, transparent);
  border-radius: 3px;
  overflow: hidden;
}
.rsimpact-cam-bar {
  display: block; height: 100%;
  opacity: 0.8;
  border-radius: 3px;
}
.rsimpact-cam-pct { text-align: right; font-variant-numeric: tabular-nums; font-weight: 600; }
.rsimpact-cam-hits { text-align: right; font-variant-numeric: tabular-nums; }

@media (max-width: 720px) {
  .rsimpact-row { grid-template-columns: 1fr; gap: 0.4em; }
  .rsimpact-axis { padding-left: 0; }
  .rsimpact-cam-row { grid-template-columns: 1fr 4em 5em; }
  .rsimpact-cam-bar-wrap { grid-column: 1 / -1; }
}

/* ===== Slideshow campagne plein écran (v1.5.13) =====
   Couvre toute la viewport via position:fixed pour donner une vraie sensation
   de "présentation", indépendamment de la sidebar admin. Sortie via croix
   en haut-droite ou Esc. */
.slideshow-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background:
    radial-gradient(ellipse at top left, color-mix(in srgb, var(--accent) 12%, var(--bg)) 0%, var(--bg) 60%),
    var(--bg);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  font-family: 'Trebuchet MS', sans-serif;
}
.slideshow-topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0.6em 1em;
  border-bottom: 1px solid color-mix(in srgb, var(--text-primary) 8%, transparent);
  flex: 0 0 auto;
}
.slideshow-brand {
  display: inline-flex; align-items: center; gap: 0.4em;
  font-size: 0.85em; color: var(--muted);
}
.slideshow-brand .material-symbols-outlined { color: var(--accent); }
.slideshow-counter { color: var(--muted); font-size: 0.9em; }
.slideshow-close {
  width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 8px;
  color: var(--muted);
  background: transparent;
  border: 1px solid transparent;
  transition: all 0.12s;
}
.slideshow-close:hover {
  background: color-mix(in srgb, #c0392b 12%, transparent);
  color: #c0392b;
  border-color: color-mix(in srgb, #c0392b 30%, transparent);
}
.slideshow-track {
  flex: 1 1 auto;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.slide {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 2.5em 4em;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s;
}
.slide.is-active { opacity: 1; pointer-events: auto; }

.slide-h2 {
  font-size: 2em;
  font-weight: 600;
  text-align: center;
  margin: 0 0 1.5em;
  color: var(--text-primary);
}
.slide-empty { font-size: 1.3em; color: var(--muted); }

/* Slide 1 : couverture */
.slide-cover-inner { text-align: center; max-width: 900px; }
.slide-eyebrow {
  text-transform: uppercase; letter-spacing: 0.18em;
  font-size: 0.95em; color: var(--accent); font-weight: 600;
  margin-bottom: 0.8em;
}
.slide-title {
  font-size: clamp(2.4em, 5vw, 4em);
  font-weight: 700;
  margin: 0 0 0.7em;
  line-height: 1.1;
  color: var(--text-primary);
}
.slide-subtitle {
  display: flex; flex-wrap: wrap; gap: 0.6em;
  justify-content: center; margin-bottom: 2.5em;
}
.slide-pill {
  display: inline-block;
  padding: 0.4em 0.9em;
  background: color-mix(in srgb, var(--text-primary) 8%, transparent);
  border-radius: 999px;
  font-size: 0.95em;
  color: var(--text-secondary);
}
.slide-pill-accent {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  color: var(--accent);
  font-weight: 600;
}
.slide-pill-accent code { font-family: 'Trebuchet MS', sans-serif; font-weight: 700; }
.slide-cover-hero { margin-top: 1em; }
.slide-cover-hero-number {
  font-size: clamp(4em, 12vw, 9em);
  font-weight: 700;
  color: var(--accent);
  line-height: 1;
  font-variant-numeric: tabular-nums;
  text-shadow: 0 8px 32px color-mix(in srgb, var(--accent) 35%, transparent);
}
.slide-cover-hero-label {
  font-size: 1.4em;
  color: var(--text-secondary);
  margin-top: 0.4em;
  text-transform: lowercase;
  letter-spacing: 0.05em;
}

/* Slide KPI */
.slide-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5em;
  width: 100%;
  max-width: 1100px;
}
.slide-kpi-card {
  padding: 2em 1em;
  background: color-mix(in srgb, var(--accent) 6%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--border));
  border-radius: 16px;
  text-align: center;
}
.slide-kpi-icon { color: var(--accent); margin-bottom: 0.5em; }
.slide-kpi-icon .material-symbols-outlined { font-size: 2.2em; }
.slide-kpi-value {
  font-size: clamp(2em, 4vw, 3em);
  font-weight: 700;
  color: var(--accent);
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
}
.slide-kpi-label {
  margin-top: 0.5em;
  color: var(--text-secondary);
  font-size: 1em;
}

/* Slide chart bar */
.slide-bar-chart {
  display: flex; align-items: flex-end; gap: 3px;
  width: 100%; max-width: 1100px;
  height: 50vh; max-height: 400px;
  padding: 1em 0;
  border-bottom: 2px solid var(--border);
}
.slide-bar-col {
  flex: 1; min-width: 0; height: 100%;
  display: flex; align-items: flex-end;
}
.slide-bar {
  width: 100%; min-height: 2px;
  background: var(--accent);
  border-radius: 4px 4px 0 0;
  opacity: 0.85;
  transition: opacity 0.12s;
}
.slide-bar-col:hover .slide-bar { opacity: 1; }
.slide-bar-axis {
  display: flex; justify-content: space-between;
  width: 100%; max-width: 1100px;
  margin-top: 0.5em;
  font-size: 0.9em;
  color: var(--muted);
}

/* Slide sources */
.slide-sources-list {
  list-style: none; margin: 0; padding: 0;
  width: 100%; max-width: 900px;
  display: flex; flex-direction: column;
  gap: 0.55em;
}
.slide-source-row {
  display: grid;
  grid-template-columns: 220px 1fr 5em 6em;
  gap: 0.8em;
  align-items: center;
  font-size: 1.1em;
}
.slide-source-label {
  display: inline-flex; align-items: center; gap: 0.5em;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.slide-source-dot {
  width: 12px; height: 12px; border-radius: 4px;
  flex-shrink: 0;
}
.slide-source-bar-wrap {
  height: 20px;
  background: color-mix(in srgb, var(--text-primary) 5%, transparent);
  border-radius: 4px;
  overflow: hidden;
}
.slide-source-bar { display: block; height: 100%; border-radius: 4px; opacity: 0.85; }
.slide-source-pct {
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-weight: 700;
  color: var(--accent);
}
.slide-source-hits {
  text-align: right;
  font-variant-numeric: tabular-nums;
  color: var(--muted);
}

/* Slide top posts */
.slide-topposts-list {
  list-style: none; margin: 0; padding: 0;
  counter-reset: slide-toppost;
  width: 100%; max-width: 900px;
  display: flex; flex-direction: column; gap: 0.6em;
}
.slide-toppost {
  counter-increment: slide-toppost;
  display: grid;
  grid-template-columns: auto 200px 1fr auto;
  gap: 1em;
  align-items: center;
  padding: 1em 1.2em;
  background: color-mix(in srgb, var(--accent) 4%, transparent);
  border: 1px solid var(--border);
  border-radius: 12px;
  font-size: 1.05em;
}
.slide-toppost::before {
  content: counter(slide-toppost);
  display: inline-flex; align-items: center; justify-content: center;
  width: 2em; height: 2em;
  background: var(--accent);
  color: #fff;
  border-radius: 50%;
  font-weight: 700;
}
.slide-toppost-badge {
  display: inline-block;
  padding: 0.25em 0.7em;
  border-radius: 6px;
  color: #fff;
  font-size: 0.85em;
  font-weight: 600;
  text-shadow: 0 1px 1px rgba(0,0,0,0.2);
  white-space: nowrap;
}
.slide-toppost-date { color: var(--muted); font-size: 0.95em; }
.slide-toppost-hits { text-align: right; }
.slide-toppost-hits strong { color: var(--accent); font-size: 1.2em; }

/* Slide outro */
.slide-outro-inner { text-align: center; max-width: 700px; }
.slide-outro-icon {
  width: 80px; height: 80px;
  margin: 0 auto 1em;
  background: color-mix(in srgb, #e91e63 14%, transparent);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.slide-outro-icon .material-symbols-outlined { font-size: 44px; color: #e91e63; }
.slide-h2-outro {
  font-size: 2.6em; font-weight: 700;
  margin: 0 0 0.8em;
}
.slide-outro-sub { font-size: 1.2em; line-height: 1.6; color: var(--text-secondary); }
.slide-outro-cta {
  display: inline-flex; align-items: center; gap: 0.4em;
  margin-top: 1.5em;
  padding: 0.7em 1.4em;
  background: var(--accent); color: #fff;
  border-radius: 10px;
  font-weight: 600;
  text-decoration: none;
  transition: transform 0.12s;
}
.slide-outro-cta:hover { transform: translateY(-2px); color: #fff; text-decoration: none; }

/* Nav bar bas */
.slideshow-nav {
  flex: 0 0 auto;
  display: flex; align-items: center; justify-content: center; gap: 1em;
  padding: 0.8em;
  background: color-mix(in srgb, var(--text-primary) 4%, transparent);
  border-top: 1px solid color-mix(in srgb, var(--text-primary) 8%, transparent);
}
.slideshow-arrow {
  width: 44px; height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 50%;
  color: var(--text-primary);
  cursor: pointer;
  transition: all 0.12s;
}
.slideshow-arrow:hover {
  background: var(--accent); color: #fff; border-color: var(--accent);
}
.slideshow-arrow .material-symbols-outlined { font-size: 1.4em; }
.slideshow-dots {
  display: flex; gap: 0.5em;
}
.slideshow-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--text-primary) 18%, transparent);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: all 0.12s;
}
.slideshow-dot:hover { background: color-mix(in srgb, var(--accent) 50%, transparent); }
.slideshow-dot.is-active {
  background: var(--accent);
  transform: scale(1.4);
}

@media (max-width: 720px) {
  .slide { padding: 1.2em; }
  .slide-h2 { font-size: 1.4em; }
  .slide-kpi-grid { grid-template-columns: repeat(2, 1fr); gap: 0.8em; }
  .slide-kpi-card { padding: 1.1em 0.6em; }
  .slide-source-row { grid-template-columns: 1fr 4em 5em; }
  .slide-source-bar-wrap { grid-column: 1 / -1; }
  .slide-toppost { grid-template-columns: auto 1fr auto; font-size: 0.9em; }
  .slide-toppost-date { grid-column: 2; }
  .slide-bar-chart { height: 30vh; }
}

/* ===== Promo "Mode présentation" sur compare view ===== */
.cmp-slideshow-promo {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1.2em;
  align-items: center;
  background: linear-gradient(135deg,
    color-mix(in srgb, #7c3aed 8%, var(--surface)),
    color-mix(in srgb, #7c3aed 2%, var(--surface)));
  border: 1px solid color-mix(in srgb, #7c3aed 22%, var(--border));
}
.cmp-slideshow-icon {
  width: 56px; height: 56px;
  border-radius: 14px;
  background: #7c3aed;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 6px 18px color-mix(in srgb, #7c3aed 35%, transparent);
}
.cmp-slideshow-icon .material-symbols-outlined { color: #fff; font-size: 32px; }
.cmp-slideshow-body .card-title { margin: 0 0 0.25em; }
.cmp-slideshow-body p { margin: 0 0 0.8em; }
.cmp-slideshow-buttons {
  display: flex; gap: 0.5em; flex-wrap: wrap;
}
.cmp-slideshow-buttons .btn {
  display: inline-flex; align-items: center; gap: 0.35em;
}
@media (max-width: 720px) {
  .cmp-slideshow-promo { grid-template-columns: 1fr; text-align: center; }
  .cmp-slideshow-icon { margin: 0 auto; }
  .cmp-slideshow-buttons { justify-content: center; }
}
