/* =============================================================================
   TerraTrack - Dashboard commercial (TD-034)
   Scope strict : nouvel onglet #s-commercial + synthese Bilan.
   ============================================================================= */

#s-commercial {
  background: var(--tt-bg);
}

.commercial-dashboard {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 24px 28px 42px;
}

.commercial-hero,
.commercial-empty {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 20px;
}

.commercial-empty {
  padding: 20px;
  border: 1px solid var(--tt-border);
  border-radius: var(--tt-r-3);
  box-shadow: var(--tt-shadow-1);
  background: var(--tt-surface);
}

.commercial-eyebrow {
  display: block;
  color: var(--tt-accent);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.commercial-hero h2 {
  margin: 4px 0 3px;
  color: var(--tt-fg);
  font-size: 24px;
  line-height: 1.15;
  font-weight: 700;
  letter-spacing: -.01em;
}

.commercial-empty h2 {
  margin: 4px 0 3px;
  color: var(--tt-fg);
  font-size: 24px;
  line-height: 1.15;
  font-weight: 700;
  letter-spacing: -.01em;
}

.commercial-hero p,
.commercial-empty p {
  margin: 0;
  color: var(--tt-fg-3);
  font-size: 13px;
}

.commercial-hero-side {
  padding: 12px 18px;
  border: 1px solid var(--tt-border);
  border-radius: var(--tt-r-3);
  box-shadow: var(--tt-shadow-1);
  background: var(--tt-surface);
  text-align: right;
}

.commercial-hero-side span {
  display: block;
  color: var(--tt-fg-3);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
}

.commercial-hero-side strong {
  display: block;
  margin-top: 2px;
  color: var(--tt-fg);
  font-family: var(--tt-font-mono, ui-monospace);
  font-size: 26px;
  font-weight: 700;
  letter-spacing: -.02em;
}

.commercial-kpis {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 12px;
}

.commercial-kpi {
  min-width: 0;
  padding: 13px 14px;
  border: 1px solid var(--tt-border);
  border-radius: var(--tt-r-3);
  background: var(--tt-surface);
  box-shadow: var(--tt-shadow-1);
}

.commercial-kpi.is-accent { border-top: 2px solid var(--tt-accent); }
.commercial-kpi.is-success { border-top: 2px solid var(--tt-success); }
.commercial-kpi.is-blue { border-top: 2px solid var(--tt-info); }
.commercial-kpi.is-purple { border-top: 2px solid var(--pur); }
.commercial-kpi.is-orange { border-top: 2px solid var(--tt-warn); }
.commercial-kpi.is-neutral { border-top: 2px solid var(--tt-border-strong); }

.commercial-kpi span {
  display: block;
  color: var(--tt-fg-3);
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.commercial-kpi strong {
  display: block;
  min-height: 22px;
  margin-top: 3px;
  overflow: hidden;
  color: var(--tt-fg);
  font-family: var(--tt-font-mono, ui-monospace);
  font-size: 20px;
  font-weight: 700;
  line-height: 1.1;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.commercial-kpi small {
  display: block;
  min-height: 15px;
  margin-top: 3px;
  overflow: hidden;
  color: var(--tt-fg-4);
  font-size: 11px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.commercial-filters {
  display: grid;
  grid-template-columns: 140px 150px 120px minmax(200px, 1fr) auto;
  gap: 12px;
  align-items: end;
  padding: 14px 16px;
  border: 1px solid var(--tt-border);
  border-radius: var(--tt-r-3);
  box-shadow: var(--tt-shadow-1);
  background: var(--tt-surface);
}

.commercial-filters label {
  min-width: 0;
}

.commercial-filters label > span {
  display: block;
  margin-bottom: 5px;
  color: var(--tt-fg-3);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.commercial-filters select,
.commercial-search div {
  width: 100%;
  height: 36px;
  border: 1px solid var(--tt-border);
  border-radius: var(--tt-r-2);
  background: var(--tt-bg);
  color: var(--tt-fg);
  font-size: 13px;
}

.commercial-filters select {
  padding: 0 11px;
}

.commercial-search div {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 11px;
}

.commercial-search input {
  min-width: 0;
  width: 100%;
  border: 0;
  outline: none;
  background: transparent;
  color: var(--tt-fg);
  font-size: 13px;
}

.commercial-grid {
  display: grid;
  grid-template-columns: 1.1fr .95fr 1fr 1.2fr;
  gap: 16px;
  align-items: stretch;
}

.commercial-table-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 16px;
  align-items: start;
}

.commercial-movements {
  grid-template-columns: 1fr 1fr;
}

.commercial-card {
  display: flex;
  flex-direction: column;
  min-width: 0;
  overflow: hidden;
  border: 1px solid var(--tt-border);
  border-radius: var(--tt-r-3);
  box-shadow: var(--tt-shadow-1);
  background: var(--tt-surface);
}

.commercial-card > header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--tt-divider);
}

.commercial-card > header strong {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--tt-fg);
  font-size: 14px;
  font-weight: 600;
}

.commercial-card > header span {
  color: var(--tt-fg-4);
  font-size: 11px;
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
}

.commercial-table-head {
  align-items: flex-start;
  flex-wrap: wrap;
}

.commercial-table-title {
  min-width: 160px;
}

.commercial-table-title strong,
.commercial-table-title span {
  display: block;
}

.commercial-table-tools {
  display: flex;
  flex: 1;
  flex-wrap: wrap;
  gap: 8px;
  align-items: end;
  justify-content: flex-end;
  min-width: 280px;
}

.commercial-table-tools label {
  display: grid;
  gap: 4px;
  min-width: 112px;
}

.commercial-table-tools label:first-child {
  min-width: 180px;
}

.commercial-table-tools span {
  color: var(--tt-fg-4);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
}

.commercial-table-tools input,
.commercial-table-tools select {
  height: 32px;
  border: 1px solid var(--tt-border);
  border-radius: var(--tt-r-2);
  background: var(--tt-bg);
  color: var(--tt-fg);
  font: inherit;
  font-size: 12px;
}

.commercial-table-tools input {
  width: 100%;
  padding: 0 10px;
}

.commercial-table-tools select {
  padding: 0 8px;
}

.commercial-table-tools > strong {
  min-width: 74px;
  color: var(--tt-fg-3);
  font-family: var(--tt-font-mono, ui-monospace);
  font-size: 11px;
  font-weight: 700;
  text-align: right;
}

.commercial-year-bars {
  display: flex;
  align-items: flex-end;
  gap: 14px;
  height: 160px;
  padding: 16px;
  overflow-x: hidden;
}

.commercial-year-bars button {
  display: flex;
  flex: 1;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  justify-content: flex-end;
  min-width: 0;
  height: 100%;
  padding: 0;
  border: 0;
  border-radius: var(--tt-r-2);
  background: transparent;
  color: var(--tt-fg);
  cursor: pointer;
}

.commercial-year-bars.is-dense {
  justify-content: flex-start;
  overflow-x: auto;
  overscroll-behavior-x: contain;
  scrollbar-width: thin;
}

.commercial-year-bars.is-dense button {
  flex: 0 0 58px;
  width: 58px;
}

.commercial-year-bars.is-dense .commercial-growth {
  justify-content: center;
  min-width: 0;
  width: 100%;
  font-size: 10px;
}

.commercial-year-bars i {
  display: flex;
  align-items: flex-end;
  width: 100%;
  height: var(--h);
  min-height: 8px;
  overflow: hidden;
  border-radius: var(--tt-r-2) var(--tt-r-2) 0 0;
  background: var(--tt-surface-3);
}

.commercial-year-bars i::after {
  content: "";
  display: block;
  width: 100%;
  height: 82%;
  border-radius: var(--tt-r-2) var(--tt-r-2) 0 0;
  background: var(--tt-accent);
}

.commercial-year-bars button.is-active i {
  background: var(--tt-accent-soft);
  border: 1px solid var(--tt-accent-border);
}

.commercial-year-bars button.is-active strong {
  color: var(--tt-accent);
}

.commercial-year-bars strong,
.commercial-year-bars span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.commercial-year-bars strong {
  font-family: var(--tt-font-mono, ui-monospace);
  font-size: 12px;
  font-weight: 700;
}

.commercial-year-bars span {
  color: var(--tt-fg-4);
  font-family: var(--tt-font-mono, ui-monospace);
  font-size: 10px;
}

.commercial-progress-list {
  display: flex;
  flex-direction: column;
  gap: 13px;
  padding: 16px;
}

.commercial-rank-list {
  display: flex;
  flex-direction: column;
  padding: 8px;
  max-height: 360px;
  overflow: auto;
}

.commercial-rank-card > header {
  align-items: flex-start;
}

.commercial-rank-limit {
  display: grid;
  gap: 4px;
  min-width: 76px;
}

.commercial-rank-limit span {
  color: var(--tt-fg-4);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
}

.commercial-rank-limit select {
  height: 30px;
  border: 1px solid var(--tt-border);
  border-radius: var(--tt-r-2);
  background: var(--tt-bg);
  color: var(--tt-fg);
  font: inherit;
  font-size: 12px;
}

.commercial-progress-row > div {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 5px;
  color: var(--tt-fg);
  font-size: 12px;
  font-weight: 500;
}

.commercial-progress-row span {
  color: var(--tt-fg-3);
  white-space: nowrap;
}

.commercial-progress-row i {
  display: block;
  height: 7px;
  overflow: hidden;
  border-radius: 999px;
  background: var(--tt-surface-3);
}

.commercial-progress-row em {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--tt-accent);
}

.commercial-rank-list button {
  display: grid;
  grid-template-columns: 16px minmax(0, 1fr) auto auto;
  gap: 11px;
  align-items: center;
  width: 100%;
  padding: 8px 10px;
  border: 0;
  border-radius: var(--tt-r-2);
  background: transparent;
  color: var(--tt-fg);
  text-align: left;
  cursor: pointer;
}

.commercial-rank-list button:hover,
.commercial-rank-list button:focus-visible {
  background: var(--tt-surface-2);
  outline: none;
}

.commercial-rank-list button > span:first-child {
  color: var(--tt-fg-4);
  font-family: var(--tt-font-mono, ui-monospace);
  font-size: 12px;
  font-weight: 700;
  text-align: left;
}

.commercial-rank-list strong {
  min-width: 0;
  overflow: hidden;
  font-size: 13px;
  font-weight: 600;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.commercial-rank-list div {
  min-width: 0;
}

.commercial-rank-list small {
  display: block;
  margin-top: 2px;
  overflow: hidden;
  color: var(--tt-fg-4);
  font-size: 10.5px;
  line-height: 1.35;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.commercial-rank-list.is-detailed button {
  align-items: start;
  padding-top: 9px;
  padding-bottom: 9px;
}

.commercial-rank-list em {
  color: var(--tt-fg-2);
  font-family: var(--tt-font-mono, ui-monospace);
  font-size: 12px;
  font-style: normal;
  font-weight: 400;
  white-space: nowrap;
}

.commercial-growth {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  min-width: 48px;
  color: var(--tt-fg-3);
  font-family: var(--tt-font-mono, ui-monospace);
  font-size: 11px;
  font-weight: 700;
  white-space: nowrap;
}

.commercial-kpi .commercial-growth {
  justify-content: flex-start;
  min-width: 0;
  margin-top: 3px;
  font-size: 11px;
}

.commercial-growth.is-up {
  color: var(--tt-success);
}

.commercial-growth.is-down {
  color: var(--tt-danger);
}

.commercial-table-scroll {
  max-height: 470px;
  overflow: auto;
}

.commercial-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}

.commercial-table th {
  position: sticky;
  top: 0;
  z-index: 1;
  padding: 9px 14px;
  background: var(--tt-surface-2);
  color: var(--tt-fg-3);
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: .04em;
  text-align: right;
  text-transform: uppercase;
}

.commercial-table th:first-child,
.commercial-table td:first-child,
.commercial-table th.is-left,
.commercial-table td.is-left {
  text-align: left;
}

.commercial-table th button {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 4px;
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  cursor: pointer;
  font: inherit;
  letter-spacing: inherit;
  text-align: right;
  text-transform: inherit;
}

.commercial-table th.is-left button,
.commercial-table th:first-child button {
  justify-content: flex-start;
  text-align: left;
}

.commercial-table th button::after {
  content: "";
  width: 0;
  height: 0;
  border-right: 3px solid transparent;
  border-left: 3px solid transparent;
  opacity: 0;
}

.commercial-table th button.is-sort-asc::after {
  border-bottom: 5px solid currentColor;
  opacity: .8;
}

.commercial-table th button.is-sort-desc::after {
  border-top: 5px solid currentColor;
  opacity: .8;
}

.commercial-table th button:hover,
.commercial-table th button:focus-visible {
  color: var(--tt-accent);
  outline: none;
}

.commercial-table td {
  padding: 10px 14px;
  border-top: 1px solid var(--tt-divider);
  color: var(--tt-fg);
  text-align: right;
  vertical-align: top;
  white-space: nowrap;
}

.commercial-table td:first-child strong {
  font-weight: 600;
}

.commercial-table td:first-child {
  min-width: 160px;
  white-space: normal;
}

.commercial-table td strong {
  color: var(--tt-fg);
}

.commercial-table td span:not(.commercial-growth) {
  display: block;
  margin-top: 2px;
  color: var(--tt-fg-3);
  font-size: 11px;
}

.commercial-table tr[data-commercial-client] {
  cursor: pointer;
}

.commercial-table tr[data-commercial-client]:hover td {
  background: var(--tt-surface-2);
}

.commercial-muted,
.commercial-empty-cell {
  color: var(--tt-fg-3);
  font-size: 12px;
}

.dash-financial-summary {
  overflow: hidden;
}

.dash-financial-summary-empty {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.dash-financial-summary-empty strong,
.dash-financial-summary-empty span {
  display: block;
}

.dash-financial-summary-empty span {
  margin-top: 2px;
  color: var(--tt-fg-3);
  font-size: 12px;
}

.dash-financial-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.dash-financial-summary-metric {
  min-width: 0;
  padding: 11px 12px;
  border: 1px solid var(--tt-border);
  border-radius: 9px;
  background: var(--tt-surface-2);
}

.dash-financial-summary-metric span {
  display: block;
  color: var(--tt-fg-3);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
}

.dash-financial-summary-metric strong {
  display: block;
  margin-top: 5px;
  overflow: hidden;
  color: var(--tt-fg);
  font-family: var(--tt-font-mono, ui-monospace);
  font-size: 17px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dash-financial-summary-metric em {
  display: block;
  margin-top: 3px;
  font-style: normal;
  font-weight: 700;
}

.dash-financial-summary-metric em.is-up { color: var(--tt-success); }
.dash-financial-summary-metric em.is-down { color: var(--tt-danger); }

.dash-financial-summary-foot {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-top: 10px;
  color: var(--tt-fg-3);
  font-size: 12px;
}

.dash-financial-summary-foot strong {
  color: var(--tt-fg);
}

@media (max-width: 1180px) {
  .commercial-kpis {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .commercial-grid,
  .commercial-table-grid,
  .commercial-movements {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 860px) {
  .commercial-dashboard {
    padding: 16px 12px 92px;
  }

  .commercial-hero,
  .commercial-empty {
    align-items: stretch;
    flex-direction: column;
  }

  .commercial-hero-side {
    min-width: 0;
    text-align: left;
  }

  .commercial-kpis,
  .commercial-filters,
  .dash-financial-summary-grid {
    grid-template-columns: 1fr;
  }

  .dash-financial-summary-empty,
  .dash-financial-summary-foot {
    align-items: stretch;
    flex-direction: column;
  }
}

/* =============================================================================
   Detail commercial par client (TD-034) — menu d'action + panneau lateral
   ============================================================================= */

/* --- Menu d'action (popover ancre au clic) --- */
.commercial-actions-pop {
  position: fixed;
  z-index: 1500;
  min-width: 232px;
  padding: 6px;
  border: 1px solid var(--tt-border);
  border-radius: var(--tt-r-3);
  background: var(--tt-surface);
  box-shadow: 0 12px 32px rgba(15, 23, 42, .18);
  animation: cap-in .12s ease-out;
}

@keyframes cap-in {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}

.cap-head {
  padding: 6px 10px 8px;
  color: var(--tt-fg-3);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .03em;
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cap-item {
  display: flex;
  align-items: center;
  gap: 11px;
  width: 100%;
  padding: 9px 10px;
  border: 0;
  border-radius: 9px;
  background: transparent;
  text-align: left;
  cursor: pointer;
}

.cap-item:hover,
.cap-item:focus-visible {
  background: var(--tt-bg);
  outline: none;
}

.cap-ic {
  display: inline-flex;
  color: var(--tt-accent);
}

.cap-text { min-width: 0; }
.cap-text strong { display: block; color: var(--tt-fg); font-size: 13.5px; font-weight: 600; }
.cap-text small { display: block; color: var(--tt-fg-3); font-size: 11.5px; }

/* --- Panneau lateral --- */
.ccd-backdrop {
  position: fixed;
  inset: 0;
  z-index: 1400;
  display: flex;
  justify-content: flex-end;
  background: rgba(15, 23, 42, .42);
  opacity: 0;
  transition: opacity .22s ease;
  pointer-events: none;
}

.ccd-backdrop.open { opacity: 1; }

.ccd-backdrop[hidden] { display: none; }

.ccd-panel {
  display: flex;
  flex-direction: column;
  width: min(560px, 94vw);
  max-width: 100%;
  height: 100%;
  background: var(--tt-bg);
  box-shadow: -18px 0 48px rgba(15, 23, 42, .22);
  transform: translateX(100%);
  transition: transform .26s cubic-bezier(.22, .61, .36, 1);
  pointer-events: auto;
}

.ccd-backdrop.open .ccd-panel { transform: translateX(0); }

.ccd-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  padding: 20px 22px 16px;
  border-bottom: 1px solid var(--tt-border);
  background: var(--tt-surface);
}

.ccd-eyebrow {
  display: block;
  color: var(--tt-accent);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ccd-head h2 {
  margin: 4px 0 8px;
  color: var(--tt-fg);
  font-size: 21px;
  line-height: 1.15;
  font-weight: 700;
  letter-spacing: -.01em;
}

.ccd-chips { display: flex; flex-wrap: wrap; gap: 6px; }

.ccd-chip {
  display: inline-flex;
  align-items: center;
  padding: 3px 9px;
  border: 1px solid var(--tt-border);
  border-radius: 999px;
  background: var(--tt-bg);
  color: var(--tt-fg);
  font-size: 11.5px;
  font-weight: 600;
}

.ccd-chip.is-muted { color: var(--tt-fg-3); font-weight: 500; }

.ccd-close {
  flex: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: 1px solid var(--tt-border);
  border-radius: 10px;
  background: var(--tt-bg);
  color: var(--tt-fg-3);
  cursor: pointer;
}

.ccd-close:hover { color: var(--tt-fg); border-color: var(--tt-border-strong); }

.ccd-scroll {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 18px 22px 32px;
}

.ccd-section {
  padding: 16px;
  border: 1px solid var(--tt-border);
  border-radius: var(--tt-r-3);
  background: var(--tt-surface);
  box-shadow: var(--tt-shadow-1);
}

.ccd-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.ccd-section-head strong { display: block; color: var(--tt-fg); font-size: 14px; font-weight: 700; }
.ccd-section-head span { display: block; color: var(--tt-fg-3); font-size: 11.5px; }

.ccd-kpis {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.ccd-kpi {
  min-width: 0;
  padding: 11px 12px;
  border: 1px solid var(--tt-border);
  border-radius: 12px;
  background: var(--tt-bg);
}

.ccd-kpi span {
  display: block;
  color: var(--tt-fg-3);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.ccd-kpi strong {
  display: block;
  margin-top: 3px;
  color: var(--tt-fg);
  font-family: var(--tt-font-mono, ui-monospace);
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -.01em;
}

.ccd-kpi small { display: block; margin-top: 2px; color: var(--tt-fg-3); font-size: 11px; }

.ccd-scope {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 12px 0 0;
  color: var(--tt-fg-3);
  font-size: 12px;
}

.ccd-table { width: 100%; border-collapse: collapse; font-size: 12.5px; }
.ccd-table th {
  padding: 6px 8px;
  border-bottom: 1px solid var(--tt-border);
  color: var(--tt-fg-3);
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: .03em;
  text-transform: uppercase;
  text-align: left;
}
.ccd-table td { padding: 7px 8px; border-bottom: 1px solid var(--tt-border); color: var(--tt-fg); }
.ccd-table tbody tr:last-child td { border-bottom: 0; }
.ccd-table .ccd-num { text-align: right; font-variant-numeric: tabular-nums; white-space: nowrap; }
.ccd-table tr.is-active td { background: color-mix(in srgb, var(--tt-accent) 9%, transparent); }
.ccd-table tr.ccd-gap td { color: var(--tt-fg-3); }
.ccd-table tfoot td { padding-top: 9px; font-weight: 700; border-top: 1px solid var(--tt-border-strong); }

.ccd-tag {
  display: inline-block;
  padding: 1px 7px;
  border-radius: 999px;
  background: var(--tt-bg);
  border: 1px dashed var(--tt-border-strong);
  color: var(--tt-fg-3);
  font-size: 10.5px;
}

.ccd-barwrap {
  display: block;
  height: 6px;
  border-radius: 999px;
  background: var(--tt-bg);
  overflow: hidden;
}
.ccd-barwrap em { display: block; height: 100%; border-radius: 999px; background: var(--tt-accent); }

.ccd-year-pick { display: flex; flex-direction: column; gap: 2px; }
.ccd-year-pick span { color: var(--tt-fg-3); font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }
.ccd-year-pick select {
  padding: 5px 8px;
  border: 1px solid var(--tt-border);
  border-radius: 8px;
  background: var(--tt-bg);
  color: var(--tt-fg);
  font-size: 12.5px;
}

.ccd-empty {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  padding: 14px;
  border: 1px dashed var(--tt-border-strong);
  border-radius: 12px;
  background: var(--tt-bg);
  color: var(--tt-fg-3);
}
.ccd-empty p { margin: 0; font-size: 12.5px; line-height: 1.45; }
.ccd-empty svg { flex: none; margin-top: 1px; }

.ccd-analysis {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.ccd-analysis-item {
  padding: 10px 12px;
  border: 1px solid var(--tt-border);
  border-radius: 12px;
  background: var(--tt-bg);
}
.ccd-analysis-item span { display: block; color: var(--tt-fg-3); font-size: 10.5px; font-weight: 600; text-transform: uppercase; letter-spacing: .03em; }
.ccd-analysis-item strong { display: block; margin-top: 3px; color: var(--tt-fg); font-size: 13.5px; font-weight: 700; }
.ccd-analysis-item.is-up strong { color: var(--tt-success); }
.ccd-analysis-item.is-down strong { color: var(--tt-danger, #dc2626); }

.ccd-periodbar {
  position: sticky;
  top: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 10px;
  padding: 10px 2px;
  margin-bottom: 2px;
  background: var(--tt-bg);
  border-bottom: 1px solid var(--tt-border);
}
.ccd-periodbar label { display: flex; align-items: center; gap: 8px; }
.ccd-periodbar label span { color: var(--tt-fg-3); font-size: 11px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; }
.ccd-periodbar select {
  padding: 6px 10px;
  border: 1px solid var(--tt-border);
  border-radius: 8px;
  background: var(--tt-surface);
  color: var(--tt-fg);
  font-size: 13px;
  font-weight: 600;
}
.ccd-periodbar > strong { color: var(--tt-accent); font-size: 13px; font-weight: 700; margin-left: auto; }
.ccd-cumul-toggle { display: flex; align-items: center; gap: 6px; color: var(--tt-fg-3); font-size: 12px; font-weight: 600; cursor: pointer; }
.ccd-cumul-toggle input { accent-color: var(--tt-accent); }

/* Barre d'actions du detail (export bilan : Excel / PDF). */
.ccd-actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}
.ccd-export {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 14px;
  border: 1px solid var(--tt-border);
  border-radius: 9px;
  background: var(--tt-surface);
  color: var(--tt-fg);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: border-color .15s, background .15s, color .15s;
}
.ccd-export:hover { border-color: var(--tt-accent); color: var(--tt-accent); }
.ccd-export svg { flex: none; }
.ccd-actions-status { font-size: 12px; font-weight: 600; color: var(--tt-fg-3); }
.ccd-actions-status.is-ok { color: var(--tt-accent); }
.ccd-actions-status.is-err { color: var(--tt-danger, #d92d20); }

.ccd-table tr.ccd-sub td { color: var(--tt-fg-3); font-size: 12px; }
.ccd-table tr.ccd-sub td:first-child { padding-left: 18px; }

@media (max-width: 640px) {
  .ccd-panel { width: 100vw; }
  .ccd-kpis { grid-template-columns: 1fr; }
  .ccd-analysis { grid-template-columns: 1fr; }
  .ccd-scroll { padding: 14px 14px 28px; }
  .ccd-head { padding: 16px 16px 13px; }
}
