﻿/* ============================================================
   V-TOOLS DASHBOARD — Design System v2
   Refonte complète. Source unique.
   Palette logo: #1fddf0 → #2ee6c8 → #0ff29e
   ============================================================ */

/* ============ 1. TOKENS ============ */
:root {
  /* Brand */
  --c1: #1fddf0; --c2: #2ee6c8; --c3: #0ff29e;
  --accent: #1fddf0;
  --accent-2: #0ff29e;
  --accent-soft: rgba(31,221,240,.10);
  --accent-softer: rgba(31,221,240,.05);
  --accent-ring: rgba(31,221,240,.35);
  --accent-glow: rgba(15,242,158,.3);
  --grad-brand: linear-gradient(135deg, #1fddf0 0%, #2ee6c8 50%, #0ff29e 100%);
  --grad-brand-soft: linear-gradient(135deg, rgba(31,221,240,.18), rgba(15,242,158,.10));
  --grad-brand-text: linear-gradient(95deg, #1fddf0 0%, #0ff29e 100%);
  --grad-title: linear-gradient(180deg, #ffffff 0%, #8c97b0 130%);

  /* Background — Carbon (gris neutre, sans teinte) */
  --bg: #0a0a0a;
  --bg-1: #0f0f0f;
  --bg-2: #161616;
  --bg-3: #1d1d1d;
  --bg-card: #0f0f0f;

  /* Surface (glass) */
  --surface: rgba(22,22,22,.72);
  --surface-2: rgba(30,30,30,.72);
  --surface-3: rgba(38,38,38,.72);
  --surface-flat: #16161699;
  --surface-solid: #141414;

  /* Borders */
  --line: rgba(255,255,255,.06);
  --line-2: rgba(255,255,255,.10);
  --line-3: rgba(255,255,255,.18);

  /* Text */
  --text: #eef2f9;
  --text-2: #b0b9cc;
  --text-3: #7a8399;
  --muted: #525b72;
  --dim: #343c52;

  /* Status */
  --ok: #22c55e; --ok-soft: rgba(34,197,94,.12); --ok-ring: rgba(34,197,94,.35);
  --warn: #f59e0b; --warn-soft: rgba(245,158,11,.12); --warn-ring: rgba(245,158,11,.35);
  --danger: #ef4444; --danger-soft: rgba(239,68,68,.12); --danger-ring: rgba(239,68,68,.35);
  --info: #60a5fa; --info-soft: rgba(96,165,250,.12); --info-ring: rgba(96,165,250,.35);
  --grad-ok: linear-gradient(135deg,#4ade80,#16a34a);
  --grad-warn: linear-gradient(135deg,#fbbf24,#d97706);
  --grad-danger: linear-gradient(135deg,#f87171,#dc2626);

  /* Radii */
  --r-xs: 6px; --r-sm: 10px; --r-md: 14px; --r-lg: 18px; --r-xl: 22px; --r-2xl: 28px; --r-full: 999px;

  /* Shadows */
  --sh-xs: 0 1px 2px rgba(0,0,0,.3);
  --sh-sm: 0 2px 8px rgba(0,0,0,.35);
  --sh-md: 0 10px 28px rgba(0,0,0,.4), 0 2px 6px rgba(0,0,0,.25);
  --sh-lg: 0 28px 72px rgba(0,0,0,.55), 0 6px 20px rgba(0,0,0,.28);
  --sh-glow: 0 0 0 1px rgba(31,221,240,.22), 0 8px 32px rgba(15,242,158,.14);
  --sh-inner: inset 0 1px 0 rgba(255,255,255,.06);

  /* Motion */
  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-soft: cubic-bezier(.4,0,.2,1);
  --ease-snap: cubic-bezier(.2,.8,.2,1);
  --t-fast: 120ms; --t-base: 180ms; --t-slow: 280ms;

  /* Layout */
  --sidebar-w: 220px;
  --topbar-h: 56px;
  --gutter: 24px;
}

/* ============ 2. RESET & BASE ============ */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; height: 100%; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  font-feature-settings: 'cv11','ss01','ss02','ss03';
  font-size: 14px;
  line-height: 1.5;
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  letter-spacing: -0.005em;
  overflow-x: hidden;
}
button, input, textarea, select { font: inherit; color: inherit; }
button { background: none; border: none; cursor: pointer; padding: 0; }
a { color: var(--accent); text-decoration: none; transition: color var(--t-fast) var(--ease); }
a:hover { color: var(--accent-2); }
h1,h2,h3,h4,h5 { margin: 0; font-weight: 700; letter-spacing: -0.015em; color: var(--text); }
p { margin: 0; }
ul, ol { margin: 0; padding: 0; list-style: none; }
img, svg { display: block; max-width: 100%; }

::selection { background: rgba(31,221,240,.32); color: #fff; }

/* Scrollbars */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,.07);
  border-radius: 999px;
  border: 2px solid transparent;
  background-clip: padding-box;
}
::-webkit-scrollbar-thumb:hover { background: rgba(31,221,240,.3); background-clip: padding-box; border: 2px solid transparent; }

kbd {
  font-family: 'JetBrains Mono', ui-monospace, Menlo, monospace;
  font-size: 10.5px;
  padding: 2px 6px;
  background: rgba(255,255,255,.05);
  border: 1px solid var(--line-2);
  border-radius: 5px;
  color: var(--text-2);
  box-shadow: inset 0 -1px 0 rgba(0,0,0,.3);
  line-height: 1;
}

/* Focus rings */
:focus-visible { outline: 2px solid var(--accent-ring); outline-offset: 2px; border-radius: 4px; }
button:focus:not(:focus-visible), input:focus:not(:focus-visible), textarea:focus:not(:focus-visible) { outline: none; }

/* ============ 3. SHELL LAYOUT ============ */
#app {
  display: grid;
  grid-template-columns: var(--sidebar-w) 1fr;
  min-height: 100vh;
  position: relative;
  z-index: 1;
}

/* — SIDEBAR — */
.sidebar {
  grid-column: 1;
  position: sticky; top: 0;
  height: 100vh;
  display: flex; flex-direction: column;
  background: var(--bg-1);
  border-right: 1px solid var(--line);
  z-index: 40;
  overflow: hidden;
}
.sidebar-brand {
  padding: 20px 18px 16px;
  display: flex; align-items: center; justify-content: space-between;
}
.brand-logo { display: flex; align-items: center; gap: 12px; min-width: 0; }
.vt-logo {
  width: auto; height: 36px; object-fit: contain;
  filter: drop-shadow(0 4px 14px rgba(236,63,92,.35)) drop-shadow(0 0 22px rgba(110,62,192,.18));
  transition: transform var(--t-slow) var(--ease), filter var(--t-slow) var(--ease);
}
.sidebar-brand:hover .vt-logo {
  transform: translateY(-1px) rotate(-3deg) scale(1.05);
  filter: drop-shadow(0 6px 18px rgba(236,63,92,.55)) drop-shadow(0 0 32px rgba(110,62,192,.32));
}
.brand-text { display: flex; flex-direction: column; min-width: 0; }
.brand-name {
  font-size: 17px;
  font-weight: 800;
  letter-spacing: -0.02em;
  background: linear-gradient(95deg, #ec3f5c 0%, #a93cd9 50%, #6e3ec0 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
  line-height: 1.1;
}
.brand-sub {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.22em;
  color: var(--text-3);
  text-transform: uppercase;
  margin-top: 2px;
}
.sidebar-close {
  display: none;
  width: 32px; height: 32px;
  border-radius: var(--r-xs);
  color: var(--text-2);
  font-size: 14px;
  transition: all var(--t-base) var(--ease);
}
.sidebar-close:hover { background: rgba(255,255,255,.06); color: var(--text); }

.sidebar-cmdk {
  margin: 14px 14px 6px;
  padding: 10px 12px;
  background: rgba(255,255,255,.035);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  color: var(--text-3);
  font-size: 13px;
  display: flex; align-items: center; gap: 10px;
  transition: all var(--t-base) var(--ease);
}
.sidebar-cmdk:hover { background: rgba(255,255,255,.06); border-color: var(--line-2); color: var(--text-2); }
.cmdk-icon { font-size: 14px; opacity: .7; }
.cmdk-label { flex: 1; text-align: left; }
.cmdk-kbd { display: inline-flex; gap: 3px; }

.sidebar-nav { flex: 1; padding: 6px 10px 14px; overflow-y: auto; }
.nav-group { margin-bottom: 14px; }
.nav-group-label {
  padding: 10px 14px 6px;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.16em;
  color: var(--muted);
  text-transform: uppercase;
  display: flex; align-items: center; justify-content: space-between;
  cursor: default;
}
.nav-group.collapsible > .nav-group-label { cursor: pointer; user-select: none; }
.nav-group.collapsible > .nav-group-label:hover { color: var(--text-2); }
.nav-group-chevron { transition: transform .25s ease; flex-shrink: 0; opacity: .6; }
.nav-group.nav-grp-collapsed > .nav-group-label .nav-group-chevron { transform: rotate(-90deg); }
.nav-group-items { overflow: hidden; transition: height .25s ease, opacity .2s ease; }
.nav-group.nav-grp-collapsed > .nav-group-items { opacity: 0; }
.nav-item {
  position: relative;
  width: 100%;
  padding: 9px 12px;
  margin: 1px 0;
  border-radius: var(--r-sm);
  color: var(--text-2);
  font-size: 13.5px;
  font-weight: 500;
  display: flex; align-items: center; gap: 11px;
  text-align: left;
  transition: background var(--t-base) var(--ease), color var(--t-base) var(--ease), transform var(--t-fast) var(--ease);
}
.nav-item::before {
  content: '';
  position: absolute; left: 0; top: 50%;
  width: 3px; height: 0;
  background: rgba(255,255,255,.4);
  border-radius: 0 2px 2px 0;
  transform: translateY(-50%);
  transition: height var(--t-base) var(--ease);
}
.nav-item:hover { background: rgba(255,255,255,.05); color: var(--text); }
.nav-item:hover::before { height: 0; }
.nav-item:active { transform: translateX(1px); }
.nav-item.active {
  background: rgba(255,255,255,.06);
  color: var(--text);
  font-weight: 600;
}
.nav-item.active::before { height: 0; }
.nav-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 22px; height: 22px;
  font-size: 14px;
  opacity: .9;
  transition: transform var(--t-base) var(--ease);
}
.nav-item:hover .nav-icon { transform: scale(1.1); }
.nav-label { flex: 1; }
.nav-count {
  min-width: 20px; height: 20px;
  padding: 0 6px;
  background: var(--grad-danger);
  border-radius: 999px;
  color: #fff; font-size: 11px; font-weight: 700;
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 6px rgba(239,68,68,.35);
}

.sidebar-health {
  padding: 10px 14px;
  border-top: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 6px;
}
.hb-dot {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--ok);
  box-shadow: 0 0 8px var(--ok);
  animation: pulse-dot 2.2s var(--ease) infinite;
}
.hb-dot.warn { background: var(--warn); box-shadow: 0 0 8px var(--warn); }
.hb-dot.err, .hb-dot.error { background: var(--danger); box-shadow: 0 0 8px var(--danger); }
.hb-text { font-size: 11.5px; color: var(--text-3); }

.sidebar-footer {
  padding: 12px 16px;
  border-top: 1px solid var(--line);
  font-size: 11px;
  color: var(--muted);
}

@keyframes pulse-dot { 0%,100% {opacity:1;transform:scale(1)} 50% {opacity:.5;transform:scale(.8)} }

.sidebar-backdrop { display: none; }
.main {
  grid-column: 2;
  min-width: 0;
  display: flex; flex-direction: column;
}
#tickets-grid {
  display: flex; flex-direction: column;
  gap: 24px; padding: 20px var(--gutter); flex: 1;
}
body:not(.view-tickets) > #app .statsbar,
body:not(.view-tickets) .main > .statsbar { display: none; }

.topbar {
  position: sticky; top: 0;
  height: var(--topbar-h);
  padding: 0 var(--gutter);
  display: flex; align-items: center; gap: 16px;
  background: var(--bg);
  border-bottom: 1px solid var(--line);
  z-index: 30;
}
.topbar-left { display: flex; align-items: center; gap: 14px; min-width: 0; flex: 1; }
.topbar-right { display: flex; align-items: center; gap: 10px; }
.topbar-menu {
  display: none;
  width: 36px; height: 36px;
  border-radius: var(--r-sm);
  color: var(--text-2);
  font-size: 16px;
  transition: all var(--t-base) var(--ease);
}
.topbar-menu:hover { background: rgba(255,255,255,.06); color: var(--text); }
.topbar-title { display: flex; flex-direction: column; min-width: 0; }
.topbar-title-main { font-size: 15px; font-weight: 700; color: var(--text); letter-spacing: -0.01em; }
.topbar-title-sub { font-size: 12.5px; color: var(--text-3); margin-top: 1px; }

.page-wrap { padding: 20px var(--gutter) 48px; max-width: 1400px; width: 100%; }
.tab-view, .view { display: none; }
.tab-view.active, .view.active { display: block; }
@keyframes view-in {
  from { opacity: 0; transform: translateY(18px) scale(.985); }
  to   { opacity: 1; transform: translateY(0)    scale(1);    }
}
@keyframes card-in {
  from { opacity: 0; transform: translateY(22px) scale(.97); }
  to   { opacity: 1; transform: translateY(0)    scale(1);   }
}
.card-anim {
  animation: card-in 380ms cubic-bezier(.22,.68,0,1.15) both;
}

/* ============ 4. BUTTONS ============ */
.btn, button.btn,
.btn-primary, .btn-ghost, .btn-danger, .btn-success,
.filter-btn, .refresh-btn, .view-btn, .ping-btn, .translate-btn,
.panel-close-btn, .tp-md-btn, .learn-range-btn, .wh-embed-btn,
.facture-submit-btn, .push-toggle-btn,
#login-btn, .btn-senddev, .btn-close {
  position: relative;
  display: inline-flex; align-items: center; justify-content: center;
  gap: 8px;
  padding: 10px 16px;
  font-size: 13.5px; font-weight: 600; line-height: 1;
  letter-spacing: -0.005em;
  border: 1px solid var(--line-2);
  border-radius: var(--r-sm);
  background: rgba(255,255,255,.035);
  color: var(--text);
  white-space: nowrap;
  user-select: none;
  transition: background var(--t-base) var(--ease), border-color var(--t-base) var(--ease), color var(--t-base) var(--ease), transform var(--t-fast) var(--ease), box-shadow var(--t-base) var(--ease), filter var(--t-base) var(--ease);
  box-shadow: var(--sh-xs), var(--sh-inner);
}
.btn:hover, .btn-ghost:hover, .filter-btn:hover, .refresh-btn:hover, .view-btn:hover,
.ping-btn:hover, .translate-btn:hover, .tp-md-btn:hover, .learn-range-btn:hover,
.wh-embed-btn:hover, .push-toggle-btn:hover, .btn-close:hover {
  background: rgba(255,255,255,.07);
  border-color: var(--line-3);
  transform: translateY(-1px);
  box-shadow: var(--sh-sm), var(--sh-inner);
}
.btn:active, .btn-primary:active, .btn-ghost:active, .btn-danger:active, .btn-success:active,
#login-btn:active, .facture-submit-btn:active, .btn-senddev:active {
  transform: translateY(0) scale(.98);
  transition-duration: 80ms;
}
.btn:disabled, .btn-primary:disabled, .btn-ghost:disabled, .btn-danger:disabled,
.btn-success:disabled, #login-btn:disabled {
  opacity: .45; cursor: not-allowed; transform: none !important; filter: grayscale(.4);
}
.btn:focus-visible, .btn-primary:focus-visible, .btn-ghost:focus-visible,
.btn-danger:focus-visible, .btn-success:focus-visible, #login-btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--accent-ring), var(--sh-sm);
}

.btn-primary, .facture-submit-btn, #login-btn, .btn-senddev {
  background: var(--accent);
  border: 1px solid var(--accent);
  color: #020d0e;
  font-weight: 700;
  box-shadow: 0 0 0 0 transparent;
}
.btn-primary:hover, .facture-submit-btn:hover, #login-btn:hover, .btn-senddev:hover {
  background: #28eeff;
  border-color: #28eeff;
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(31,221,240,.30);
}

.btn-danger { background: rgba(239,68,68,.10); border: 1px solid rgba(239,68,68,.35); color: #fca5a5; }
.btn-danger:hover { background: rgba(239,68,68,.18); border-color: rgba(239,68,68,.55); color: #fecaca; transform: translateY(-1px); }
.btn-success { background: rgba(34,197,94,.10); border: 1px solid rgba(34,197,94,.35); color: #86efac; }
.btn-success:hover { background: rgba(34,197,94,.18); border-color: rgba(34,197,94,.55); transform: translateY(-1px); }
.btn-ghost { background: transparent; border-color: var(--line); color: var(--text-2); }
.btn-ghost:hover { color: var(--text); background: rgba(255,255,255,.04); }
.btn-sm, .btn-mini { padding: 6px 10px; font-size: 12px; border-radius: var(--r-xs); }

.filter-btn.active, .learn-range-btn.active, .view-btn.active, .tp-md-btn.active, .wh-subtab.active {
  background: var(--accent-soft);
  border-color: var(--accent-ring);
  color: var(--accent);
  box-shadow: inset 0 0 0 1px var(--accent-ring), 0 4px 12px rgba(31,221,240,.14);
}

.refresh-btn, .panel-close-btn, .wh-modal-close {
  width: 36px; height: 36px;
  padding: 0;
  border-radius: var(--r-sm);
  font-size: 16px;
}
.refresh-btn:hover { color: var(--accent); }
.refresh-btn:hover svg, .refresh-btn.loading svg { animation: spin-soft 800ms var(--ease); }
@keyframes spin-soft { from {transform:rotate(0)} to {transform:rotate(360deg)} }

/* ============ 5. INPUTS ============ */
input[type="text"], input[type="url"], input[type="number"],
input[type="password"], input[type="email"], input[type="search"],
textarea, select,
.tp-input, .wh-input, .facture-field, .cmdk-input,
#login-input, #facture-search {
  width: 100%;
  padding: 11px 14px;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--line-2);
  border-radius: var(--r-sm);
  color: var(--text);
  font-size: 13.5px;
  line-height: 1.4;
  transition: border-color var(--t-base) var(--ease), background var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease);
  box-shadow: var(--sh-inner);
}
textarea { resize: vertical; min-height: 80px; font-family: inherit; }
input::placeholder, textarea::placeholder { color: var(--muted); }
input:hover, textarea:hover, select:hover,
.tp-input:hover, .wh-input:hover, .facture-field:hover {
  border-color: var(--line-3);
  background: rgba(255,255,255,.05);
}
input:focus, textarea:focus, select:focus,
.tp-input:focus, .wh-input:focus, .facture-field:focus,
.cmdk-input:focus, #login-input:focus {
  outline: none;
  border-color: var(--accent);
  background: rgba(31,221,240,.03);
  box-shadow: 0 0 0 3px var(--accent-ring), var(--sh-inner);
}
input[type="color"] { padding: 4px; height: 40px; cursor: pointer; }
input[type="checkbox"], input[type="radio"] { width: auto; accent-color: var(--accent); }

label, .tp-label, .wh-label, .tp-field-label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-2);
  margin-bottom: 6px;
  letter-spacing: 0.01em;
}

/* ============ 6. CARDS ============ */
.card, .kpi-card, .stat-card, .tp-card, .learn-card,
.facture-card, .wh-embed-card, .wh-card {
  position: relative;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  box-shadow: var(--sh-sm);
  transition: transform var(--t-base) var(--ease), border-color var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease);
  overflow: hidden;
}
.card:hover, .kpi-card:hover, .stat-card:hover,
.tp-card:hover, .learn-card:hover, .wh-card:hover {
  transform: translateY(-2px);
  border-color: var(--line-2);
  box-shadow: var(--sh-lg), var(--sh-inner);
}

/* ============ 7. HERO ============ */
.hero { padding: 28px 0 8px; display: flex; flex-direction: column; gap: 10px; }
.hero-greeting, .hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px;
  background: var(--accent-soft);
  border: 1px solid var(--accent-ring);
  border-radius: var(--r-full);
  font-size: 12.5px; font-weight: 600;
  color: var(--accent);
  width: fit-content;
}
.hero-greeting::before, .hero-badge::before {
  content: ''; width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 10px var(--accent);
  animation: pulse-dot 2.2s var(--ease) infinite;
}
.hero-title, .hero h1 {
  font-size: 36px; font-weight: 800;
  letter-spacing: -0.03em; line-height: 1.05;
  color: var(--text);
  margin: 0;
}
.hero-subtitle { font-size: 15px; color: var(--text-3); max-width: 620px; margin-top: 4px; }
.hero-left { flex: 1; display: flex; flex-direction: column; gap: 10px; }
.hero-right { display: flex; align-items: center; gap: 10px; }
.hero-actions { display: flex; gap: 10px; margin-top: 12px; flex-wrap: wrap; }

/* ============ 8. SECTIONS & HEADERS ============ */
.section-header {
  display: flex; align-items: baseline; justify-content: space-between;
  margin: 28px 0 14px; gap: 12px; flex-wrap: wrap;
}
.section-title {
  font-size: 16px; font-weight: 700;
  letter-spacing: -0.01em; color: var(--text);
  display: flex; align-items: center; gap: 8px;
}
.section-count {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 22px; height: 22px; padding: 0 8px;
  background: var(--accent-soft); border: 1px solid var(--accent-ring);
  border-radius: var(--r-full);
  font-size: 11px; font-weight: 700; color: var(--accent);
}
.section-sub, .section-hint { font-size: 12.5px; color: var(--text-3); }

/* ============ 9. OVERVIEW / KPI ============ */
.ov-grid, .kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
  margin-top: 16px;
}
.kpi-card, .stat-card { padding: 20px; display: flex; flex-direction: column; gap: 12px; }
.kpi-icon, .stat-icon {
  width: 38px; height: 38px;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(31,221,240,.08);
  border: 1px solid rgba(31,221,240,.18);
  border-radius: var(--r-sm);
  color: var(--accent);
  flex-shrink: 0;
  position: relative; z-index: 1;
}
.kpi-icon svg, .stat-icon svg { width: 18px; height: 18px; stroke: currentColor; flex-shrink: 0; }
.kpi-card.kpi-urgent .kpi-icon, .kpi-card.kpi-urgent .stat-icon { background: rgba(239,68,68,.08); border-color: rgba(239,68,68,.18); color: var(--danger); }
.kpi-card.kpi-warn .kpi-icon, .kpi-card.kpi-warn .stat-icon { background: rgba(245,158,11,.08); border-color: rgba(245,158,11,.18); color: var(--warn); }
.kpi-card.kpi-ok .kpi-icon, .kpi-card.kpi-ok .stat-icon { background: rgba(34,197,94,.08); border-color: rgba(34,197,94,.18); color: var(--ok); }
.kpi-label, .stat-label {
  font-size: 12px; font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--text-3); position: relative; z-index: 1;
}
.kpi-value, .stat-value {
  font-size: 30px; font-weight: 800;
  letter-spacing: -0.02em; color: var(--text); line-height: 1.1;
  font-variant-numeric: tabular-nums;
  position: relative; z-index: 1;
}
.kpi-sub, .stat-sub { font-size: 12px; color: var(--text-3); position: relative; z-index: 1; }
.kpi-body { display: flex; flex-direction: column; gap: 4px; position: relative; z-index: 1; }
.kpi-card.kpi-urgent .kpi-value { color: var(--danger); }
.kpi-card.kpi-warn .kpi-value { color: var(--warn); }
.kpi-card.kpi-ok .kpi-value { color: var(--ok); }
.kpi-card.kpi-accent .kpi-value { color: var(--accent); }

.ov-columns { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 24px; }
@media (max-width: 980px) { .ov-columns { grid-template-columns: 1fr; } }
.ov-section {
  padding: 20px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
}
.ov-list { display: flex; flex-direction: column; gap: 6px; margin-top: 12px; }
.ov-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px;
  border-radius: var(--r-sm);
  background: rgba(255,255,255,.02);
  border: 1px solid transparent;
  cursor: pointer;
  transition: all var(--t-base) var(--ease);
}
.ov-item:hover { background: rgba(255,255,255,.05); border-color: var(--line); transform: translateX(2px); }
.ov-item-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--muted); flex-shrink: 0; }
.ov-item-dot.urgent { background: var(--danger); box-shadow: 0 0 8px var(--danger); }
.ov-item-dot.high { background: var(--warn); box-shadow: 0 0 8px var(--warn); }
.ov-item-dot.ok { background: var(--ok); box-shadow: 0 0 8px var(--ok); }
.ov-item-main { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.ov-item-name { font-size: 13.5px; font-weight: 600; color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ov-item-meta { font-size: 11.5px; color: var(--text-3); display: flex; gap: 8px; }
.ov-item-age { color: var(--muted); }
.ov-item-arrow { color: var(--muted); font-size: 12px; opacity: 0; transition: all var(--t-base) var(--ease); }
.ov-item:hover .ov-item-arrow { opacity: 1; transform: translateX(2px); }
.ov-empty { padding: 20px; text-align: center; color: var(--text-3); font-size: 13px; }

.ov-health { display: flex; flex-direction: column; gap: 8px; margin-top: 12px; }
.ov-health-row, .health-row {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px;
  background: rgba(255,255,255,.02);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  font-size: 13px;
}
.health-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--muted); flex-shrink: 0; }
.health-dot.ok { background: var(--ok); box-shadow: 0 0 8px var(--ok); }
.health-dot.warn { background: var(--warn); box-shadow: 0 0 8px var(--warn); }
.health-dot.err { background: var(--danger); box-shadow: 0 0 8px var(--danger); }
.ohr-label { flex: 1; color: var(--text-2); font-weight: 500; }
.ohr-value { color: var(--text); font-weight: 600; font-variant-numeric: tabular-nums; }

.shortcuts-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 10px; margin-top: 12px; }
.sc-item {
  padding: 14px;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  display: flex; flex-direction: column; gap: 4px;
  cursor: pointer;
  transition: all var(--t-base) var(--ease);
}
.sc-item:hover { background: rgba(31,221,240,.06); border-color: var(--accent-ring); transform: translateY(-2px); }

/* ============ 10. TICKETS LIST ============ */
.statsbar { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 12px; margin: 16px 0; }
.statsbar .stat-card { padding: 14px; }
.statsbar .stat-value { font-size: 24px; }

.toolbar { display: flex; align-items: center; gap: 10px; margin: 16px 0; flex-wrap: wrap; }
.view-toggle { display: inline-flex; gap: 4px; padding: 4px; background: rgba(255,255,255,.03); border: 1px solid var(--line); border-radius: var(--r-sm); }
.view-toggle .view-btn { padding: 6px 12px; border: none; background: transparent; }
.view-toggle .view-btn.active { background: var(--accent-soft); color: var(--accent); }

.ticket-section { margin-top: 20px; }
.section-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 12px;
  margin-top: 12px;
}

.ticket-card {
  position: relative;
  padding: 14px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-left: 3px solid var(--muted);
  border-radius: var(--r-md);
  display: flex; flex-direction: column; gap: 10px;
  cursor: pointer;
  transition: all var(--t-base) var(--ease);
  box-shadow: var(--sh-sm);
}
.ticket-card:hover {
  border-color: var(--accent-ring);
  border-left-color: var(--accent);
  transform: translateY(-2px);
  box-shadow: var(--sh-md), 0 0 0 1px var(--accent-ring);
}
.ticket-card.urgent { border-left-color: var(--danger); }
.ticket-card.urgent:hover { box-shadow: var(--sh-md), 0 0 0 1px var(--danger-ring); }
.ticket-card.high { border-left-color: var(--warn); }

.card-header { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.card-name { font-weight: 600; font-size: 14px; color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.card-email { font-size: 11.5px; color: var(--text-3); font-family: 'JetBrains Mono', monospace; }
.card-meta { display: flex; flex-wrap: wrap; gap: 6px; }
.card-age { font-size: 11px; color: var(--muted); margin-left: auto; }
.card-actions-hover, .card-actions-static { display: flex; gap: 6px; }
.card-actions-hover { opacity: 0; transition: opacity var(--t-base) var(--ease); }
.ticket-card:hover .card-actions-hover { opacity: 1; }

.chip, .badge, .kind-badge, .lang-badge, .learn-badge,
.cc-badge, .cc-scope-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 8px;
  font-size: 11px; font-weight: 600;
  border-radius: var(--r-full);
  background: rgba(255,255,255,.05);
  border: 1px solid var(--line-2);
  color: var(--text-2);
  line-height: 1;
  white-space: nowrap;
}
.chip.urgent { background: var(--danger-soft); border-color: var(--danger-ring); color: #fca5a5; }
.chip.high { background: var(--warn-soft); border-color: var(--warn-ring); color: #fcd34d; }
.chip.ok, .chip.success { background: var(--ok-soft); border-color: var(--ok-ring); color: #86efac; }
.chip.info { background: var(--info-soft); border-color: var(--info-ring); color: #93c5fd; }
.chip.accent { background: var(--accent-soft); border-color: var(--accent-ring); color: var(--accent); }

.sla-bar-wrap { height: 4px; background: rgba(255,255,255,.05); border-radius: 4px; overflow: hidden; }
.sla-bar, .sla-fill {
  height: 100%; background: var(--grad-brand);
  border-radius: 4px;
  transition: width var(--t-slow) var(--ease);
}
.sla-fill.warn { background: var(--grad-warn); }
.sla-fill.urgent { background: var(--grad-danger); }

.skeleton, .ticket-skeleton {
  background: rgba(255,255,255,.03);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: 14px;
  display: flex; flex-direction: column; gap: 10px;
}
.sk-bar, .sk-title, .sk-medium, .sk-short {
  height: 12px;
  background: linear-gradient(90deg, rgba(255,255,255,.04), rgba(255,255,255,.08), rgba(255,255,255,.04));
  background-size: 200% 100%;
  border-radius: 6px;
  animation: skeleton-shine 1.4s ease-in-out infinite;
}
.sk-title { height: 16px; width: 60%; }
.sk-medium { width: 80%; }
.sk-short { width: 40%; }
@keyframes skeleton-shine { 0% {background-position: 200% 0} 100% {background-position: -200% 0} }

/* ============ 11. TICKET PANEL ============ */
.panel-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.55);
  z-index: 80; opacity: 0; pointer-events: none;
  transition: opacity var(--t-base) var(--ease);
}
.panel-overlay.open { opacity: 1; pointer-events: auto; }
.panel, .ticket-panel {
  position: fixed; top: 0; right: 0;
  width: min(520px, 100vw);
  height: 100vh;
  background: var(--bg-1);
  border-left: 1px solid var(--line);
  box-shadow: -24px 0 64px rgba(0,0,0,.5);
  display: flex; flex-direction: column;
  transform: translateX(100%);
  transition: transform var(--t-slow) var(--ease-snap);
  z-index: 90;
}
.panel.open, .ticket-panel.open { transform: translateX(0); }
.panel-header {
  padding: 16px 20px;
  border-bottom: 1px solid var(--line);
  display: flex; align-items: center; gap: 12px;
  background: var(--bg-1);
}
.panel-header-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.panel-channel-name {
  font-size: 15px; font-weight: 700; color: var(--text);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.panel-meta { display: flex; gap: 10px; font-size: 12px; color: var(--text-3); flex-wrap: wrap; }
.panel-meta-item { display: inline-flex; align-items: center; gap: 4px; }
.panel-badges { display: flex; gap: 6px; margin-top: 4px; flex-wrap: wrap; }
.panel-actions-bar {
  padding: 12px 20px;
  border-bottom: 1px solid var(--line);
  display: flex; gap: 8px; flex-wrap: wrap;
  background: rgba(14,18,32,.4);
}
.panel-messages-wrap { flex: 1; overflow-y: auto; padding: 16px 20px; }
.panel-messages { display: flex; flex-direction: column; gap: 14px; }

.date-sep {
  text-align: center;
  font-size: 11px; color: var(--muted);
  text-transform: uppercase; letter-spacing: 0.1em;
  margin: 12px 0 8px; position: relative;
}
.date-sep::before, .date-sep::after {
  content: ''; position: absolute; top: 50%;
  width: 30%; height: 1px; background: var(--line);
}
.date-sep::before { left: 0; }
.date-sep::after { right: 0; }

.msg-dash, .msg { display: flex; gap: 10px; max-width: 85%; }
.msg-dash.in, .msg-dash[data-side="in"] { align-self: flex-start; }
.msg-dash[data-side="out"] { align-self: flex-end; flex-direction: row-reverse; }
.msg-avatar {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--grad-brand-soft);
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; flex-shrink: 0; overflow: hidden;
}
.msg-avatar img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.msg-dash-label { font-size: 12px; color: var(--text-3); margin-bottom: 2px; display: flex; gap: 6px; align-items: baseline; }
.msg-name { font-weight: 600; color: var(--text-2); font-size: 12.5px; }
.msg-meta { font-size: 11px; color: var(--muted); }
.msg-content, .msg-text {
  padding: 10px 14px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  font-size: 13.5px; line-height: 1.5;
  color: var(--text);
  word-wrap: break-word;
}
.msg-dash[data-side="out"] .msg-content, .msg-dash[data-side="out"] .msg-text {
  background: var(--accent-soft); border-color: var(--accent-ring);
}
.msg-system .msg-text, .msg.msg-system {
  background: rgba(255,255,255,.02);
  color: var(--text-3);
  font-style: italic; font-size: 12.5px;
  text-align: center;
  padding: 6px 12px;
  border-radius: var(--r-full);
  width: fit-content; align-self: center;
}
.msg-translation { font-size: 12px; color: var(--accent); margin-top: 4px; font-style: italic; }

.panel-reply-wrap {
  padding: 14px 20px;
  border-top: 1px solid var(--line);
  background: rgba(14,18,32,.6);
}
.panel-reply { display: flex; gap: 8px; align-items: flex-end; }
.panel-reply textarea { flex: 1; min-height: 44px; max-height: 160px; padding: 11px 14px; }
.panel-reply-send { flex-shrink: 0; }
.translate-hint { font-size: 11px; color: var(--text-3); margin-top: 6px; }
.msgs-loading { padding: 20px; text-align: center; color: var(--text-3); }

/* ============ 12. RESOLVED ============ */
.resolved-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-bottom: 16px; flex-wrap: wrap; padding: 12px 16px; background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--r-md); }
.resolved-feed { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 14px; }
.resolved-card {
  padding: 16px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  display: flex; flex-direction: column; gap: 10px;
  transition: all var(--t-base) var(--ease);
}
.resolved-card:hover { border-color: var(--line-2); transform: translateY(-2px); box-shadow: var(--sh-md); }
.resolved-card-header { display: flex; justify-content: space-between; align-items: baseline; }
.resolved-card-author { font-size: 12px; color: var(--text-2); font-weight: 600; }
.resolved-card-time { font-size: 11px; color: var(--muted); }
.resolved-title-label { font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.1em; }
.resolved-embed {
  background: rgba(255,255,255,.02);
  border: 1px solid var(--line);
  border-left: 3px solid var(--accent);
  border-radius: var(--r-md);
  padding: 12px;
}
.resolved-embed-inner { display: flex; flex-direction: column; gap: 8px; }
.resolved-embed-title { font-weight: 700; color: var(--text); font-size: 14px; }
.resolved-embed-desc { font-size: 13px; color: var(--text-2); line-height: 1.5; }
.resolved-embed-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; margin-top: 4px; }
.resolved-embed-field-name { font-size: 11px; color: var(--text-3); font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; }
.resolved-embed-field-value { font-size: 12.5px; color: var(--text-2); }
.resolved-plain { color: var(--text-2); font-size: 13px; }
.resolved-empty { padding: 40px; text-align: center; color: var(--text-3); }
.resolved-loading { padding: 20px; text-align: center; color: var(--text-3); }

/* ============ 13. LEARN ============ */
.learn-toolbar { display: flex; gap: 10px; align-items: center; margin-bottom: 16px; flex-wrap: wrap; }
.learn-statsbar { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 12px; margin-bottom: 16px; }
.learn-stat { padding: 14px; background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--r-md); }
.learn-range { display: inline-flex; gap: 4px; padding: 4px; background: rgba(255,255,255,.03); border: 1px solid var(--line); border-radius: var(--r-sm); }
.learn-range-btn { padding: 6px 10px; border: none; font-size: 12px; }
.learn-range-btn.active { background: var(--accent-soft); color: var(--accent); border: none; }
.learn-filters { display: flex; gap: 6px; flex-wrap: wrap; }
.learn-chart-wrap { padding: 16px; background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--r-lg); margin-bottom: 16px; }
.learn-chart-legend { display: flex; gap: 16px; margin-top: 10px; font-size: 12px; color: var(--text-3); flex-wrap: wrap; }
.learn-list { display: flex; flex-direction: column; gap: 8px; }
.learn-item {
  padding: 14px;
  background: var(--bg-2);
  border: 1px solid var(--line); border-radius: var(--r-md);
  transition: all var(--t-base) var(--ease);
}
.learn-item:hover { border-color: var(--line-2); transform: translateX(2px); }
.learn-item-head { display: flex; justify-content: space-between; align-items: center; gap: 10px; }
.learn-item-title { font-weight: 600; color: var(--text); font-size: 13.5px; }
.learn-item-meta { font-size: 11.5px; color: var(--text-3); }
.learn-item-body { font-size: 13px; color: var(--text-2); line-height: 1.5; margin-top: 6px; }
.learn-item-badges { display: flex; gap: 6px; margin-top: 8px; flex-wrap: wrap; }
.state-learned { background: var(--ok-soft); border-color: var(--ok-ring); color: #86efac; }
.state-unlearned { background: var(--warn-soft); border-color: var(--warn-ring); color: #fcd34d; }
.learn-empty, .learn-loading { padding: 40px; text-align: center; color: var(--text-3); }

/* ============ 14. COMMISSIONS — Rewardful ============ */

/* KPI bar */
.rw-kpis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 10px;
  margin-bottom: 18px;
}
.rw-kpi {
  padding: 14px 16px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
}
.rw-kpi-val { font-size: 20px; font-weight: 800; color: var(--text); font-variant-numeric: tabular-nums; }
.rw-kpi-lbl { font-size: 11px; font-weight: 600; color: var(--text-3); text-transform: uppercase; letter-spacing: .08em; margin-top: 3px; }
.rw-kpi.rw-kpi-warn .rw-kpi-val { color: var(--warn); }
.rw-kpi.rw-kpi-accent .rw-kpi-val { color: var(--accent); }
.rw-kpi.rw-kpi-ok .rw-kpi-val { color: var(--ok); }

/* ── Period cards ──────────────────────────────────────────────────────── */
.rw-cards-section {
  position: relative;
  margin-bottom: 18px;
}
/* ── Mode discret button ─────────────────────────────────────────────────── */
.rw-discret-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  margin-left: auto;
  margin-top: 6px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  cursor: pointer;
  color: var(--text-3);
  transition: color .15s, background .15s;
}
.rw-discret-btn:hover { color: var(--text); background: var(--bg-3, rgba(255,255,255,.06)); }
.rw-discret-btn.active { color: #f59e0b; border-color: rgba(245,158,11,.35); }

/* ── Rewardful token sync modal ──────────────────────────────────────────── */
.rw-sync-modal {
  position: relative;
  background: #000;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  width: 100%;
  max-width: 480px;
  max-height: 90vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 24px 60px rgba(0,0,0,.7);
}
.rw-sync-modal-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 20px 0;
}
.rw-sync-modal-title {
  display: flex; align-items: center; gap: 9px;
  font-size: 15px; font-weight: 700; color: var(--text);
}
.rw-sync-modal-close {
  width: 30px; height: 30px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--text-3); transition: background .15s, color .15s;
}
.rw-sync-modal-close:hover { background: rgba(255,255,255,.07); color: var(--text); }
.rw-sync-modal-body {
  padding: 16px 20px 20px;
  overflow-y: auto;
  display: flex; flex-direction: column; gap: 12px;
}

/* Big CTA */
.rw-token-sync-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 15px 20px;
  background: #6ee7a7;
  color: #042714;
  font-weight: 800;
  font-size: 15px;
  border: none;
  border-radius: 14px;
  cursor: pointer;
  transition: opacity .15s, transform .1s, background .15s;
  letter-spacing: -0.01em;
}
.rw-token-sync-btn:hover:not(:disabled) { background: #7ef3b6; transform: translateY(-1px); }
.rw-token-sync-btn:disabled { opacity: .4; cursor: not-allowed; }
.rw-token-sync-btn.spinning svg { animation: spin .8s linear infinite; }

/* What to sync */
.rw-sync-what-card {
  background: #0d0d0d;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 14px;
  padding: 14px 16px;
}
.rw-sync-what-title { font-size: 13px; font-weight: 700; color: var(--text); margin: 0 0 12px; }
.rw-sync-what-options { display: flex; gap: 8px; }
.rw-sync-check-btn {
  flex: 1;
  display: flex; align-items: center; justify-content: center; gap: 7px;
  padding: 9px 12px;
  border: 1.5px solid rgba(255,255,255,.07);
  border-radius: 10px;
  font-size: 13px; font-weight: 600;
  color: var(--text-3);
  cursor: pointer;
  transition: all .15s;
  user-select: none;
  background: transparent;
}
.rw-sync-check-btn input { display: none; }
.rw-sync-check-btn.active {
  border-color: rgba(110,231,167,.45);
  background: rgba(110,231,167,.08);
  color: #6ee7a7;
}
.rw-sync-check-btn.active svg { stroke: #6ee7a7; }
.rw-sync-check-btn:hover:not(.active) { border-color: rgba(255,255,255,.18); color: var(--text-2); }

/* Info card */
.rw-sync-info-card {
  background: #0d0d0d;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 14px;
  padding: 14px 16px;
  font-size: 13px;
  color: var(--text-2);
}
.rw-sync-info-title { font-weight: 700; color: var(--text); margin: 0 0 10px; font-size: 13px; }
.rw-sync-info-list {
  margin: 0 0 12px 0; padding: 0;
  list-style: none;
  display: flex; flex-direction: column; gap: 6px;
}
.rw-sync-info-list li {
  display: flex; align-items: flex-start; gap: 8px;
}
.rw-sync-info-list li::before {
  content: '•';
  color: #6ee7a7;
  font-size: 16px;
  line-height: 1.2;
  flex-shrink: 0;
}
.rw-sync-info-footer {
  display: flex; align-items: center; gap: 8px;
  padding-top: 10px;
  border-top: 1px solid rgba(255,255,255,.06);
  font-size: 12px;
  color: var(--text-3);
}
.rw-sync-info-time { display: flex; align-items: center; gap: 4px; }
.rw-sync-info-limit { color: #f59e0b; font-weight: 600; }

/* Token status pill (lecture seule) */
.rw-sync-token-status {
  display: flex; align-items: center; gap: 9px;
  padding: 11px 14px;
  border-radius: 12px;
  font-size: 12.5px;
  border: 1px solid rgba(255,255,255,.06);
  background: #0d0d0d;
}
.rw-sync-token-status code {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  background: rgba(255,255,255,.06);
  padding: 1px 6px; border-radius: 4px;
  color: var(--text-2);
}
.rw-sync-token-status.rw-sync-token-ok {
  color: #6ee7a7;
  border-color: rgba(110,231,167,.18);
  background: rgba(110,231,167,.05);
}
.rw-sync-token-status.rw-sync-token-missing {
  color: #f59e0b;
  border-color: rgba(245,158,11,.22);
  background: rgba(245,158,11,.06);
}
.rw-sync-token-status.rw-sync-token-missing strong { color: #fbbf24; font-weight: 700; }

/* Token card (legacy — gardé pour rétro-compat éventuelle) */
.rw-sync-token-card {
  background: #0d0d0d;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 14px;
  padding: 14px 16px;
}
.rw-sync-token-label {
  font-size: 13px; font-weight: 700; color: var(--text);
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 6px;
}
.rw-sync-token-hint { font-size: 11px; color: var(--text-3); margin: 0 0 12px; line-height: 1.6; }
.rw-sync-code {
  font-size: 11px; background: rgba(255,255,255,.08);
  padding: 2px 6px; border-radius: 5px;
  font-family: 'JetBrains Mono', monospace;
  color: var(--text-2);
}
.rw-token-input-row { display: flex; gap: 8px; }
.rw-token-input {
  flex: 1;
  background: rgba(255,255,255,.05);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 9px 12px;
  font-size: 13px;
  color: var(--text-1);
  font-family: 'JetBrains Mono', monospace;
  outline: none;
  transition: border-color .15s;
}
.rw-token-input:focus { border-color: rgba(110,231,167,.5); }
.rw-token-input::placeholder { color: var(--text-3); font-family: inherit; }
.rw-sync-save-btn {
  padding: 9px 16px;
  background: rgba(255,255,255,.08);
  border: 1px solid var(--line);
  border-radius: 10px;
  font-size: 13px; font-weight: 600;
  color: var(--text);
  cursor: pointer;
  white-space: nowrap;
  transition: background .15s, border-color .15s;
}
.rw-sync-save-btn:hover { background: rgba(255,255,255,.12); border-color: rgba(110,231,167,.4); }
.rw-token-current { font-size: 12px; color: #34d399; margin: 8px 0 0; }

/* History */
.rw-sync-history { }
.rw-token-history { }
.rw-token-history-title { font-size: 12px; font-weight: 600; color: var(--text-3); text-transform: uppercase; letter-spacing: .06em; margin: 0 0 8px; }
.rw-token-history-list { display: flex; flex-direction: column; gap: 6px; max-height: 220px; overflow-y: auto; }
.rw-token-history-empty { font-size: 13px; color: var(--text-3); margin: 0; }
.rw-token-history-row {
  display: flex;
  align-items: center;
  gap: 10px;
  background: #0d0d0d;
  border: 1px solid rgba(255,255,255,.05);
  border-radius: var(--r-sm);
  padding: 8px 12px;
  font-size: 12px;
}
.rw-token-history-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.rw-token-history-dot.ok  { background: #34d399; }
.rw-token-history-dot.err { background: #f87171; }
.rw-token-history-date { color: var(--text-3); white-space: nowrap; }
.rw-token-history-counts { color: var(--text-1); flex: 1; }
.rw-token-history-dur { color: var(--text-3); white-space: nowrap; }
.rw-token-history-err { color: #f87171; font-size: 11px; margin-top: 2px; }

/* ── Mode discret panel ──────────────────────────────────────────────────── */
.rw-discret-panel {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: 320px;
  background: var(--bg-2, #111827);
  border-left: 1px solid var(--line, rgba(255,255,255,.09));
  z-index: 500;
  display: flex;
  flex-direction: column;
  gap: 0;
  overflow-y: auto;
  box-shadow: -8px 0 40px rgba(0,0,0,.45);
  animation: rwDpSlideIn .22s cubic-bezier(.4,0,.2,1);
}
.rw-discret-panel[hidden] { display: none; }
@keyframes rwDpSlideIn {
  from { transform: translateX(100%); opacity: 0; }
  to   { transform: translateX(0);    opacity: 1; }
}
.rw-dp-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 20px 14px;
  border-bottom: 1px solid var(--line, rgba(255,255,255,.09));
  position: sticky; top: 0;
  background: var(--bg-2, #111827);
  z-index: 1;
}
.rw-dp-title {
  display: flex; align-items: center; gap: 9px;
  font-size: 15px; font-weight: 700; color: var(--text-1);
}
.rw-dp-close {
  width: 26px; height: 26px;
  display: flex; align-items: center; justify-content: center;
  background: none; border: none; cursor: pointer;
  color: var(--text-3); font-size: 18px;
  border-radius: 6px; transition: background .15s, color .15s;
}
.rw-dp-close:hover { background: var(--bg-3); color: var(--text-1); }
.rw-dp-desc {
  font-size: 12.5px; color: var(--text-3); line-height: 1.5;
  padding: 14px 20px 0; margin: 0;
}
.rw-dp-master-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px;
}
.rw-dp-master-label { font-size: 13.5px; font-weight: 600; color: var(--text-1); line-height: 1.4; }
.rw-dp-master-label small { font-size: 11px; font-weight: 400; color: var(--text-3); }
.rw-dp-switch { position: relative; display: inline-block; width: 42px; height: 24px; flex-shrink: 0; }
.rw-dp-switch input { opacity: 0; width: 0; height: 0; }
.rw-dp-thumb {
  position: absolute; inset: 0;
  background: rgba(255,255,255,.12); border-radius: 12px;
  transition: background .2s;
  cursor: pointer;
}
.rw-dp-thumb::before {
  content: ''; position: absolute;
  width: 18px; height: 18px; left: 3px; top: 3px;
  background: #fff; border-radius: 50%;
  transition: transform .2s;
}
.rw-dp-switch input:checked + .rw-dp-thumb { background: var(--accent, #6366f1); }
.rw-dp-switch input:checked + .rw-dp-thumb::before { transform: translateX(18px); }
.rw-dp-divider { height: 1px; background: var(--line, rgba(255,255,255,.09)); margin: 0 20px; }
.rw-dp-group { padding: 16px 20px 8px; }
.rw-dp-group-head {
  display: flex; align-items: center; gap: 7px;
  margin-bottom: 10px;
}
.rw-dp-group-icon { color: var(--text-3); flex-shrink: 0; }
.rw-dp-group-title { font-size: 13px; font-weight: 700; color: var(--text-1); flex: 1; }
.rw-dp-all {
  font-size: 11px; color: var(--accent, #6366f1);
  cursor: pointer; font-weight: 600; letter-spacing: .02em;
  user-select: none;
}
.rw-dp-all:hover { opacity: .8; }
.rw-dp-item {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 0; cursor: pointer;
  font-size: 13px; color: var(--text-2);
  border-radius: 6px;
  transition: color .15s;
}
.rw-dp-item:hover { color: var(--text-1); }
.rw-dp-item input[type="checkbox"] {
  width: 15px; height: 15px; accent-color: var(--accent, #6366f1);
  cursor: pointer; flex-shrink: 0;
}

/* ── Blur classes ────────────────────────────────────────────────────────── */
.rw-blur { filter: blur(7px); transition: filter .2s; user-select: none; cursor: default; }
.rw-blur:hover { filter: none; }

.rw-cards-cfg-btn {
  position: absolute;
  top: -2px;
  right: 0;
  z-index: 1;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  cursor: pointer;
  color: var(--text-3);
  transition: color .15s, background .15s;
}
.rw-cards-cfg-btn:hover { color: var(--text); background: var(--bg-3, rgba(255,255,255,.06)); }

.rw-period-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  padding-right: 38px;
}
@media (max-width: 1000px) { .rw-period-cards { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px)  { .rw-period-cards { grid-template-columns: 1fr; padding-right: 0; } }

.rw-period-card {
  background: var(--bg-1);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: 16px 18px;
  display: flex;
  flex-direction: column;
}
.rw-pcard-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 10px;
}
.rw-pcard-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-3);
  line-height: 1.3;
}
.rw-pcard-icon { color: #16f5ca; flex-shrink: 0; margin-top: 1px; }
.rw-pcard-icon svg { width: var(--icon-sz, 20px); height: var(--icon-sz, 20px); }
.rw-pcard-amount {
  font-size: 26px;
  font-weight: 800;
  color: var(--text);
  font-variant-numeric: tabular-nums;
  line-height: 1;
  margin-bottom: 4px;
}
.rw-pcard-sub {
  font-size: 12px;
  color: var(--text-3);
  font-variant-numeric: tabular-nums;
  margin-bottom: 2px;
}
.rw-pcard-sub-due-now { color: #f87171; }
.rw-pcard-divider { height: 1px; background: transparent; margin: 10px 0; }

/* Month projection block */
.rw-proj-row { display: flex; justify-content: space-between; align-items: baseline; gap: 6px; margin-bottom: 7px; }
.rw-proj-label { font-size: 10.5px; font-weight: 600; color: var(--text-3); text-transform: uppercase; letter-spacing: .06em; }
.rw-proj-value { font-size: 13px; font-weight: 800; color: var(--text); font-variant-numeric: tabular-nums; }
.rw-proj-bar-wrap { height: 4px; background: var(--bg-3, rgba(255,255,255,.07)); border-radius: 2px; overflow: hidden; margin-bottom: 7px; }
.rw-proj-bar { height: 100%; background: var(--accent); border-radius: 2px; transition: width .6s var(--ease); }
.rw-proj-vs { font-size: 11px; color: var(--text-3); }
.rw-pcard-stats { display: flex; justify-content: space-between; }
.rw-pcard-stat { display: flex; flex-direction: column; gap: 2px; }
.rw-pcard-stat-val {
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  font-variant-numeric: tabular-nums;
}
.rw-pcard-stat-lbl {
  font-size: 10px;
  font-weight: 600;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: .06em;
}
.rw-pcard-stat-due-now .rw-pcard-stat-val,
.rw-pcard-stat-due-now .rw-pcard-stat-lbl {
  color: #f87171;
}
.rw-pcard-kpis {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}
.rw-pcard-kpi {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}
.rw-pcard-kpis .rw-pcard-kpi:last-child {
  text-align: right;
}
.rw-pcard-kpi-value {
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.rw-pcard-kpi-label {
  font-size: 10px;
  font-weight: 600;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: .06em;
}
.rw-pcard-kpi-sub {
  font-size: 10px;
  color: var(--text-3);
  font-variant-numeric: tabular-nums;
}
.rw-pcard-kpi-danger .rw-pcard-kpi-value,
.rw-pcard-kpi-danger .rw-pcard-kpi-label {
  color: #f87171;
}

/* Period card redesigned footer */
.rw-pcard-footer-row {
  display: flex;
  align-items: stretch;
  gap: 0;
}
.rw-pcard-footer-sep {
  width: 1px;
  background: var(--line);
  margin: 0 14px;
  flex-shrink: 0;
}
.rw-pcard-footer-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}
.rw-pcard-footer-lbl {
  font-size: 10.5px;
  color: var(--text-3);
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.rw-pcard-footer-val {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-1);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.rw-pcard-footer-sub {
  font-size: 10.5px;
  color: var(--text-3);
}
.rw-pcard-footer-code {
  color: #cf346b !important;
}
.rw-pcard-monthly {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.rw-pcard-month-head,
.rw-pcard-month-row {
  display: grid;
  grid-template-columns: 62px .7fr .7fr .8fr 1.15fr;
  gap: 8px;
  align-items: center;
}
.rw-pcard-month-head {
  padding-bottom: 2px;
}
.rw-pcard-month-head-cell,
.rw-pcard-month-cell {
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.rw-pcard-month-head-cell {
  font-size: 9px;
  font-weight: 700;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: .06em;
}
.rw-pcard-month-body {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.rw-pcard-month-row {
  min-height: 24px;
  padding: 8px 10px;
  border: 1px solid rgba(255,255,255,.05);
  border-radius: 10px;
  background: rgba(255,255,255,.02);
}
.rw-pcard-month-cell {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-2);
}
.rw-pcard-month-key {
  color: var(--text);
}
.rw-pcard-month-amt {
  color: #34d399;
  text-align: right;
}
@keyframes rw-pulse { 0%,100%{opacity:.4} 50%{opacity:.7} }
.rw-pcard-skeleton {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  height: 118px;
  animation: rw-pulse 1.5s ease-in-out infinite;
}

/* Cards config modal rows */
.rw-cards-cfg-rows { display: flex; flex-direction: column; gap: 16px; }
.rw-cfg-row { display: flex; align-items: center; gap: 16px; }
.rw-cfg-label { font-size: 13px; font-weight: 600; color: var(--text); min-width: 55px; }
.rw-cfg-row .select { flex: 1; }

/* Stats row: grille 2×2 — heatmap/donut ligne 1, semaine record ligne 2 col 1 */
.rw-stats-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
  align-items: stretch;
  gap: 14px;
  margin-bottom: 18px;
}
.rw-stats-row .rw-heatmap-card   { grid-column: 1; grid-row: 1; }
.rw-donut-main-card               { grid-column: 2; grid-row: 1; display: flex; flex-direction: column; justify-content: flex-start; }
.rw-week-insights-row             { grid-column: 1 / -1; grid-row: 2; }
.rw-insights-row                  { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; align-items: stretch; }
.rw-donut-kpi-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}
.rw-donut-kpi {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.rw-donut-kpi-val {
  font-size: 13px;
  font-weight: 700;
  color: var(--text-1);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.rw-donut-kpi-lbl {
  font-size: 10px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.rw-donut-board-title {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-2);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 8px;
}
.rw-donut-board-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 0;
  border-bottom: 1px solid var(--line);
}
.rw-donut-board-item:last-child { border-bottom: none; }
.rw-donut-board-rank {
  font-size: 11px;
  font-weight: 700;
  color: var(--muted);
  width: 20px;
  flex-shrink: 0;
}
.rw-donut-board-conv {
  font-size: 12px;
  color: var(--text-2);
  flex: 1;
}
.rw-donut-board-ca {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-1);
  flex-shrink: 0;
}
.rw-stat-card {
  padding: 16px 18px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  display: flex;
  flex-direction: column;
}
.rw-stats-side {
  display: grid;
  grid-template-rows: auto auto;
  gap: 14px;
  min-width: 0;
}
.rw-stat-title { font-size: 11px; font-weight: 700; color: var(--text-3); text-transform: uppercase; letter-spacing: .08em; margin-bottom: 12px; }
.rw-stat-title svg { color: #16f5ca; }
.rw-stat-body { display: flex; flex-direction: column; gap: 0; }

.rw-week-insights {
  margin-top: 0;
}
.rw-week-card {
  padding: 16px 18px;
  background:
    radial-gradient(circle at top left, rgba(16,185,129,.05), transparent 32%),
    linear-gradient(180deg, rgba(255,255,255,.012), rgba(255,255,255,.004));
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
}
.rw-week-card-head {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 14px;
}
.rw-collapsible-card .rw-card-toggler {
  cursor: pointer;
  user-select: none;
  align-items: center;
  margin-bottom: 0;
}
.rw-collapsible-card .rw-card-toggler:hover .rw-card-chevron { opacity: 1; }
.rw-card-chevron {
  flex-shrink: 0;
  opacity: .45;
  transition: transform .25s ease, opacity .15s ease;
}
.rw-collapsible-card.rw-card-collapsed .rw-card-chevron { transform: rotate(-90deg); }
.rw-card-body {
  overflow: hidden;
  transition: height .25s ease, opacity .2s ease;
  margin-top: 14px;
}
.rw-collapsible-card.rw-card-collapsed .rw-card-body {
  opacity: 0;
}
.rw-week-card-icon {
  width: 36px;
  height: 36px;
  border-radius: 11px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(22,245,202,.18);
  background: rgba(22,245,202,.06);
  color: #16f5ca;
}
.rw-week-card-title {
  font-size: 15px;
  font-weight: 800;
  color: var(--text);
  line-height: 1.2;
}
.rw-week-card-sub {
  margin-top: 4px;
  font-size: 12.5px;
  color: var(--text-3);
}
.rw-week-stack {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.rw-week-box {
  border-radius: 16px;
  padding: 14px 16px;
  border: 1px solid rgba(255,255,255,.07);
  background: rgba(255,255,255,.02);
}
.rw-week-box-best {
  background: rgba(8,54,41,.62);
  border-color: rgba(16,185,129,.35);
}
.rw-week-box-current {
  background: rgba(255,255,255,.025);
}
.rw-week-box-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}
.rw-week-box-head strong {
  font-size: 14px;
  color: var(--text);
}
.rw-week-box-head span {
  font-size: 12px;
  color: var(--text-3);
  text-align: right;
}
.rw-week-metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.rw-week-metrics span {
  display: block;
  font-size: 11.5px;
  color: var(--text-3);
  margin-bottom: 6px;
}
.rw-week-metrics strong {
  display: block;
  font-size: 16px;
  font-weight: 800;
  color: var(--text);
}
.rw-week-metrics small {
  display: block;
  margin-top: 6px;
  font-size: 11.5px;
  font-weight: 700;
}
.rw-week-metrics small.is-up { color: #34d399; }
.rw-week-metrics small.is-down { color: #f87171; }

/* Quick Wins card */
.rw-qw-section { margin-top: 14px; }
.rw-qw-section + .rw-qw-section { margin-top: 12px; }
.rw-qw-section-label {
  display: flex; align-items: center; gap: 6px;
  font-size: 12px; font-weight: 700; color: var(--text-2);
  margin-bottom: 8px;
}
.rw-qw-section-label svg { opacity: .7; }
.rw-qw-count {
  display: inline-flex; align-items: center; justify-content: center;
  width: 18px; height: 18px; border-radius: 50%;
  font-size: 10px; font-weight: 800;
  background: rgba(255,255,255,.08); color: var(--text-3);
}
.rw-qw-item {
  background: rgba(255,255,255,.03);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px 12px;
  margin-bottom: 6px;
}
.rw-qw-item:last-child { margin-bottom: 0; }
.rw-qw-item-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 5px; }
.rw-qw-item-title { font-size: 13px; font-weight: 700; color: var(--text); }
.rw-qw-item-desc { font-size: 12px; color: var(--text-3); line-height: 1.55; }
.rw-qw-badge {
  font-size: 10px; font-weight: 700; padding: 2px 7px; border-radius: 20px;
  white-space: nowrap; flex-shrink: 0;
}
.rw-qw-badge.high { background: rgba(16,185,129,.15); color: #34d399; border: 1px solid rgba(16,185,129,.25); }
.rw-qw-badge.medium { background: rgba(99,102,241,.15); color: #818cf8; border: 1px solid rgba(99,102,241,.25); }
.rw-qw-badge.low { background: rgba(255,255,255,.06); color: var(--text-3); border: 1px solid var(--line); }
.rw-qw-empty { font-size: 12.5px; color: var(--text-3); padding: 6px 0; }

.rw-breakdown-card {
  min-width: 0;
}
.rw-breakdown-head {
  margin-bottom: 14px;
}
.rw-breakdown-sub {
  margin-top: -2px;
  font-size: 12px;
  color: var(--text-3);
}
.rw-breakdown-sect + .rw-breakdown-sect {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}
.rw-breakdown-label {
  margin-bottom: 10px;
  font-size: 11px;
  font-weight: 700;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.rw-breakdown-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

@media (max-width: 1180px) {
  .rw-stats-row {
    grid-template-columns: 1fr;
  }
}

/* Plan breakdown rows */
.rw-plan-row {
  display: grid;
  grid-template-columns: 130px 1fr 120px;
  align-items: center;
  gap: 10px;
  padding: 7px 0;
  border-bottom: 1px solid var(--line);
}
.rw-plan-row:last-child { border-bottom: none; }
.rw-plan-left { display: flex; align-items: center; gap: 7px; min-width: 0; }
.rw-plan-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.rw-plan-name { font-size: 13px; font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rw-plan-pct { font-size: 11px; color: var(--text-3); flex-shrink: 0; }
.rw-plan-bar-wrap { height: 5px; background: var(--bg-3,rgba(255,255,255,.07)); border-radius: 3px; overflow: hidden; }
.rw-plan-bar { height: 100%; border-radius: 3px; transition: width .4s var(--ease); }
.rw-plan-right { display: flex; align-items: center; justify-content: flex-end; gap: 10px; }
.rw-plan-count { font-size: 11.5px; color: var(--text-3); font-variant-numeric: tabular-nums; }
.rw-plan-amount { font-size: 13px; font-weight: 700; color: var(--accent); font-variant-numeric: tabular-nums; min-width: 58px; text-align: right; }

/* Code breakdown rows */
.rw-code-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 0;
  border-bottom: 1px solid var(--line);
}
.rw-code-row:last-child { border-bottom: none; }
.rw-code-tag { font-size: 11px; font-weight: 700; color: var(--accent); background: color-mix(in srgb, var(--accent) 12%, transparent); padding: 2px 8px; border-radius: 4px; min-width: 58px; text-align: center; letter-spacing: .04em; }
.rw-code-stats { flex: 1; display: flex; align-items: center; gap: 4px; }
.rw-code-conv { font-size: 12.5px; font-weight: 700; color: var(--text); font-variant-numeric: tabular-nums; }
.rw-code-leads-n { font-size: 12.5px; font-weight: 600; color: var(--text-2,var(--text)); font-variant-numeric: tabular-nums; }
.rw-code-label { font-size: 11px; color: var(--text-3); }
.rw-code-sep { font-size: 11px; color: var(--text-3); }
.rw-code-total { font-size: 13px; font-weight: 700; color: var(--text); min-width: 24px; text-align: right; font-variant-numeric: tabular-nums; }

/* Chart */
.rw-chart-card { display: flex; flex-direction: column; }
.rw-trend-wrap { flex: 1; overflow: hidden; margin-top: 2px; }
#rw-trend-chart { width: 100%; height: 130px; }

/* Table section collapsible */
/* 4 independent collapsible data sections */
.rw-data-section { margin-top: 0; }
.rw-data-section-hd {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 6px;
  cursor: pointer;
  user-select: none;
  border-top: 1px solid rgba(255,255,255,.07);
  border-bottom: 1px solid rgba(255,255,255,.07);
}
.rw-data-section-hd:hover { background: rgba(255,255,255,.02); }
.rw-data-section-hd:hover .rw-data-section-chevron { opacity: 1; }
.rw-data-section-icon { display: flex; align-items: center; color: #16f5ca; }
.rw-data-section-label { font-size: 14px; font-weight: 500; color: var(--text-1); flex: 1; }
.rw-data-section-badge {
  font-size: 11px; font-weight: 600; color: var(--text-2);
  background: rgba(255,255,255,.08); border-radius: 20px; padding: 2px 8px;
}
.rw-data-section-chevron { opacity: .4; flex-shrink: 0; transition: transform .25s ease, opacity .15s ease; color: var(--text-2); }
.rw-data-section.rw-ds-collapsed .rw-data-section-chevron { transform: rotate(-90deg); }
.rw-data-section-bd { overflow: hidden; transition: height .25s ease, opacity .2s ease; }
.rw-data-section.rw-ds-collapsed .rw-data-section-bd { opacity: 0; }

.rw-table-section { margin-top: 16px; }
.rw-table-section-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 6px;
  cursor: pointer;
  user-select: none;
  border-top: 1px solid rgba(255,255,255,.07);
  border-bottom: 1px solid rgba(255,255,255,.07);
}
.rw-table-section-header:hover { background: rgba(255,255,255,.02); }
.rw-table-section-header:hover .rw-table-section-chevron { opacity: 1; }
.rw-table-section-icon {
  display: flex;
  align-items: center;
  color: var(--text-2);
  opacity: .7;
}
.rw-table-section-label {
  font-size: 14px;
  font-weight: 500;
  color: var(--text-1);
  flex: 1;
}
.rw-table-section-badge {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-2);
  background: rgba(255,255,255,.08);
  border-radius: 20px;
  padding: 2px 8px;
}
.rw-table-section-chevron {
  opacity: .4;
  flex-shrink: 0;
  transition: transform .25s ease, opacity .15s ease;
  color: var(--text-2);
}
.rw-table-section.rw-ts-collapsed .rw-table-section-chevron { transform: rotate(-90deg); }
.rw-table-section-body {
  overflow: hidden;
  transition: height .25s ease, opacity .2s ease;
}
.rw-table-section.rw-ts-collapsed .rw-table-section-body { opacity: 0; }

/* Sub-tabs */
.rw-tabs {
  display: flex;
  gap: 4px;
  margin-bottom: 12px;
  border-bottom: 1px solid var(--line);
  padding-bottom: 0;
}
.rw-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-3);
  border: none;
  background: none;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
}
.rw-tab:hover { color: var(--text); }
.rw-tab.active { color: var(--accent); border-bottom-color: var(--accent); }
.rw-tab-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 18px;
  padding: 0 6px;
  background: var(--accent-soft);
  color: var(--accent);
  border-radius: var(--r-full);
  font-size: 10.5px;
  font-weight: 700;
}

/* View panels */
.rw-view { display: none; }
.rw-view.active { display: block; }

/* Table */
.comm-table-wrap {
  background: var(--bg-1);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  overflow: hidden;
  overflow-x: auto;
}
.comm-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.comm-table th {
  padding: 10px 14px;
  text-align: left;
  font-weight: 600;
  font-size: 11px;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: .08em;
  background: rgba(255,255,255,.02);
  border-bottom: 1px solid var(--line);
  white-space: nowrap;
}
.comm-table td { padding: 11px 14px; border-bottom: 1px solid var(--line); color: var(--text-2); }
.comm-table tr:last-child td { border-bottom: none; }
.comm-table tr:hover td { background: rgba(255,255,255,.02); color: var(--text); }
.comm-customer { font-weight: 500; color: var(--text); }
.comm-amount  { font-weight: 700; color: var(--accent); font-variant-numeric: tabular-nums; }
.comm-amount-accent { color: #31cc94 !important; }
.comm-commission { font-weight: 700; color: var(--ok); font-variant-numeric: tabular-nums; }
.comm-date  { color: var(--text-3); font-size: 12px; white-space: nowrap; }
.comm-empty, .comm-loading { padding: 40px; text-align: center; color: var(--text-3); }
.comm-type-badge { display: inline-block; font-size: 11px; font-weight: 600; padding: 2px 8px; border-radius: 20px; white-space: nowrap; letter-spacing: .02em; }
.comm-type-new     { background: rgba(255,255,255,.06); color: var(--text-2); border: 1px solid rgba(255,255,255,.12); }
.comm-type-renewal { background: rgba(56,189,248,.15); color: #38bdf8; border: 1px solid rgba(56,189,248,.32); }

/* ── Commission detail modal ─────────────────────────────────────── */
.comm-detail-modal { max-width: 720px !important; position: relative; }
.comm-detail-close-abs { position: absolute; top: 16px; right: 16px; z-index: 10; }
.comm-table tbody tr { cursor: pointer; transition: background .12s ease; }

.cdm-hero {
  display: flex; align-items: center; gap: 14px;
  padding: 18px 20px; margin: -22px -22px 18px -22px;
  background: linear-gradient(180deg, rgba(255,255,255,.025), transparent);
  border-bottom: 1px solid var(--line);
}
.cdm-avatar {
  width: 48px; height: 48px; border-radius: 14px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #0a0a0a; font-weight: 800; font-size: 18px;
  display: flex; align-items: center; justify-content: center;
  letter-spacing: -.02em;
}
.cdm-hero-info { flex: 1; min-width: 0; }
.cdm-hero-name { font-size: 16px; font-weight: 700; color: var(--text); letter-spacing: -.01em; word-break: break-word; }
.cdm-hero-badges { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 6px; }

.cdm-kpis {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 10px; margin-bottom: 18px;
}
.cdm-kpi {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: 12px; padding: 12px 14px;
  display: flex; flex-direction: column; gap: 4px;
}
.cdm-kpi-lbl { font-size: 10.5px; font-weight: 600; color: var(--text-3); text-transform: uppercase; letter-spacing: .08em; }
.cdm-kpi-val { font-size: 17px; font-weight: 700; color: var(--text); font-variant-numeric: tabular-nums; }
.cdm-kpi-val.green { color: #31cc94; }
.cdm-kpi-val.accent { color: var(--accent); }

.cdm-calc {
  margin: 0 0 18px 0;
  padding: 14px 18px;
  background: linear-gradient(135deg, rgba(31,221,240,.05), rgba(49,204,148,.04));
  border: 1px solid rgba(31,221,240,.15);
  border-radius: 12px;
}
.cdm-calc-lbl {
  font-size: 10.5px; font-weight: 600; color: var(--text-3);
  text-transform: uppercase; letter-spacing: .08em; margin-bottom: 8px;
}
.cdm-calc-eq {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  font-size: 18px; font-weight: 700; font-variant-numeric: tabular-nums;
}
.cdm-calc-num   { color: var(--text); }
.cdm-calc-rate  { color: var(--accent); }
.cdm-calc-op    { color: var(--text-3); font-weight: 400; font-size: 16px; }
.cdm-calc-result{ color: #31cc94; }

.cdm-section { margin-top: 18px; }
.cdm-section-title {
  font-size: 11px; font-weight: 700; color: var(--text-3);
  text-transform: uppercase; letter-spacing: .08em; margin-bottom: 10px;
}
.cdm-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 0; border-bottom: 1px solid var(--line); gap: 12px;
}
.cdm-row:last-child { border-bottom: none; }
.cdm-row-key { color: var(--text-3); font-size: 13px; }
.cdm-row-val { color: var(--text); font-size: 13px; font-weight: 500; text-align: right; }

.cdm-history {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: 12px; overflow: hidden;
}
.cdm-history-row {
  display: grid; grid-template-columns: 1fr auto auto;
  gap: 12px; padding: 10px 14px;
  border-bottom: 1px solid var(--line);
  align-items: center; font-size: 13px;
}
.cdm-history-row:last-child { border-bottom: none; }
.cdm-history-row.current { background: rgba(31,221,240,.05); }
.cdm-history-date { color: var(--text-3); font-variant-numeric: tabular-nums; font-size: 12px; }
.cdm-history-plan { color: var(--text); font-weight: 500; }
.cdm-history-amount { color: #31cc94; font-weight: 700; font-variant-numeric: tabular-nums; }

.cdm-totals {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 16px; margin-top: 10px;
  background: linear-gradient(135deg, rgba(49,204,148,.08), rgba(49,204,148,.02));
  border: 1px solid rgba(49,204,148,.15);
  border-radius: 12px;
}
.cdm-totals-lbl { font-size: 12px; color: var(--text-3); text-transform: uppercase; letter-spacing: .06em; font-weight: 600; }
.cdm-totals-val { font-size: 20px; font-weight: 800; color: #31cc94; font-variant-numeric: tabular-nums; }

@media (max-width: 640px) {
  .cdm-kpis { grid-template-columns: repeat(2, 1fr); }
}

/* Status badges */
.rw-status {
  display: inline-flex;
  align-items: center;
  padding: 3px 8px;
  border-radius: var(--r-full);
  font-size: 11px;
  font-weight: 700;
  white-space: nowrap;
}
.rw-status-due     { background: rgba(239,68,68,.12);  color: #fca5a5; }
.rw-status-pending { background: rgba(245,158,11,.12); color: #fcd34d; }
.rw-status-paid    { background: var(--ok-soft);       color: #86efac; }

/* Plan badges */
.rw-plan-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--r-full);
  font-size: 11px;
  font-weight: 700;
  background: var(--accent-soft);
  color: var(--accent);
}
.rw-plan-badge.rw-plan-advanced    { background: rgba(83,0,164,.18);  color: #5300a4; }
.rw-plan-badge.rw-plan-performance { background: rgba(63,255,91,.10);  color: #3fff5b; }
.rw-plan-badge.rw-plan-sniper      { background: rgba(164,21,125,.18);   color: #a4157d; }

/* Code badge */
.rw-code-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--r-full);
  font-size: 11px;
  font-weight: 700;
  font-family: 'JetBrains Mono', monospace;
  background: rgba(255,255,255,.05);
  border: 1px solid var(--line-2);
  color: var(--text);
}
.rw-recur-badge { display: inline-block; padding: 2px 9px; border-radius: var(--r-full); font-size: 11px; font-weight: 700; letter-spacing: .02em; }
.rw-recur-new     { background: rgba(16,185,129,.12); color: #10b981; }
.rw-recur-renewal { background: rgba(99,102,241,.12);  color: #a5b4fc; }

/* Discount */
.rw-discount {
  display: inline-block;
  font-size: 11.5px;
  color: var(--warn);
  font-weight: 500;
}

/* Sync status */
.rw-sync-status {
  font-size: 11.5px;
  color: var(--text-3);
  font-variant-numeric: tabular-nums;
}
.rw-sync-ok   { color: var(--ok); }
.rw-sync-warn { color: var(--warn); }
.rw-sync-err  { color: var(--danger); }
.rw-sync-spin { color: var(--accent); }

/* View padding */
#view-commissions { padding: 20px var(--gutter) 40px; }

/* ============ 15. CLASSEMENT ============ */
.cls-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; }
.cls-period-tabs { display: flex; gap: 4px; background: var(--surface-2); border: 1px solid var(--line); border-radius: var(--r-sm); padding: 3px; }
.cls-period-btn { padding: 6px 16px; border-radius: 6px; font-size: 13px; font-weight: 600; color: var(--text-3); background: none; border: none; cursor: pointer; transition: all var(--t-fast) var(--ease); }
.cls-period-btn.active { background: var(--surface-3); color: var(--text-1); }
.cls-period-btn:hover:not(.active) { color: var(--text-2); }

/* Podium */
.cls-podium-wrap { margin-bottom: 20px; }
.cls-podium { display: flex; align-items: flex-end; justify-content: center; gap: 12px; min-height: 260px; }
.cls-podium-item { display: flex; flex-direction: column; align-items: center; flex: 1; max-width: 200px; }
.cls-podium-avatar {
  position: relative; width: 64px; height: 64px; border-radius: 18px;
  border: 2px solid; display: flex; align-items: center; justify-content: center;
  margin-bottom: 10px;
}
.cls-podium-badge {
  position: absolute; bottom: -8px; left: 50%; transform: translateX(-50%);
  font-size: 10px; font-weight: 800; color: #000; padding: 2px 7px;
  border-radius: 20px; white-space: nowrap;
}
.cls-podium-code { font-size: 15px; font-weight: 800; color: var(--text-1); margin-bottom: 3px; }
.cls-podium-comm { font-size: 18px; font-weight: 900; color: var(--text-1); font-variant-numeric: tabular-nums; }
.cls-podium-sub  { font-size: 11px; color: var(--text-3); margin-bottom: 10px; }
.cls-podium-bar  {
  width: 100%; border-radius: 10px 10px 0 0;
  display: flex; align-items: flex-end; justify-content: center; padding-bottom: 10px;
}
.cls-podium-bar-num { font-size: 42px; font-weight: 900; opacity: .12; color: #fff; }
.cls-podium-1 .cls-podium-avatar { width: 72px; height: 72px; border-radius: 20px; }
.cls-podium-1 .cls-podium-comm { font-size: 22px; }

/* KPIs */
.cls-kpi-row { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; margin-bottom: 16px; }
.cls-kpi {
  background: var(--surface-2); border: 1px solid var(--line); border-radius: var(--r-sm);
  padding: 16px 18px; display: flex; flex-direction: column; gap: 4px;
}
.cls-kpi-icon { margin-bottom: 4px; }
.cls-kpi-val { font-size: 22px; font-weight: 800; color: var(--text-1); font-variant-numeric: tabular-nums; }
.cls-kpi-lbl { font-size: 11px; color: var(--text-3); font-weight: 500; text-transform: uppercase; letter-spacing: .05em; }

/* Bottom row */
.cls-bottom-row { display: grid; grid-template-columns: 1fr 1.6fr; gap: 14px; }
.cls-top-sale-card, .cls-pulse-card {
  background: var(--surface-2); border: 1px solid var(--line);
  border-radius: var(--r-md); padding: 20px 22px;
}

/* Top sale */
.cls-topsale-head { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; }
.cls-topsale-icon { width: 40px; height: 40px; border-radius: 12px; background: rgba(245,158,11,.12); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.cls-topsale-title { font-size: 15px; font-weight: 700; color: var(--text-1); }
.cls-topsale-sub { font-size: 12px; color: var(--text-3); margin-top: 2px; }
.cls-record-badge { margin-left: auto; padding: 3px 10px; border-radius: 20px; font-size: 11px; font-weight: 700; background: rgba(245,158,11,.15); color: #f59e0b; border: 1px solid rgba(245,158,11,.3); flex-shrink: 0; }
.cls-topsale-body { display: flex; align-items: center; gap: 16px; }
.cls-topsale-avatar { width: 52px; height: 52px; border-radius: 14px; background: rgba(245,158,11,.12); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.cls-topsale-amount { font-size: 28px; font-weight: 900; color: var(--text-1); }
.cls-topsale-meta { font-size: 12px; color: var(--text-3); margin-top: 3px; }

/* Pulse chart */
.cls-pulse-head { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.cls-pulse-dot { width: 8px; height: 8px; border-radius: 50%; background: #19f0d7; flex-shrink: 0; box-shadow: 0 0 8px #19f0d7; }
.cls-pulse-title { font-size: 15px; font-weight: 700; color: var(--text-1); }
.cls-pulse-sub { font-size: 12px; color: var(--text-3); margin-top: 2px; }
.cls-pulse-bars { display: flex; align-items: flex-end; gap: 8px; height: 120px; }
.cls-pulse-bar-wrap { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 5px; height: 100%; }
.cls-pulse-bar-val { font-size: 11px; font-weight: 600; color: var(--text-3); }
.cls-pulse-bar-outer { flex: 1; width: 100%; background: rgba(255,255,255,.04); border-radius: 6px 6px 0 0; display: flex; align-items: flex-end; overflow: hidden; }
.cls-pulse-bar-inner { width: 100%; background: rgba(25,240,215,.25); border-radius: 6px 6px 0 0; transition: height .5s var(--ease); }
.cls-pulse-bar-inner.active { background: rgba(25,240,215,.55); }
.cls-pulse-bar-lbl { font-size: 10px; color: var(--text-3); white-space: nowrap; }
.cls-pulse-bar-lbl.active { color: #19f0d7; font-weight: 700; }
.cls-empty { color: var(--text-3); font-size: 13px; padding: 20px 0; text-align: center; }

/* ============ 16. FACTURATION ============ */
.facture-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 16px; }
@media (max-width: 980px) { .facture-layout { grid-template-columns: 1fr; } }
.facture-form-col, .facture-history-col { display: flex; flex-direction: column; gap: 16px; }
.facture-card {
  padding: 22px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-md);
}
.facture-title { font-size: 15px; font-weight: 700; margin-bottom: 14px; display: flex; align-items: center; gap: 8px; }
.facture-fields { display: flex; flex-direction: column; gap: 12px; }
.facture-field { width: 100%; }
.facture-submit-btn { width: 100%; padding: 12px; font-size: 14px; margin-top: 8px; }
.facture-result { margin-top: 12px; padding: 12px; background: var(--ok-soft); border: 1px solid var(--ok-ring); border-radius: var(--r-sm); color: #86efac; font-size: 13px; }
.facture-result.err { background: var(--danger-soft); border-color: var(--danger-ring); color: #fca5a5; }
.facture-history { display: flex; flex-direction: column; gap: 6px; max-height: 600px; overflow-y: auto; }
.history-row {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  gap: 12px; align-items: center;
  padding: 10px 12px;
  background: rgba(255,255,255,.02);
  border: 1px solid var(--line); border-radius: var(--r-sm);
  font-size: 13px;
  transition: all var(--t-base) var(--ease);
}
.history-row:hover { background: rgba(255,255,255,.04); border-color: var(--line-2); }
.history-date { color: var(--text-3); font-size: 12px; font-variant-numeric: tabular-nums; }
.history-id { font-family: 'JetBrains Mono', monospace; font-size: 11.5px; color: var(--text-2); }
.history-dl { padding: 4px 8px; font-size: 11px; }
.history-empty, .history-loading { padding: 20px; text-align: center; color: var(--text-3); }
.invoice-id { font-family: 'JetBrains Mono', monospace; font-size: 13px; color: var(--accent); }

/* ============ 16. TICKET PANEL (tp-*) ============ */
.tp-topbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; gap: 14px; flex-wrap: wrap; }
.tp-topbar-actions { display: flex; gap: 10px; }
.tp-title { font-size: 20px; font-weight: 700; }
.tp-subtitle { font-size: 13px; color: var(--text-3); margin-top: 4px; }
.tp-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 20px; }
@media (max-width: 1100px) { .tp-grid { grid-template-columns: 1fr; } }
.tp-editor, .tp-preview-wrap { display: flex; flex-direction: column; gap: 14px; }
.tp-card { padding: 18px; background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--r-lg); }
.tp-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.tp-header h3 { font-size: 14px; }
.tp-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 12px; }
.tp-field-label { font-size: 12px; font-weight: 600; color: var(--text-2); }
.tp-input { width: 100%; }
.tp-hint { font-size: 11.5px; color: var(--text-3); margin-top: 4px; }
.tp-row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.tp-color-wrap { display: flex; gap: 8px; align-items: center; }
.tp-md-toolbar { display: flex; gap: 4px; margin-bottom: 6px; padding: 4px; background: rgba(255,255,255,.02); border: 1px solid var(--line); border-radius: var(--r-sm); }
.tp-md-btn { padding: 4px 8px; font-size: 12px; border: none; background: transparent; }
.tp-md-btn:hover { background: rgba(255,255,255,.06); }
.tp-radio, .tp-toggle, .tp-cat-enabled { display: inline-flex; gap: 6px; align-items: center; cursor: pointer; font-size: 13px; }
.tp-cats { display: flex; flex-direction: column; gap: 10px; }
.tp-cat { background: rgba(255,255,255,.02); border: 1px solid var(--line); border-radius: var(--r-md); overflow: hidden; transition: border-color var(--t-base) var(--ease); }
.tp-cat:hover { border-color: var(--line-2); }
.tp-cat.drag-over { border-color: var(--accent); background: var(--accent-soft); }
.tp-cat-head { display: flex; align-items: center; gap: 10px; padding: 10px 12px; background: rgba(255,255,255,.02); }
.tp-cat-drag { cursor: grab; color: var(--muted); font-size: 14px; }
.tp-cat-drag:active { cursor: grabbing; }
.tp-cat-emoji input { width: 50px; text-align: center; }
.tp-cat-label input { width: 100%; }
.tp-cat-label { flex: 1; }
.tp-cat-del { color: var(--danger); padding: 4px 8px; }
.tp-cat-body { padding: 12px; display: grid; grid-template-columns: 1fr 1fr; gap: 10px; border-top: 1px solid var(--line); }
.tp-cat-mode, .tp-cat-style, .tp-cat-reorder { display: flex; flex-direction: column; gap: 4px; }
.tp-cat-mode label, .tp-cat-style label { font-size: 11px; color: var(--text-3); }
.tp-actions { display: flex; gap: 10px; }
.tp-pub-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.tp-pub-info { font-size: 12px; color: var(--text-3); margin-top: 8px; }

.tp-preview { background: #2b2d31; border-radius: var(--r-md); padding: 14px; border: 1px solid var(--line); }
.tp-preview-head { color: #b5bac1; font-size: 12px; margin-bottom: 8px; font-weight: 600; }
.tp-discord-msg { display: flex; gap: 12px; padding: 4px 0; }
.tp-discord-avatar { width: 40px; height: 40px; border-radius: 50%; background: var(--grad-brand); flex-shrink: 0; }
.tp-discord-body { flex: 1; min-width: 0; color: #dbdee1; }
.tp-discord-author { font-weight: 600; color: #f2f3f5; display: flex; align-items: center; gap: 6px; font-size: 14px; }
.tp-discord-bot { background: #5865f2; color: #fff; font-size: 10px; padding: 1px 4px; border-radius: 3px; font-weight: 700; }
.tp-discord-embed { margin-top: 6px; background: #2b2d31; border-left: 4px solid var(--accent); border-radius: 0 4px 4px 0; padding: 10px 14px; max-width: 520px; }
.tp-discord-title { font-weight: 700; color: #fff; font-size: 15px; margin-bottom: 4px; }
.tp-discord-desc { font-size: 13px; color: #dbdee1; line-height: 1.4; white-space: pre-wrap; }
.tp-discord-image img { border-radius: 4px; margin-top: 8px; max-width: 100%; }
.tp-discord-footer { font-size: 11px; color: #949ba4; margin-top: 6px; }
.tp-discord-components { margin-top: 6px; display: flex; flex-direction: column; gap: 4px; }
.tp-discord-btn-row { display: flex; gap: 4px; flex-wrap: wrap; }
.tp-discord-btn { padding: 6px 12px; background: #4e5058; border-radius: 3px; font-size: 13px; font-weight: 500; color: #fff; }
.tp-discord-select { background: #1e1f22; padding: 8px 12px; border-radius: 4px; color: #dbdee1; font-size: 13px; border: 1px solid #3f4147; cursor: pointer; }

/* ============ 17. WEBHOOKS ============ */
#view-webhooks { max-width: 1480px; }
.wh-view { display: none; flex-direction: column; gap: 20px; }
.wh-view.active { display: flex; }
.wh-topbar { display: flex; justify-content: space-between; align-items: flex-start; gap: 14px; flex-wrap: wrap; margin-bottom: 14px; }
.wh-topbar-left { flex: 1; }
.wh-topbar-actions { display: flex; gap: 10px; }
.wh-title { font-size: 20px; font-weight: 700; }
.wh-subtitle { font-size: 13px; color: var(--text-3); margin-top: 4px; max-width: 720px; line-height: 1.45; }
.wh-flow {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin: 14px 0;
}
.wh-flow-step {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  background: linear-gradient(135deg, rgba(45,212,191,.07), rgba(255,255,255,.025));
}
.wh-flow-num {
  width: 26px;
  height: 26px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  background: var(--accent-soft);
  color: var(--accent);
  font-weight: 800;
  font-size: 12px;
}
.wh-flow-step strong { display: block; font-size: 13px; color: var(--text); }
.wh-flow-step p { margin-top: 2px; color: var(--text-3); font-size: 12px; line-height: 1.35; }
.wh-subtabs {
  display: inline-flex;
  align-self: flex-start;
  gap: 4px;
  padding: 5px;
  margin: 2px 0 16px;
  background: rgba(255,255,255,.035);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  box-shadow: var(--sh-inner);
}
.wh-subtab { padding: 9px 16px; font-size: 12.5px; font-weight: 700; color: var(--text-2); border: none; background: transparent; border-radius: var(--r-sm); transition: all var(--t-base) var(--ease); }
.wh-subtab:hover { background: rgba(255,255,255,.055); color: var(--text); }
.wh-subtab.active { background: var(--accent-soft); color: var(--accent); box-shadow: 0 0 0 1px var(--accent-ring) inset; }
.wh-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(330px, 1fr)); gap: 16px; }
.wh-card { padding: 18px; background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--r-xl); display: flex; flex-direction: column; gap: 12px; transition: all var(--t-base) var(--ease); min-height: 220px; position: relative; overflow: hidden; }
.wh-card:hover { border-color: var(--line-2); transform: translateY(-2px); box-shadow: var(--sh-md); }
.wh-card::before {
  content: '';
  position: absolute;
  inset: 0 auto 0 0;
  width: 3px;
  background: var(--accent);
  opacity: .85;
}
.wh-card-head { display: flex; align-items: center; gap: 10px; }
.wh-card-avatar { width: 44px; height: 44px; border-radius: 50%; overflow: hidden; background: var(--grad-brand-soft); flex-shrink: 0; display: inline-flex; align-items: center; justify-content: center; color: var(--accent); font-weight: 800; }
.wh-card-avatar img { width: 100%; height: 100%; object-fit: cover; }
.wh-card-info { flex: 1; min-width: 0; }
.wh-card-name { font-weight: 800; font-size: 14.5px; color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.wh-card-meta { font-size: 11.5px; color: var(--text-3); margin-top: 3px; }
.wh-card-desc { font-size: 12.5px; color: var(--text-2); line-height: 1.45; }
.wh-card-note { padding: 10px 12px; border-radius: var(--r-sm); background: rgba(245,158,11,.08); border: 1px solid rgba(245,158,11,.22); color: var(--text-2); font-size: 12px; line-height: 1.4; }
.wh-card-color { display: none; }
.wh-card-actions { display: flex; gap: 6px; flex-wrap: wrap; margin-top: auto; padding-top: 8px; border-top: 1px solid var(--line); }

.wh-composer { display: grid; grid-template-columns: minmax(420px, .95fr) minmax(460px, 1.05fr); gap: 20px; align-items: start; }
@media (max-width: 1100px) { .wh-composer { grid-template-columns: 1fr; } }
.wh-composer-form, .wh-composer-preview {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  background: var(--bg-2);
}
.wh-composer-preview { position: sticky; top: 92px; }
.wh-section-title { font-size: 13px; font-weight: 700; color: var(--text); margin-bottom: 10px; display: flex; align-items: center; gap: 8px; }
.wh-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 10px; }
.wh-label { font-size: 12px; font-weight: 600; color: var(--text-2); }
.wh-input { width: 100%; }
.wh-hint, .wh-inst { font-size: 11.5px; color: var(--text-3); }
.wh-callout {
  padding: 12px 14px;
  border: 1px solid rgba(45,212,191,.28);
  background: rgba(45,212,191,.08);
  border-radius: var(--r-md);
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.45;
}
.wh-callout strong { color: var(--text); }
.wh-callout-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 10px; }
.wh-callout-muted { border-color: var(--line); background: rgba(255,255,255,.03); }
.wh-callout.error { border-color: rgba(239,68,68,.35); background: rgba(239,68,68,.1); color: #fecaca; }
.wh-callout.success { border-color: rgba(34,197,94,.35); background: rgba(34,197,94,.1); color: #bbf7d0; }
.wh-row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.wh-color { display: flex; gap: 8px; align-items: center; }
.wh-embeds-list { display: flex; flex-direction: column; gap: 10px; }
.wh-embed-card {
  padding: 12px;
  background: rgba(255,255,255,.02);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  border-left: 3px solid var(--accent);
}
.wh-embed-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; gap: 8px; }
.wh-embed-title-preview { font-weight: 600; color: var(--text); font-size: 13px; }
.wh-embed-color-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--accent); }
.wh-embed-body { display: flex; flex-direction: column; gap: 8px; }
.wh-embed-actions { display: flex; gap: 6px; }
.wh-embed-btn { padding: 4px 8px; font-size: 11px; }
.wh-embed-toggle { display: flex; gap: 6px; align-items: center; cursor: pointer; }
.wh-embed-empty { padding: 20px; text-align: center; color: var(--text-3); font-size: 12px; }
.wh-embeds-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
.wh-compose-actions { display: flex; gap: 10px; margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--line); flex-wrap: wrap; }
.wh-deploy-preset { background: rgba(255,255,255,.03); border: 1px solid var(--line); border-radius: var(--r-sm); padding: 10px 12px; font-size: 12px; color: var(--text-3); margin-top: 6px; }

.wh-preview { background: #313338; border-radius: var(--r-lg); border: 1px solid var(--line); overflow: hidden; min-height: 110px; }
.wh-preview-head { padding: 8px 14px; background: rgba(0,0,0,.2); color: #b5bac1; font-size: 12px; font-weight: 600; }
.wh-preview-msg { padding: 12px 14px; display: flex; gap: 12px; }
.wh-preview-avatar { width: 40px; height: 40px; border-radius: 50%; background: var(--grad-brand); flex-shrink: 0; overflow: hidden; }
.wh-preview-avatar img { width: 100%; height: 100%; object-fit: cover; }
.wh-preview-body { flex: 1; min-width: 0; color: #dbdee1; }
.wh-preview-author { display: flex; align-items: center; gap: 6px; font-size: 14px; }
.wh-preview-name { font-weight: 600; color: #f2f3f5; }
.wh-preview-badge { background: #5865f2; color: #fff; font-size: 10px; padding: 1px 4px; border-radius: 3px; font-weight: 700; }
.wh-preview-time { color: #949ba4; font-size: 11px; }
.wh-preview-content { color: #dbdee1; font-size: 14px; line-height: 1.4; white-space: pre-wrap; margin-top: 2px; }
.wh-preview-embeds { display: flex; flex-direction: column; gap: 6px; margin-top: 6px; }
.wh-preview-embed { display: grid; grid-template-columns: 1fr auto; border-left: 4px solid var(--accent); background: #2b2d31; border-radius: 0 4px 4px 0; padding: 10px 14px; max-width: 520px; }
.wh-preview-embed-main { min-width: 0; }
.wh-preview-title { font-weight: 700; color: #fff; font-size: 15px; margin-bottom: 4px; }
.wh-preview-desc { font-size: 13px; color: #dbdee1; line-height: 1.4; white-space: pre-wrap; }
.wh-preview-footer { font-size: 11px; color: #949ba4; margin-top: 6px; }
.wh-preview-author-icon { width: 20px; height: 20px; border-radius: 50%; }
.wh-preview-embed-thumb img { border-radius: 4px; max-width: 80px; }
.wh-preview-image img { margin-top: 8px; border-radius: 4px; max-width: 100%; }
.wh-preview-label { display: flex; justify-content: space-between; gap: 10px; font-size: 11px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: 0.08em; }
.wh-preview-hint { color: var(--text-3); font-size: 11px; font-style: italic; text-align: right; }

.wh-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(360px, 1fr)); gap: 14px; }
.wh-inst { display: flex; gap: 12px; align-items: center; padding: 14px; background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--r-lg); }
.wh-inst-avatar { width: 38px; height: 38px; border-radius: 50%; background: var(--grad-brand-soft); flex-shrink: 0; overflow: hidden; }
.wh-inst-info { flex: 1; min-width: 0; }
.wh-inst-name { font-weight: 600; font-size: 13.5px; color: var(--text); }
.wh-inst-loc { font-size: 12px; color: var(--text-3); margin-top: 2px; }
.wh-inst-status { margin-top: 5px; font-size: 11.5px; color: var(--accent); }
.wh-inst-actions { display: flex; gap: 6px; }

.wh-modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.65); z-index: 100; display: none; align-items: center; justify-content: center; padding: 20px; }
.wh-modal-overlay.open { display: flex; animation: fade-in var(--t-base) var(--ease); }
.wh-modal { background: var(--bg-1); border: 1px solid var(--line-2); border-radius: var(--r-xl); box-shadow: var(--sh-lg); max-width: 640px; width: 100%; max-height: 85vh; display: flex; flex-direction: column; overflow: hidden; animation: modal-in var(--t-slow) var(--ease) both; }
@keyframes modal-in { from { opacity: 0; transform: scale(.96) translateY(8px); } to { opacity: 1; transform: scale(1) translateY(0); } }
@keyframes fade-in { from { opacity: 0 } to { opacity: 1 } }
.wh-modal-head { padding: 18px 22px; border-bottom: 1px solid var(--line); display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.wh-modal-body { padding: 22px; overflow-y: auto; }
.wh-modal-foot { padding: 16px 22px; border-top: 1px solid var(--line); display: flex; justify-content: flex-end; gap: 10px; }
.wh-modal-section { margin-bottom: 18px; }
.wh-empty { padding: 40px; text-align: center; color: var(--text-3); }
.wh-empty-icon { font-size: 36px; margin-bottom: 8px; opacity: .5; }

@media (max-width: 900px) {
  .wh-flow { grid-template-columns: 1fr; }
  .wh-grid, .wh-list { grid-template-columns: 1fr; }
  .wh-subtabs { width: 100%; }
  .wh-subtab { flex: 1; }
  .wh-composer-preview { position: static; }
}

/* ============ 18. CUSTOM COMMANDS ============ */
.cc-layout { display: grid; grid-template-columns: 320px 1fr; gap: 20px; }
@media (max-width: 980px) { .cc-layout { grid-template-columns: 1fr; } }
.cc-list-col, .cc-editor-col { display: flex; flex-direction: column; gap: 14px; }
.cc-section { padding: 16px; background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--r-lg); }
.cc-list { display: flex; flex-direction: column; gap: 6px; max-height: 560px; overflow-y: auto; padding-right: 4px; }
.cc-item { padding: 12px; background: rgba(255,255,255,.02); border: 1px solid var(--line); border-radius: var(--r-md); cursor: pointer; transition: all var(--t-base) var(--ease); display: flex; align-items: center; gap: 10px; }
.cc-item:hover { border-color: var(--line-2); background: rgba(255,255,255,.04); transform: translateX(2px); }
.cc-item.active { background: var(--accent-soft); border-color: var(--accent-ring); }
.cc-item-main { flex: 1; min-width: 0; }
.cc-item-name { font-weight: 600; font-size: 13.5px; font-family: 'JetBrains Mono', monospace; color: var(--accent); }
.cc-item-desc { font-size: 11.5px; color: var(--text-3); margin-top: 2px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cc-item-side { display: flex; flex-direction: column; gap: 4px; align-items: flex-end; }
.cc-list-empty { padding: 20px; text-align: center; color: var(--text-3); font-size: 12.5px; }
.cc-empty { padding: 48px 20px; text-align: center; color: var(--text-3); }
.cc-empty-icon { font-size: 40px; opacity: .4; margin-bottom: 8px; }
.cc-empty-title { font-size: 15px; color: var(--text-2); font-weight: 600; margin-bottom: 4px; }
.cc-empty-hint { font-size: 12.5px; }
.cc-editor { display: flex; flex-direction: column; gap: 14px; }
.cc-editor-footer { display: flex; justify-content: space-between; align-items: center; gap: 10px; margin-top: 10px; padding-top: 14px; border-top: 1px solid var(--line); flex-wrap: wrap; }
.cc-editor-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.cc-deploy-info { font-size: 12px; color: var(--text-3); }
.cc-scope-badge { background: var(--accent-soft); border-color: var(--accent-ring); color: var(--accent); }
.cc-badge { background: rgba(255,255,255,.05); border-color: var(--line-2); color: var(--text-2); }
.cc-badge-on { background: var(--ok-soft); border-color: var(--ok-ring); color: #86efac; }
.cc-badge-off { background: rgba(100,116,139,.15); border-color: rgba(100,116,139,.35); color: var(--text-3); }
.cc-badge-pending { background: var(--warn-soft); border-color: var(--warn-ring); color: #fcd34d; }
.cc-response-type { display: flex; gap: 10px; flex-wrap: wrap; }
.cc-response-type label { display: inline-flex; align-items: center; gap: 6px; cursor: pointer; font-size: 13px; padding: 8px 12px; background: rgba(255,255,255,.02); border: 1px solid var(--line); border-radius: var(--r-sm); transition: all var(--t-base) var(--ease); margin: 0; }
.cc-switch-row { display: flex; gap: 14px; align-items: center; }
.cc-fields-wrap { display: flex; flex-direction: column; gap: 10px; }
.cc-fields-header { display: flex; justify-content: space-between; align-items: center; }
.cc-fields-list { display: flex; flex-direction: column; gap: 8px; }
.cc-field-row { display: grid; grid-template-columns: 1fr 2fr auto auto; gap: 8px; align-items: center; padding: 8px; background: rgba(255,255,255,.02); border: 1px solid var(--line); border-radius: var(--r-sm); }
.cc-field-inline { display: inline-flex; gap: 6px; align-items: center; font-size: 12px; }
.cc-field-del { color: var(--danger); padding: 4px 6px; }
.cc-v2-head { display: flex; justify-content: space-between; gap: 14px; align-items: flex-start; margin-bottom: 12px; }
.cc-v2-head-actions { display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.cc-v2-hint { margin: 6px 0 0; font-size: 12px; color: var(--text-3); line-height: 1.55; }
.cc-v2-builder { display: flex; flex-direction: column; gap: 14px; }
.cc-v2-mode-switch { display: flex; gap: 8px; flex-wrap: wrap; }
.cc-v2-mode-switch .btn.active {
  background: rgba(31,221,240,.12);
  border-color: rgba(31,221,240,.28);
  color: var(--text);
}
.cc-v2-simple {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 14px;
  border-radius: var(--r-md);
  background: rgba(255,255,255,.025);
  border: 1px solid var(--line);
}
.cc-v2-simple[hidden] { display: none !important; }
.cc-v2-simple-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.cc-v2-simple-separator {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px;
  padding: 12px;
  border-radius: 12px;
  border: 1px dashed rgba(255,255,255,.14);
  background: rgba(255,255,255,.02);
}
.cc-v2-builder-top { display: flex; gap: 12px; flex-wrap: wrap; }
.cc-v2-color-field { max-width: 280px; }
.cc-v2-color-row { display: flex; gap: 10px; align-items: center; }
#cc-v2-accent-color-picker { width: 54px; min-width: 54px; height: 42px; padding: 0; border-radius: 12px; overflow: hidden; }
.cc-v2-builder-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.cc-v2-blocks { display: flex; flex-direction: column; gap: 12px; }
.cc-v2-block-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 14px;
  background: rgba(255,255,255,.025);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
}
.cc-v2-block-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.cc-v2-block-title {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .01em;
  color: var(--text-2);
}
.cc-v2-block-actions { display: flex; gap: 6px; flex-wrap: wrap; }
.cc-v2-inline-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.cc-v2-sublist { display: flex; flex-direction: column; gap: 10px; }
.cc-v2-subitem {
  padding: 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.025);
}
.cc-v2-subitem-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  margin-bottom: 10px;
}
.cc-v2-separator-box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px;
  border-radius: 12px;
  border: 1px dashed rgba(255,255,255,.15);
  color: var(--text-3);
}
.cc-v2-empty {
  padding: 18px;
  border-radius: 14px;
  border: 1px dashed rgba(255,255,255,.14);
  color: var(--text-3);
  text-align: center;
  font-size: 12.5px;
}
.cc-v2-json-wrap { margin-top: 6px; }
.cc-v2-json-error {
  margin-top: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(244,63,94,.12);
  border: 1px solid rgba(244,63,94,.28);
  color: #fda4af;
  font-size: 12px;
  line-height: 1.5;
}
#cc-v2-json { min-height: 320px; font-family: 'JetBrains Mono', monospace; font-size: 12.5px; line-height: 1.55; }
.cc-preview-v2 {
  --v2-accent: #2dd4bf;
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 8px;
  padding: 16px 16px 16px 18px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  background: rgba(18, 21, 32, .92);
  overflow: hidden;
}
.cc-preview-v2::before {
  content: '';
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: var(--v2-accent);
}
.cc-preview-v2-text,
.cc-preview-v2-section-text {
  color: #eef2ff;
  font-size: 13px;
  line-height: 1.6;
  white-space: pre-wrap;
  word-break: break-word;
}
.cc-preview-v2-separator {
  height: 1px;
  background: rgba(255,255,255,.1);
  border-radius: 999px;
}
.cc-preview-v2-separator.large { margin: 6px 0; }
.cc-preview-v2-buttons { display: flex; gap: 8px; flex-wrap: wrap; }
.cc-preview-v2-button {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.1);
  font-size: 12.5px;
  font-weight: 600;
  color: #eef2ff;
  background: rgba(255,255,255,.04);
}
.cc-preview-v2-button.primary { background: #5865f2; border-color: rgba(88,101,242,.55); }
.cc-preview-v2-button.secondary { background: #4b5563; border-color: rgba(107,114,128,.55); }
.cc-preview-v2-button.success { background: #1f8b4c; border-color: rgba(34,197,94,.45); }
.cc-preview-v2-button.danger { background: #9f1239; border-color: rgba(244,63,94,.45); }
.cc-preview-v2-button.link { background: rgba(56,189,248,.18); border-color: rgba(56,189,248,.35); }
.cc-preview-v2-select {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 12px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 12px;
  background: rgba(255,255,255,.03);
}
.cc-preview-v2-select-head { display: flex; justify-content: space-between; gap: 12px; font-size: 12px; color: var(--text-3); }
.cc-preview-v2-select-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
  color: #eef2ff;
}
.cc-preview-v2-option-list { display: flex; flex-direction: column; gap: 8px; }
.cc-preview-v2-option { display: flex; justify-content: space-between; gap: 12px; padding: 10px 12px; border-radius: 10px; background: rgba(255,255,255,.03); }
.cc-preview-v2-option-main { display: flex; flex-direction: column; gap: 4px; }
.cc-preview-v2-option-label { color: #eef2ff; font-size: 12.5px; font-weight: 600; }
.cc-preview-v2-option-desc { color: var(--text-3); font-size: 11.5px; }
.cc-preview-v2-option-value { color: var(--accent); font-size: 11px; font-family: 'JetBrains Mono', monospace; }
.cc-preview-v2-section {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  padding: 12px;
  border-radius: 12px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.08);
}
.cc-preview-v2-section-body { display: flex; flex-direction: column; gap: 8px; }
.cc-preview-v2-thumb {
  width: 72px;
  height: 72px;
  border-radius: 12px;
  object-fit: cover;
  border: 1px solid rgba(255,255,255,.08);
}
.cc-preview-v2-image {
  max-width: 100%;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.08);
}
.cc-preview-v2-error {
  padding: 12px 14px;
  border-radius: 12px;
  background: rgba(244,63,94,.12);
  border: 1px solid rgba(244,63,94,.28);
  color: #fda4af;
  font-size: 12.5px;
  line-height: 1.55;
}
@media (max-width: 900px) {
  .cc-v2-inline-grid { grid-template-columns: 1fr; }
  .cc-v2-simple-grid { grid-template-columns: 1fr; }
  .cc-v2-head { flex-direction: column; }
  .cc-v2-head-actions { justify-content: flex-start; }
  .cc-v2-simple-separator { flex-direction: column; align-items: stretch; }
}

/* ============ 19. COMMAND PALETTE ============ */
.cmdk, #cmdk {
  position: fixed; inset: 0; z-index: 200;
  display: none; align-items: flex-start; justify-content: center;
  padding-top: 15vh;
}
.cmdk.open, #cmdk.open { display: flex; animation: fade-in var(--t-base) var(--ease); }
.cmdk-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.55); }
.cmdk-panel {
  position: relative;
  width: min(620px, calc(100vw - 32px));
  background: var(--bg-2);
  border: 1px solid var(--line-2);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-lg);
  overflow: hidden;
  animation: cmdk-in var(--t-slow) var(--ease) both;
}
@keyframes cmdk-in { from { opacity: 0; transform: translateY(-12px) scale(.98); } to { opacity: 1; transform: translateY(0) scale(1); } }
.cmdk-input-wrap { display: flex; align-items: center; gap: 10px; padding: 4px 16px; border-bottom: 1px solid var(--line); }
.cmdk-prefix { color: var(--text-3); font-size: 14px; }
.cmdk-input { flex: 1; border: none !important; background: transparent !important; padding: 18px 4px !important; font-size: 16px !important; box-shadow: none !important; }
.cmdk-input:focus { box-shadow: none !important; background: transparent !important; border: none !important; }
.cmdk-esc { font-size: 11px; color: var(--muted); }
.cmdk-results { max-height: 52vh; overflow-y: auto; padding: 8px; }
.cmdk-group-label { font-size: 10.5px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); padding: 10px 12px 4px; }
.cmdk-result { display: flex; align-items: center; gap: 12px; padding: 10px 12px; border-radius: var(--r-sm); cursor: pointer; transition: background var(--t-fast) var(--ease); }
.cmdk-result:hover, .cmdk-result.active, .cmdk-result[aria-selected="true"] { background: var(--accent-soft); color: var(--accent); }
.cmdk-result-icon { font-size: 16px; width: 22px; text-align: center; }
.cmdk-result-main { flex: 1; min-width: 0; }
.cmdk-result-name { font-size: 13.5px; font-weight: 600; color: var(--text); }
.cmdk-result:hover .cmdk-result-name, .cmdk-result.active .cmdk-result-name { color: var(--accent); }
.cmdk-result-desc { font-size: 11.5px; color: var(--text-3); margin-top: 1px; }
.cmdk-result-kbd { display: inline-flex; gap: 3px; }
.cmdk-empty { padding: 28px; text-align: center; color: var(--text-3); font-size: 13px; }
.cmdk-footer { display: flex; align-items: center; gap: 14px; padding: 8px 16px; border-top: 1px solid var(--line); background: rgba(0,0,0,.2); font-size: 11px; color: var(--text-3); }

/* ============ 20. TOAST ============ */
.toast, #toast {
  position: fixed;
  top: 20px; right: 20px;
  padding: 12px 18px;
  background: var(--bg-2);
  border: 1px solid var(--line-2);
  border-radius: var(--r-md);
  color: var(--text);
  font-size: 13.5px;
  box-shadow: var(--sh-lg);
  z-index: 1000;
  opacity: 0;
  transform: translateX(20px);
  pointer-events: none;
  transition: all var(--t-base) var(--ease);
}
.toast.visible, #toast.visible { opacity: 1; transform: translateX(0); pointer-events: auto; }
.toast.success, #toast.success { border-left: 3px solid var(--ok); }
.toast.error, #toast.error { border-left: 3px solid var(--danger); }
.toast.warn, #toast.warn { border-left: 3px solid var(--warn); }

/* ============ 21. LOGIN ============ */
#login-page {
  position: fixed; inset: 0;
  display: none;
  align-items: center; justify-content: center;
  background: var(--bg);
  z-index: 300; padding: 20px;
}
#login-page.visible { display: flex; }
.login-box {
  background: var(--bg-2);
  border: 1px solid var(--line-2);
  border-radius: var(--r-lg);
  padding: 36px 34px;
  box-shadow: var(--sh-lg);
  max-width: 380px; width: 100%;
  display: flex; flex-direction: column; gap: 14px;
  animation: modal-in var(--t-slow) var(--ease) both;
}
.login-logo { display: flex; justify-content: center; margin-bottom: 8px; }
.login-logo img, .login-logo svg {
  filter: drop-shadow(0 8px 28px rgba(236,63,92,.45)) drop-shadow(0 0 44px rgba(110,62,192,.25));
}
.login-box h2 {
  font-size: 22px;
  letter-spacing: -0.02em;
  text-align: center;
  margin: 0;
  font-weight: 700;
  display: inline-flex; align-items: baseline; gap: 10px; justify-content: center;
}
.login-sub { font-size: 11px; font-weight: 500; letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-3); opacity: .8; }
#login-btn { width: 100%; padding: 12px; font-size: 14px; }
#login-error { color: var(--danger); font-size: 12px; text-align: center; }

/* ============ 22. BOTTOM NAV (mobile) ============ */
.bottom-nav {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  background: rgba(10,10,10,.92);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border-top: 1px solid rgba(255,255,255,.07);
  padding: 8px 6px calc(8px + env(safe-area-inset-bottom, 0px));
  z-index: 50;
  justify-content: space-around;
  align-items: stretch;
  gap: 2px;
}
.bottom-nav-item {
  flex: 1;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 4px;
  padding: 6px 4px;
  border-radius: 10px;
  color: var(--text-3);
  font-size: 0; /* défaut : pas de label, on l'active via .bn-lbl */
  background: transparent; border: 0;
  transition: color .18s ease, background .18s ease, transform .12s ease;
  -webkit-tap-highlight-color: transparent;
  cursor: pointer;
}
.bottom-nav-item .bn-lbl {
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: .01em;
  line-height: 1;
}
.bottom-nav-item svg { stroke-width: 1.9; }
.bottom-nav-item.active {
  color: #6ee7a7;
}
.bottom-nav-item.active svg { stroke-width: 2.1; }
.bottom-nav-item:active { transform: scale(.92); }
.bottom-nav-item:hover:not(.active) { color: var(--text-2); }

/* ============ 23. MISC ============ */
.drop-zone {
  padding: 24px;
  background: rgba(255,255,255,.02);
  border: 2px dashed var(--line-2);
  border-radius: var(--r-lg);
  text-align: center;
  color: var(--text-3);
  transition: all var(--t-base) var(--ease);
  cursor: pointer;
}
.drop-zone:hover, .drop-zone.drag-over { background: var(--accent-soft); border-color: var(--accent-ring); color: var(--accent); }
.drop-zone-icon { font-size: 32px; margin-bottom: 6px; opacity: .6; }
.file-list { display: flex; flex-direction: column; gap: 6px; margin-top: 8px; }
.file-item { display: flex; align-items: center; gap: 10px; padding: 8px 12px; background: rgba(255,255,255,.02); border: 1px solid var(--line); border-radius: var(--r-sm); }
.file-item-icon { font-size: 16px; opacity: .7; }
.file-item-name { flex: 1; font-size: 13px; color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.file-item-size { font-size: 11px; color: var(--text-3); }
.file-item-remove { color: var(--danger); padding: 2px 6px; }

.sse-pill {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 10px;
  background: var(--ok-soft);
  border: 1px solid var(--ok-ring);
  border-radius: var(--r-full);
  font-size: 11px;
  color: #86efac;
  font-weight: 600;
}
.sse-pill svg { flex-shrink: 0; }
.sse-pill.offline { background: var(--danger-soft); border-color: var(--danger-ring); color: #fca5a5; }

/* ── SYNC BANNER ───────────────────────────────────────────────── */
.sync-banner {
  display: flex; align-items: center; justify-content: space-between;
  padding: 9px 20px;
  background: rgba(99,102,241,.12);
  border-bottom: 1px solid rgba(99,102,241,.25);
  color: #a5b4fc;
  font-size: 13px; font-weight: 500;
  animation: sync-banner-in .25s var(--ease) both;
}
.sync-banner[hidden] { display: none; }
@keyframes sync-banner-in {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.sync-banner-left { display: flex; align-items: center; gap: 9px; }
.sync-banner-spin {
  flex-shrink: 0;
  animation: spin 1s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.sync-banner-close {
  background: none; border: none; cursor: pointer;
  color: rgba(165,180,252,.6); padding: 2px;
  display: flex; align-items: center;
  transition: color .15s;
}
.sync-banner-close:hover { color: #a5b4fc; }
.sync-banner.done {
  background: rgba(52,211,153,.1);
  border-bottom-color: rgba(52,211,153,.2);
  color: #6ee7b7;
}

/* ── TOPBAR STAT CHIPS ─────────────────────────────────────────── */
.tb-stats { display: flex; align-items: center; gap: 5px; }
.tb-stat {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 10px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 20px;
  font-size: 11.5px; font-weight: 600;
  color: var(--text-2);
  cursor: default;
  position: relative;
  transition: background .15s, border-color .15s;
  font-variant-numeric: tabular-nums;
}
.tb-stat svg { color: var(--text-3); flex-shrink: 0; }
.tb-stat:hover { background: rgba(255,255,255,.09); border-color: rgba(255,255,255,.14); }
/* Tooltip */
/* Tooltip chip custom */
.tb-tooltip {
  position: fixed;
  background: linear-gradient(135deg, #1fddf0 0%, #0ff29e 100%);
  color: #021a1e;
  border-radius: 10px;
  padding: 8px 13px;
  pointer-events: none;
  z-index: 9999;
  min-width: 130px;
  box-shadow: 0 6px 20px rgba(31,221,240,.35);
  transition: opacity .12s;
}
.tb-tooltip[hidden] { display: none; }
.tb-tooltip::before {
  content: '';
  position: absolute;
  top: -6px; left: 50%; transform: translateX(-50%);
  border: 6px solid transparent;
  border-top: none;
  border-bottom-color: #1fddf0;
}
.tb-tooltip-title { font-size: 12.5px; font-weight: 700; }
.tb-tooltip-sub   { font-size: 11.5px; margin-top: 2px; opacity: .75; }

.discord-chan-link { color: var(--accent); font-family: 'JetBrains Mono', monospace; font-size: 12.5px; }
.discord-ts { color: var(--muted); font-size: 11px; font-variant-numeric: tabular-nums; }

.muted { color: var(--muted); }
.success, .ok, .green { color: var(--ok); }
.warn { color: var(--warn); }
.err, .error, .urgent { color: var(--danger); }
.accent { color: var(--accent); }
.total { font-weight: 700; }
.dot { display: inline-block; width: 6px; height: 6px; border-radius: 50%; background: #10b981; color: #10b981; }
.dot.offline { background: #f87171; color: #f87171; }
.dot.warn    { background: #f59e0b; color: #f59e0b; }

.wa-bridge-card {
  margin: 8px 10px 0;
  padding: 9px 10px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 10px;
  display: flex; align-items: center; gap: 8px;
}
.wa-bridge-card-left {
  display: flex; align-items: center; gap: 8px; flex: 1; min-width: 0;
}
.wa-bridge-dot-wrap { flex-shrink: 0; display: flex; align-items: center; }
.wa-bridge-card-info {
  display: flex; flex-direction: column; gap: 1px; min-width: 0;
}
.wa-bridge-card-label {
  font-size: 11px; font-weight: 600; color: var(--text-2); white-space: nowrap;
  overflow: hidden; text-overflow: ellipsis;
}
.wa-bridge-card-state {
  font-size: 10px; color: var(--muted); white-space: nowrap;
  overflow: hidden; text-overflow: ellipsis;
}
.wa-bridge-card-state.ok   { color: var(--ok); }
.wa-bridge-card-state.warn { color: var(--warn); }
.wa-bridge-card-state.err  { color: var(--danger); }

.wa-bridge-restart-btn {
  flex-shrink: 0; display: flex; align-items: center; justify-content: center;
  width: 26px; height: 26px; border-radius: 7px;
  border: 1px solid rgba(255,255,255,.09);
  background: rgba(255,255,255,.05); color: var(--text-3); cursor: pointer;
  transition: background .15s, color .15s, border-color .15s;
}
.wa-bridge-restart-btn:hover:not(:disabled) {
  background: rgba(255,255,255,.11); color: var(--text); border-color: rgba(255,255,255,.18);
}
.wa-bridge-restart-btn:disabled { opacity: .4; cursor: not-allowed; }
.wa-bridge-restart-btn.spinning svg { animation: spin .9s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

.new-msg-badge { background: var(--grad-danger); color: #fff; font-size: 10.5px; font-weight: 700; padding: 1px 6px; border-radius: 999px; box-shadow: 0 2px 6px rgba(239,68,68,.35); }

/* ============ 24. SIDEBAR PROFILE CARD ============ */
.sidebar-profile {
  position: relative;
  margin: 6px 10px 8px;
}
.sidebar-profile-inner {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 12px;
  cursor: default;
  transition: background var(--t-fast);
}
.sidebar-profile-inner:hover { background: rgba(255,255,255,.08); }
.sidebar-profile-logo {
  width: 32px; height: 32px; border-radius: 8px; flex-shrink: 0; object-fit: contain;
}
.sidebar-profile-info {
  display: flex; flex-direction: column; gap: 2px; flex: 1; min-width: 0;
}
.sidebar-profile-name {
  font-size: 12.5px; font-weight: 700; color: var(--text); white-space: nowrap;
  overflow: hidden; text-overflow: ellipsis; letter-spacing: .2px;
}
.sidebar-profile-role {
  font-size: 10.5px; color: var(--text-3); white-space: nowrap;
  overflow: hidden; text-overflow: ellipsis;
}
.sidebar-profile-more {
  flex-shrink: 0; width: 26px; height: 26px; border-radius: 7px;
  border: none; background: transparent; color: var(--text-3);
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: background var(--t-fast), color var(--t-fast);
}
.sidebar-profile-more:hover { background: rgba(255,255,255,.10); color: var(--text); }

.sidebar-profile-menu {
  position: absolute; bottom: calc(100% + 6px); left: 0; right: 0;
  background: var(--bg-3); border: 1px solid var(--line-2);
  border-radius: 10px; padding: 6px; z-index: 50;
  box-shadow: var(--sh-md);
  animation: fadeSlideUp .15s var(--ease) both;
}
@keyframes fadeSlideUp {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.spm-item {
  display: flex; align-items: center; gap: 8px; width: 100%;
  padding: 8px 10px; border-radius: 7px; border: none;
  background: transparent; color: var(--text-2); font-size: 12.5px;
  cursor: pointer; text-align: left; transition: background var(--t-fast), color var(--t-fast);
}
.spm-item:hover { background: rgba(255,255,255,.07); color: var(--text); }
.spm-sep { height: 1px; background: var(--line); margin: 4px 0; }
.spm-version {
  padding: 4px 10px; font-size: 10.5px; color: var(--muted); user-select: none;
}

/* ============ 25. SETTINGS PAGE ============ */
.settings-tabs-row {
  display: flex; gap: 4px;
  padding: 20px var(--gutter) 16px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 24px;
}
.settings-tab {
  padding: 6px 16px; border-radius: var(--r-full);
  border: 1px solid transparent; background: transparent;
  color: var(--text-3); font-size: 13px; font-weight: 500;
  cursor: pointer; transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}
.settings-tab:hover { color: var(--text-2); background: rgba(255,255,255,.05); }
.settings-tab.active {
  background: rgba(255,255,255,.08); color: var(--text);
  border-color: var(--line-2);
}

.settings-section { display: none; flex-direction: column; gap: 16px; padding: 0 var(--gutter) var(--gutter); }
.settings-section.active { display: flex; }

.settings-card {
  background: var(--bg-card); border: 1px solid var(--line);
  border-radius: var(--r-lg); overflow: hidden;
}
.settings-card-head {
  display: flex; align-items: center; gap: 14px;
  padding: 18px 20px;
  border-bottom: 1px solid var(--line);
}
.settings-card-icon {
  width: 38px; height: 38px; border-radius: 10px; flex-shrink: 0;
  background: var(--accent-soft); border: 1px solid var(--accent-ring);
  display: flex; align-items: center; justify-content: center;
  color: var(--accent);
}
.settings-card-icon-wa { background: rgba(37,211,102,.10); border-color: rgba(37,211,102,.3); color: #25d366; }
.settings-card-head-text { flex: 1; min-width: 0; }
.settings-card-title { font-size: 14px; font-weight: 600; color: var(--text); }
.settings-card-sub { font-size: 12px; color: var(--text-3); margin-top: 2px; }
.settings-card-head-right {
  display: flex; align-items: center; gap: 7px;
  font-size: 12px; color: var(--text-3); flex-shrink: 0;
}
.set-wa-state.ok { color: var(--ok); }
.set-wa-state.warn { color: var(--warn); }
.set-wa-state.err { color: var(--danger); }

.settings-card-body { padding: 18px 20px; }
.settings-info-grid { display: flex; flex-direction: column; gap: 0; }
.settings-info-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 20px; border-bottom: 1px solid var(--line);
}
.settings-info-row:last-child { border-bottom: none; }
.sir-label { font-size: 13px; color: var(--text-3); }
.sir-value { font-size: 13px; font-weight: 500; color: var(--text); font-variant-numeric: tabular-nums; }

.settings-token-row { display: flex; gap: 10px; align-items: center; margin-bottom: 10px; }
.settings-input {
  flex: 1; padding: 9px 13px; border-radius: var(--r-sm);
  border: 1px solid var(--line-2); background: var(--bg-2);
  color: var(--text); font-size: 13px; outline: none;
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.settings-input:focus { border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-ring); }
.set-token-current { font-size: 12px; color: var(--text-3); margin-bottom: 10px; }
.settings-hint { font-size: 12px; color: var(--muted); line-height: 1.5; }
.settings-link { color: var(--accent); text-decoration: none; }
.settings-link:hover { text-decoration: underline; }

.settings-theme-row { display: flex; gap: 10px; }
.settings-theme-btn {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 20px; border-radius: var(--r-md);
  border: 1px solid var(--line-2); background: var(--bg-2);
  color: var(--text-2); font-size: 13px; font-weight: 500;
  cursor: pointer; transition: background var(--t-fast), border-color var(--t-fast), color var(--t-fast);
}
.settings-theme-btn:hover { background: rgba(255,255,255,.07); color: var(--text); }
.settings-theme-btn.active {
  border-color: var(--accent); background: var(--accent-soft); color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent-ring);
}

/* ============ 26. RESPONSIVE ============ */
@media (max-width: 900px) {
  :root { --sidebar-w: 0px; --gutter: 16px; }
  .sidebar {
    position: fixed; left: 0; top: 0;
    width: 280px;
    transform: translateX(-100%);
    transition: transform var(--t-slow) var(--ease-snap);
  }
  .sidebar.open { transform: translateX(0); }
  .sidebar-backdrop {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.55);
    z-index: 35; opacity: 0; pointer-events: none;
    transition: opacity var(--t-base) var(--ease);
  }
  .sidebar-backdrop.open { opacity: 1; pointer-events: auto; }
  .sidebar-close { display: inline-flex; align-items: center; justify-content: center; }
  #app { grid-template-columns: 1fr; }
  .topbar-menu { display: inline-flex; align-items: center; justify-content: center; }
  .hero-title, .hero h1 { font-size: 30px; }
  .tp-grid, .wh-composer, .facture-layout, .cc-layout { grid-template-columns: 1fr !important; }
  .bottom-nav { display: flex; }
  .page-wrap { padding-bottom: calc(78px + env(safe-area-inset-bottom, 0px)); }
}

/* Refonte topbar mobile : titre court, ellipsis, KPI pills + sync texte masqués */
@media (max-width: 720px) {
  .topbar {
    padding: 0 12px;
    padding-top: env(safe-area-inset-top, 0px);
    height: calc(var(--topbar-h) + env(safe-area-inset-top, 0px));
    gap: 10px;
  }
  .topbar-left { gap: 10px; min-width: 0; flex: 1 1 auto; }
  .topbar-right { gap: 6px; flex-shrink: 0; }
  .topbar-title {
    flex-direction: row; align-items: center;
    min-width: 0; overflow: hidden;
  }
  .topbar-title-main {
    font-size: 14px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 60vw;
  }
  .topbar-title-sub { display: none; }   /* sous-titre masqué sur mobile */
  .tb-stats { display: none !important; } /* KPI pills masqués */
  /* Le bouton "Sync Rewardful" devient une icône seule */
  #comm-refresh-btn {
    padding: 8px;
    width: 36px; height: 36px;
    justify-content: center;
  }
  #comm-refresh-btn svg { margin: 0; }
  #comm-refresh-btn .btn-label,
  #comm-refresh-btn { font-size: 0; } /* cache le texte "Sync Rewardful" */
  #comm-refresh-btn svg { font-size: initial; }
  .rw-sync-status { display: none !important; }
}

@media (max-width: 520px) {
  .hero-title, .hero h1 { font-size: 24px; }
  .kpi-value, .stat-value { font-size: 24px; }
  .panel, .ticket-panel { width: 100vw; }
  .topbar-title-main { max-width: 50vw; }
}

/* ============ 25. UTILITIES ============ */
.visible { display: block !important; }
[hidden] { display: none !important; }
.collapsed { display: none; }
.removing { opacity: 0; transform: translateX(20px); transition: all var(--t-base) var(--ease); }
.reveal { animation: view-in 380ms var(--ease) both; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    transition-duration: .01ms !important;
  }
}

/* ============ 26. PATCH v2.1 — SVG icons, commissions green, commands preview, date fix ============ */

/* Dark color-scheme so native date / number pickers render with dark text field
   (fixes the white-on-white emission date input) */
:root, html, body { color-scheme: dark; }
input[type="date"], input[type="number"], input[type="month"], input[type="time"] {
  color: var(--text);
  background: rgba(255,255,255,.03);
  font-variant-numeric: tabular-nums;
}
input[type="date"]::-webkit-calendar-picker-indicator,
input[type="number"]::-webkit-calendar-picker-indicator {
  filter: invert(.75) saturate(3) hue-rotate(130deg);
  cursor: pointer;
  opacity: .8;
}
input[type="date"]::-webkit-datetime-edit,
input[type="date"]::-webkit-datetime-edit-fields-wrapper,
input[type="date"]::-webkit-datetime-edit-text,
input[type="date"]::-webkit-datetime-edit-month-field,
input[type="date"]::-webkit-datetime-edit-day-field,
input[type="date"]::-webkit-datetime-edit-year-field { color: var(--text); }

/* Nav icon: SVG sizing */
.nav-icon svg, .cmdk-icon svg {
  width: 18px; height: 18px;
  stroke: currentColor;
  flex-shrink: 0;
}
.nav-item .nav-icon { color: var(--text-3); transition: color var(--t-base) var(--ease), transform var(--t-base) var(--ease); }
.nav-item:hover .nav-icon { color: var(--text); }
.nav-item.active .nav-icon { color: var(--text); }

/* Nav count: non-urgent default (subtle), urgent variant (red/glow) */
.nav-count {
  background: rgba(255,255,255,.08);
  color: var(--text-2);
  box-shadow: none;
  font-variant-numeric: tabular-nums;
}
.nav-count.urgent {
  background: var(--grad-danger);
  color: #fff;
  box-shadow: 0 0 0 1px rgba(239,68,68,.35), 0 4px 14px rgba(239,68,68,.35);
  animation: nav-count-pulse 1.6s ease-in-out infinite;
}
@keyframes nav-count-pulse {
  0%, 100% { box-shadow: 0 0 0 1px rgba(239,68,68,.35), 0 4px 14px rgba(239,68,68,.35); }
  50%      { box-shadow: 0 0 0 3px rgba(239,68,68,.15), 0 6px 20px rgba(239,68,68,.55); }
}

/* ──────── COMMISSIONS: green theme ─────────────────────── */
#view-commissions .comm-amount:not(.comm-amount-accent) { color: var(--text); }
#view-commissions .comm-stat-val { color: var(--ok); }
#view-commissions .comm-stat {
  border-color: rgba(34,197,94,.18);
  box-shadow: inset 0 1px 0 rgba(74,222,128,.08);
}
#view-commissions .comm-stat::before {
  content: '';
  position: absolute; inset: 0;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(34,197,94,.06), transparent 60%);
  border-radius: inherit;
}
#view-commissions .comm-stat { position: relative; overflow: hidden; }
#view-commissions .comm-filter.active {
  background: rgba(34,197,94,.12);
  border-color: rgba(34,197,94,.40);
  color: #4ade80;
}
#view-commissions .comm-table tr:hover td { background: rgba(255,255,255,.03); }
#view-commissions .comm-table th {
  background: transparent;
  color: var(--text-3);
}
#view-commissions input:focus, #view-commissions select:focus {
  border-color: var(--ok);
  background: rgba(34,197,94,.04);
  box-shadow: 0 0 0 3px rgba(34,197,94,.28), var(--sh-inner);
}

/* ── Filter dropdowns ─────────────────────────────────────────────────────── */
.comm-filter-group { display: flex; gap: 8px; align-items: center; }
.comm-dd-wrap { position: relative; }

.comm-dd-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 12px; border-radius: 8px;
  border: 1px solid var(--line); background: var(--surface);
  color: var(--text-2); font-size: 13px; font-weight: 500; cursor: pointer;
  transition: border-color .15s, color .15s, background .15s;
  white-space: nowrap;
}
.comm-dd-btn:hover { border-color: var(--accent-soft); color: var(--text); }
.comm-dd-btn.comm-dd-active { border-color: var(--accent); color: var(--accent); background: rgba(20,184,166,.07); }

.comm-dd-chevron { transition: transform .15s; opacity: .5; }
.comm-dd-btn:has(+ .comm-dropdown:not([hidden])) .comm-dd-chevron { transform: rotate(180deg); }

.comm-filter-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent); display: inline-block; margin-left: 2px;
}

.comm-dropdown {
  position: absolute; top: calc(100% + 6px); left: 0; z-index: 200;
  background: var(--bg-1);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 12px; box-shadow: 0 8px 40px rgba(0,0,0,.6);
  min-width: 260px; overflow: hidden;
  backdrop-filter: none;
}
[data-theme="light"] .comm-dropdown {
  background: #fff;
  border-color: rgba(0,0,0,.1);
  box-shadow: 0 8px 40px rgba(0,0,0,.15);
}
.comm-filters-dd { min-width: 210px; }

/* quick period buttons */
.comm-quick-row { display: flex; flex-wrap: wrap; gap: 6px; padding: 12px; }
.comm-quick-btn {
  padding: 4px 10px; border-radius: 6px; border: 1px solid var(--line);
  background: transparent; color: var(--text-2); font-size: 12px; cursor: pointer;
  transition: all .12s;
}
.comm-quick-btn:hover { border-color: var(--accent-soft); color: var(--text); }
.comm-quick-btn.active { background: rgba(20,184,166,.12); border-color: var(--accent); color: var(--accent); font-weight: 600; }

.comm-dd-sep { height: 1px; background: var(--line); margin: 0; }

/* calendar */
.comm-calendar { padding: 10px 12px 4px; }
.comm-cal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.comm-cal-nav {
  width: 26px; height: 26px; border-radius: 6px; border: 1px solid var(--line);
  background: transparent; color: var(--text-2); cursor: pointer; font-size: 16px;
  display: flex; align-items: center; justify-content: center;
  transition: all .12s;
}
.comm-cal-nav:hover { background: var(--line); color: var(--text); }
.comm-cal-title { font-size: 13px; font-weight: 700; color: var(--text); }

.comm-cal-grid {
  display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px;
}
.comm-cal-dn { text-align: center; font-size: 10px; color: var(--muted); padding: 2px 0 4px; font-weight: 600; }
.comm-cal-day {
  text-align: center; font-size: 12px; color: var(--text-2);
  padding: 5px 2px; border-radius: 6px; cursor: pointer;
  transition: background .1s, color .1s;
}
.comm-cal-day:hover { background: var(--line); color: var(--text); }
.comm-cal-empty { cursor: default; }
.comm-cal-today { color: var(--accent); font-weight: 700; }
.comm-cal-sel { background: var(--accent) !important; color: #fff !important; font-weight: 700; border-radius: 6px; }
.comm-cal-start { border-radius: 6px 0 0 6px; }
.comm-cal-end   { border-radius: 0 6px 6px 0; }
.comm-cal-inrange { background: rgba(20,184,166,.15); color: var(--text); border-radius: 0; }

.comm-cal-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 12px 10px; font-size: 12px; color: var(--text-2);
}
.comm-cal-clear { background: transparent; border: none; color: var(--muted); cursor: pointer; font-size: 11px; }
.comm-cal-clear:hover { color: var(--text); }

/* filters dropdown */
.comm-filter-sect { padding: 10px 12px; }
.comm-filter-sect-lbl { font-size: 10px; text-transform: uppercase; letter-spacing: .07em; color: var(--muted); margin-bottom: 6px; font-weight: 700; }
.comm-fopt, .comm-fplan {
  display: block; width: 100%; text-align: left;
  padding: 7px 10px; border-radius: 7px; border: none;
  background: transparent; color: var(--text-2); font-size: 13px; cursor: pointer;
  transition: background .1s, color .1s;
}
.comm-fopt:hover, .comm-fplan:hover { background: var(--line); color: var(--text); }
.comm-fopt.active, .comm-fplan.active { color: var(--accent); font-weight: 600; background: rgba(20,184,166,.08); }

/* ── Donut répartition (dans la card heatmap) ───────────────────────────── */
.rw-donut-sep {
  border-top: 1px solid var(--line);
  margin: 16px -18px 0;
}
#rw-donut-wrap { padding-top: 0; flex: 1; display: flex; flex-direction: column; }
.rw-donut-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 16px;
  gap: 8px;
}
.rw-donut-toggle {
  display: flex;
  gap: 3px;
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 3px;
  flex-shrink: 0;
}
.rw-dtog-btn {
  background: transparent;
  border: none;
  border-radius: 6px;
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 500;
  color: var(--text-2);
  cursor: pointer;
  transition: background .15s, color .15s;
  white-space: nowrap;
}
.rw-dtog-btn.active { background: var(--bg-2); color: var(--text-1); box-shadow: 0 1px 3px rgba(0,0,0,.18); }
.rw-dtog-btn:not(.active):hover { color: var(--text-1); }
.rw-donut-body { display: flex; align-items: flex-start; gap: 28px; flex: 1; }
.rw-donut-left { display: flex; align-items: flex-start; justify-content: center; flex-shrink: 0; }
.rw-donut-right { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 14px; padding: 0; justify-content: space-between; }
/* ── Logo fill : segments colorés (mask-image) + zones hover (clip-path) ── */
.rw-logo-outer {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex-shrink: 0;
  gap: 10px;
}
/* Wrapper à taille fixe : détermine le layout et la position des zones */
.rw-logo-hitbox {
  position: relative;
  width: 240px;
  height: 240px;
  transform: translateY(-30px);
}
/* Container visuel uniquement : scalé 1.5× pour agrandir le logo, pas d'événements */
.rw-logo-container {
  position: absolute;
  inset: 0;
  transform: scale(1.5);
  transform-origin: top center;
  pointer-events: none;
}
/* Reflet soleil : faisceau lumineux diagonal qui balaye la silhouette du logo */
@keyframes rw-shine-sweep {
  0%   { background-position: -100px 0; opacity: 0; }
  7%   { opacity: 1; }
  44%  { background-position: 340px 0; opacity: 0; }
  100% { background-position: 340px 0; opacity: 0; }
}
.rw-logo-shine {
  position: absolute;
  inset: 0;
  mask-repeat: no-repeat;
  mask-size: contain;
  mask-position: center;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: contain;
  -webkit-mask-position: center;
  pointer-events: none;
  background-image: linear-gradient(
    108deg,
    transparent 0%,
    rgba(255,255,255,0.12) 35%,
    rgba(255,255,255,0.65) 50%,
    rgba(255,255,255,0.12) 65%,
    transparent 100%
  );
  background-size: 80px 100%;
  background-repeat: no-repeat;
  animation: rw-shine-sweep 5s ease-in-out infinite;
  z-index: 1;
}
.rw-logo-shine-top {
  mask-image: url('/icons/Logo vtools claude.png');
  -webkit-mask-image: url('/icons/Logo vtools claude.png');
}
.rw-logo-shine-bot {
  mask-image: url('/icons/Logo vtools claude 2.png');
  -webkit-mask-image: url('/icons/Logo vtools claude 2.png');
}
/* Couche visuelle : background = couleur du plan, mask-image = silhouette PNG */
.rw-logo-seg {
  position: absolute;
  inset: 0;
  mask-repeat: no-repeat;
  mask-size: contain;
  mask-position: center;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: contain;
  -webkit-mask-position: center;
  pointer-events: none;
  transition: transform .45s cubic-bezier(0.22, 1, 0.36, 1), filter .3s ease, opacity .3s ease;
  will-change: transform, filter, opacity;
}
/* transform-origin au point de séparation → effet de détachement naturel */
.rw-logo-seg-top {
  mask-image: url('/icons/Logo vtools claude.png');
  -webkit-mask-image: url('/icons/Logo vtools claude.png');
  transform-origin: center bottom;
}
.rw-logo-seg-bot {
  mask-image: url('/icons/Logo vtools claude 2.png');
  -webkit-mask-image: url('/icons/Logo vtools claude 2.png');
  transform-origin: center top;
}
/* Couche interaction : transparente, clip-path = zone hoverable */
/* Hitbox unique couvrant toute la surface visuelle du logo scalé (1.5× depuis top center)
   → left -60px car scale(1.5) depuis x=120 déborde de 60px à gauche
   → 360×360px = 240×1.5 pour couvrir toute la hauteur/largeur du visuel */
.rw-logo-full-hitbox {
  position: absolute;
  top: 0;
  left: -60px;
  width: 360px;
  height: 360px;
  cursor: crosshair;
  z-index: 10;
}

/* Tooltip flottant qui suit le curseur */
.rw-logo-cursor-tip {
  position: fixed;
  z-index: 9999;
  pointer-events: none;
  background: #161b2e;
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 8px;
  padding: 5px 11px;
  font-size: 13px;
  display: flex;
  align-items: center;
  gap: 5px;
  white-space: nowrap;
  opacity: 0;
  transition: opacity .14s ease;
}
.rw-logo-cursor-tip.visible { opacity: 1; }
/* Compteur total + stat sous le logo — opacity seul, pas de height change */
.rw-logo-below {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  margin-top: 10px;
}
.rw-logo-stat {
  display: flex;
  align-items: center;
  gap: 6px;
  opacity: 0;
  transition: opacity .22s ease;
  pointer-events: none;
  white-space: nowrap;
}
.rw-logo-stat.visible { opacity: 1; }
.rw-logo-stat-name {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.rw-logo-stat-val {
  font-size: 13px;
  font-weight: 800;
}
.rw-logo-stat-lbl {
  font-size: 10px;
  font-weight: 400;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.rw-logo-fill-count {
  font-size: 18px;
  font-weight: 700;
  color: var(--text-1);
  text-align: center;
  line-height: 1.1;
  pointer-events: none;
}
.rw-logo-fill-count span {
  display: block;
  font-size: 10px;
  font-weight: 400;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .06em;
}
.rw-donut-legend { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; min-width: 0; justify-content: flex-start; }
.rw-donut-leg-item { display: flex; flex-direction: column; gap: 8px; min-width: 0; padding: 12px 14px; background: var(--bg-3); border: 1px solid var(--line); border-radius: 10px; transition: border-color .2s; }
.rw-donut-leg-top { display: flex; align-items: center; gap: 10px; min-width: 0; }
.rw-donut-leg-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.rw-donut-leg-name { font-size: 13px; font-weight: 500; color: var(--text-1); flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.rw-donut-leg-val { font-size: 13px; font-weight: 700; color: var(--text-1); flex-shrink: 0; }
.rw-donut-leg-pct { font-size: 11px; font-weight: 400; color: var(--muted); margin-left: 4px; }
.rw-donut-leg-track { height: 3px; background: var(--line); border-radius: 99px; overflow: hidden; }
.rw-donut-leg-fill { height: 100%; border-radius: 99px; transition: width .6s cubic-bezier(.4,0,.2,1); }
.rw-donut-empty { color: var(--muted); font-size: 12px; padding: 12px 0; }
.rw-donut-board-section { border-top: 1px solid var(--line); padding-top: 12px; }

/* ── Heatmap ─────────────────────────────────────────────────────────────── */
.rw-heatmap-card,
.rw-donut-main-card {
  display: flex;
  flex-direction: column;
  overflow: visible;
  background:
    radial-gradient(circle at top left, rgba(16,185,129,.05), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.015), rgba(255,255,255,0));
}
.rw-heatmap-card-main { min-height: 0; }
.rw-heatmap-head {
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-bottom: 14px; flex-wrap: wrap; gap: 10px;
}
.rw-heatmap-sub { font-size: 11px; color: var(--muted); margin-top: 2px; }
.rw-heatmap-legend { display: flex; align-items: center; gap: 7px; flex-wrap: wrap; }
.rw-hm-leg  { font-size: 11px; color: var(--muted); }
.rw-hm-sep  { width: 1px; height: 12px; background: var(--line); margin: 0 4px; }
.rw-hm-leg-dot { width: 14px; height: 14px; border-radius: 4px; display: inline-block; }
.rw-hm-leg-item { display: flex; align-items: center; gap: 5px; font-size: 11px; color: var(--text-2); }
.rw-hm-dot  { width: 12px; height: 12px; border-radius: 4px; display: inline-block; }

.rw-heatmap-wrap {
  position: relative;
  flex: 1;
  overflow-x: hidden;
  overflow-y: visible;
  min-height: 0;
  padding: 6px 0 2px;
}
.rw-hm-grid {
  width: 100%;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.rw-hm-grid-head,
.rw-hm-grid-row {
  display: grid;
  grid-template-columns: 44px repeat(var(--rw-hm-cols, 31), minmax(0, 120px));
  gap: 8px;
}
.rw-hm-grid-head { margin-bottom: 6px; }
.rw-hm-grid-corner {
  height: 20px;
}
.rw-hm-grid-col {
  font-size: 10px;
  color: var(--text-3);
  display: flex;
  align-items: center;
  justify-content: flex-start;
  min-width: 0;
  padding: 0 2px;
  white-space: nowrap;
  font-weight: 500;
}
.rw-hm-grid-body {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.rw-hm-grid-day {
  display: flex;
  align-items: center;
  font-size: 12px;
  font-weight: 600;
  color: #c5cede;
  padding-right: 8px;
  letter-spacing: -.01em;
}
.rw-hm-grid-cell {
  appearance: none;
  border: none;
  border-radius: 10px;
  min-height: 32px;
  height: 32px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: transform .12s ease, box-shadow .12s ease, opacity .12s ease, background .12s ease;
  position: relative;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.015);
}
.rw-hm-grid-cell:hover {
  transform: translateY(-1px) scale(1.01);
  box-shadow:
    0 0 0 1px rgba(255,255,255,.06),
    0 8px 18px rgba(0,0,0,.26);
  opacity: 1 !important;
}
.rw-hm-grid-cell.is-today {
  box-shadow: 0 0 0 1px rgba(45,212,191,.55), inset 0 0 0 1px rgba(45,212,191,.15);
}
.rw-hm-grid-cell.is-empty {
  opacity: .9;
}
@media (max-width: 1180px) {
  .rw-hm-grid-head,
  .rw-hm-grid-row {
    grid-template-columns: 38px repeat(var(--rw-hm-cols, 31), minmax(0, 1fr));
    gap: 3px;
  }
  .rw-hm-grid-cell { min-height: 38px; height: 38px; border-radius: 9px; }
  .rw-hm-grid-day { font-size: 12px; }
  .rw-hm-grid-col { font-size: 9px; }
}

.rw-hm-tooltip {
  position: fixed; z-index: 1000; pointer-events: none;
  background: #0f0f0f;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 11px;
  padding: 11px 13px;
  font-size: 12px;
  color: var(--text);
  min-width: 200px;
  max-width: 260px;
  white-space: normal;
  box-shadow: 0 12px 32px rgba(0,0,0,.55);
  opacity: 0; transition: opacity .12s;
}
.rw-hm-tooltip.visible { opacity: 1; }
.rw-hm-tip-head {
  font-size: 11px;
  color: var(--text-3);
  font-weight: 600;
  letter-spacing: .01em;
  text-transform: capitalize;
}
.rw-hm-tip-total {
  font-size: 16px;
  font-weight: 800;
  color: var(--text);
  letter-spacing: -0.01em;
  margin-top: 1px;
  padding-bottom: 8px;
  font-variant-numeric: tabular-nums;
}
.rw-hm-tip-section {
  border-top: 1px solid rgba(255,255,255,.07);
  padding-top: 7px;
  margin-top: 1px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.rw-hm-tip-section + .rw-hm-tip-section { margin-top: 4px; }
.rw-hm-tip-row {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 12px;
  line-height: 1.2;
}
.rw-hm-tip-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
  box-shadow: 0 0 0 2px rgba(255,255,255,.04);
}
.rw-hm-tip-lbl {
  flex: 1;
  color: var(--text-2);
  font-weight: 500;
}
.rw-hm-tip-val {
  color: var(--text);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.rw-hm-tip-dot-new     { background: #cbd5e1; }
.rw-hm-tip-dot-renewal { background: #38bdf8; }
.rw-hm-tip-dot-perf    { background: #3fff5b; }
.rw-hm-tip-dot-adv     { background: #5300a4; }
.rw-hm-tip-dot-sniper  { background: #cb296c; }
.rw-hm-tip-dot-other   { background: rgba(255,255,255,.4); }

/* Sous-ligne : décomposition Nouveau/Renouvellement par plan */
.rw-hm-tip-row-plan { font-weight: 600; }
.rw-hm-tip-sub {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 11px;
  color: var(--text-3);
  padding-left: 16px;
  margin-top: 1px;
}
.rw-hm-tip-sub-lbl { font-weight: 500; }
.rw-hm-tip-sub-val { font-weight: 600; font-variant-numeric: tabular-nums; color: var(--text-2); }

/* Donut segment tooltip */
.rw-donut-tip {
  position: fixed; z-index: 1002; pointer-events: none;
  background: #161c2e; border: 1px solid rgba(255,255,255,.14);
  border-radius: 12px; padding: 11px 16px;
  opacity: 0; transition: opacity .14s;
  min-width: 210px; box-shadow: 0 8px 32px rgba(0,0,0,.45);
}
.rw-donut-tip.visible { opacity: 1; }
.rw-donut-tip-head { display: flex; align-items: center; gap: 9px; margin-bottom: 5px; }
.rw-donut-tip-dot  { width: 11px; height: 11px; border-radius: 50%; flex-shrink: 0; }
.rw-donut-tip-name { font-size: 14px; font-weight: 700; color: var(--text-1); }
.rw-donut-tip-val  { font-size: 12.5px; color: var(--text-3); line-height: 1.4; }
.rw-hm-tip-sep { color: var(--text-3); margin: 0 2px; }
.rw-hm-tip-plan.is-performance { color: #10b981; font-weight: 700; }
.rw-hm-tip-plan.is-advanced { color: #8b5cf6; font-weight: 700; }
.rw-hm-tip-plan.is-sniper { color: #cb296c; font-weight: 700; }

/* ── Affiliates ───────────────────────────────────────────────────────────── */
.aff-summary-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 20px;
}
.aff-sum-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 18px 20px;
}
.aff-sum-best { border-color: rgba(20,184,166,.35); }
.aff-sum-label { font-size: 11px; color: var(--text-3); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 6px; }
.aff-sum-val   { font-size: 24px; font-weight: 800; color: var(--text); letter-spacing: -.5px; }
.aff-sum-best .aff-sum-val { color: #14b8a6; }
.aff-sum-sub   { font-size: 11px; color: var(--muted); margin-top: 4px; }

.aff-toolbar { margin-bottom: 12px; }

.aff-table .aff-th-sort { cursor: pointer; user-select: none; }
.aff-table .aff-th-sort:hover { color: var(--text); }
.aff-table .aff-sort-desc::after { content: ' ↓'; opacity: .7; }
.aff-table .aff-sort-asc::after  { content: ' ↑'; opacity: .7; }

.aff-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .04em;
}
.aff-badge-active   { background: rgba(16,185,129,.12); color: #34d399; }
.aff-badge-inactive { background: rgba(100,116,139,.1);  color: var(--muted); }

.aff-conv-wrap { display: flex; align-items: center; gap: 8px; }
.aff-conv-num  { font-weight: 700; color: var(--text); min-width: 20px; }
.aff-mini-bar  { flex: 1; height: 4px; background: var(--line); border-radius: 4px; min-width: 40px; }
.aff-mini-fill { height: 100%; background: #14b8a6; border-radius: 4px; }
.aff-leads-num { color: #a5b4fc; font-weight: 600; }

#view-affiliates .comm-table tr:hover td { background: rgba(255,255,255,.03); }
#view-affiliates .comm-table th {
  background: transparent;
  color: var(--text-3);
}

/* ──────── CUSTOM COMMANDS: live preview pane ───────────── */
.cc-preview-section { background: var(--bg-2); }
.cc-preview {
  background: #2b2d31;
  border-radius: var(--r-md);
  padding: 14px 16px;
  border: 1px solid rgba(255,255,255,.06);
  display: flex;
  flex-direction: column;
  gap: 12px;
  font-family: 'Inter', system-ui, sans-serif;
}
.cc-preview-cmdbar {
  display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
  padding: 8px 12px;
  background: #1e1f22;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.04);
  color: #dbdee1;
  font-size: 13.5px;
}
.cc-preview-slash { color: #5865f2; font-weight: 700; }
.cc-preview-name { color: #fff; font-weight: 600; font-family: 'JetBrains Mono', ui-monospace, monospace; }
.cc-preview-desc { color: #949ba4; font-size: 12.5px; margin-left: 6px; }
.cc-preview-msg { display: flex; gap: 14px; padding-top: 4px; }
.cc-preview-avatar img {
  width: 40px; height: 40px;
  border-radius: 50%;
  object-fit: cover;
  background: #1e1f22;
}
.cc-preview-body { flex: 1; min-width: 0; color: #dbdee1; }
.cc-preview-head { display: flex; align-items: center; gap: 6px; margin-bottom: 2px; }
.cc-preview-bot-name { color: #fff; font-weight: 600; font-size: 15px; }
.cc-preview-badge {
  display: inline-block;
  padding: 1px 5px 0;
  border-radius: 3px;
  background: #5865f2;
  color: #fff;
  font-size: 10px;
  font-weight: 600;
  line-height: 1.35;
  letter-spacing: 0.02em;
}
.cc-preview-time { color: #949ba4; font-size: 11.5px; }
.cc-preview-content { font-size: 14.5px; color: #dbdee1; line-height: 1.4; margin-top: 2px; word-wrap: break-word; }
.cc-preview-content code, .cc-preview-embed-desc code {
  background: #1e1f22; padding: 1px 5px; border-radius: 3px;
  font-family: 'JetBrains Mono', ui-monospace, monospace; font-size: 85%;
}
.cc-preview-content pre { background: #1e1f22; padding: 8px; border-radius: 4px; overflow-x: auto; }
.cc-preview-content blockquote, .cc-preview-embed-desc blockquote {
  border-left: 3px solid #4e5058; padding-left: 10px; color: #b5bac1; margin: 2px 0;
}
.cc-preview-content a, .cc-preview-embed-desc a { color: #00a8fc; text-decoration: none; }
.cc-preview-content a:hover { text-decoration: underline; }

.cc-preview-embed {
  --embed-color: #1fddf0;
  position: relative;
  background: #2b2d31;
  border-left: 4px solid var(--embed-color);
  border-radius: 4px;
  padding: 10px 14px;
  margin-top: 8px;
  max-width: 520px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px 16px;
}
.cc-preview-embed-author,
.cc-preview-embed-title,
.cc-preview-embed-desc,
.cc-preview-embed-fields,
.cc-preview-embed-image,
.cc-preview-embed-footer { grid-column: 1; }
.cc-preview-embed-thumb {
  grid-column: 2; grid-row: 1 / span 4;
  width: 80px; height: 80px;
  object-fit: cover; border-radius: 4px;
  align-self: start;
}
.cc-preview-embed-author { font-size: 13px; color: #fff; font-weight: 600; }
.cc-preview-embed-title { color: #fff; font-weight: 600; font-size: 15px; }
.cc-preview-embed-desc { color: #dbdee1; font-size: 13.5px; line-height: 1.4; word-wrap: break-word; }
.cc-preview-embed-fields { display: flex; flex-direction: column; gap: 8px; margin-top: 4px; }
.cc-preview-field .cc-preview-field-name { color: #fff; font-weight: 600; font-size: 13px; }
.cc-preview-field .cc-preview-field-val { color: #dbdee1; font-size: 13px; }
.cc-preview-embed-image { max-width: 100%; border-radius: 4px; margin-top: 4px; grid-column: 1 / -1; }
.cc-preview-embed-footer {
  margin-top: 6px;
  color: #949ba4; font-size: 11.5px;
  grid-column: 1 / -1;
}

/* ──────── PANEL TICKETS ergonomics polish ──────────────── */
.tp-topbar {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 18px;
  padding: 20px 22px;
  background: linear-gradient(135deg, rgba(31,221,240,.07), rgba(15,242,158,.04));
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.tp-topbar-actions { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.tp-title { font-size: 20px; margin: 0 0 4px; letter-spacing: -0.02em; }
.tp-sub { color: var(--text-3); font-size: 13px; max-width: 620px; line-height: 1.5; }
.tp-toggle {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 12px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--line-2);
  border-radius: var(--r-sm);
  font-size: 12.5px; color: var(--text-2);
  cursor: pointer;
  transition: all var(--t-base) var(--ease);
}
.tp-toggle:hover { background: rgba(255,255,255,.07); border-color: var(--line-3); }
.tp-toggle input { margin: 0; }

.tp-grid {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
  gap: 22px;
  align-items: start;
}
.tp-card {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 20px 22px;
  box-shadow: var(--sh-sm);
  transition: border-color var(--t-base) var(--ease);
}
.tp-card:hover { border-color: var(--line-2); }
.tp-card h3 {
  font-size: 14.5px;
  margin: 0 0 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
  color: var(--text);
  display: flex; align-items: center; gap: 8px;
  letter-spacing: -0.01em;
}
.tp-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 12px; }
.tp-field > span, .tp-field-label { font-size: 11.5px; font-weight: 600; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.05em; }
.tp-row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 680px) { .tp-row2 { grid-template-columns: 1fr; } }
.tp-hint { font-size: 12px; color: var(--text-3); margin-top: 6px; line-height: 1.5; }
.tp-md-toolbar { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 6px; }
.btn-mini {
  padding: 5px 9px; font-size: 11px; background: rgba(255,255,255,.04);
  border: 1px solid var(--line-2); border-radius: 6px; color: var(--text-2);
  transition: all var(--t-fast) var(--ease); cursor: pointer;
}
.btn-mini:hover { background: var(--accent-soft); border-color: var(--accent-ring); color: var(--accent); }
.tp-color-wrap { display: flex; gap: 8px; align-items: center; }
.tp-color-wrap input[type="color"] { width: 48px; flex-shrink: 0; padding: 3px; }
.tp-cat-mode { display: flex; flex-direction: column; gap: 8px; margin-bottom: 12px; }
.tp-radio {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px;
  background: rgba(255,255,255,.02);
  border: 1px solid var(--line); border-radius: var(--r-sm);
  cursor: pointer;
  transition: all var(--t-fast) var(--ease);
  font-size: 13px;
}
.tp-radio:hover { background: rgba(255,255,255,.05); border-color: var(--line-2); }
.tp-radio input:checked ~ span { color: var(--accent); }
.tp-cats { display: flex; flex-direction: column; gap: 10px; margin: 10px 0; }
.tp-cat {
  background: rgba(255,255,255,.02);
  border: 1px solid var(--line-2);
  border-radius: var(--r-md);
  padding: 10px 12px;
  transition: border-color var(--t-fast) var(--ease);
}
.tp-cat:hover { border-color: var(--line-3); }
.tp-cat-head {
  display: grid;
  grid-template-columns: auto 64px 1fr auto auto;
  gap: 8px; align-items: center;
}
.tp-cat-drag { cursor: grab; color: var(--muted); font-size: 14px; user-select: none; }
.tp-cat-emoji { text-align: center; padding: 8px !important; }
.tp-cat-enabled { display: flex; align-items: center; gap: 6px; font-size: 11.5px; color: var(--text-3); white-space: nowrap; margin: 0; }
.tp-cat-del {
  width: 28px; height: 28px; padding: 0;
  border: 1px solid var(--line-2); border-radius: 6px;
  color: var(--danger); background: transparent;
  cursor: pointer; transition: all var(--t-fast) var(--ease);
  font-size: 14px;
}
.tp-cat-del:hover { background: var(--danger-soft); border-color: var(--danger-ring); }
.tp-cat-body { display: flex; flex-direction: column; gap: 8px; margin-top: 8px; }
.tp-cat-reorder { display: flex; gap: 4px; justify-content: flex-end; }
.tp-pub-actions { display: flex; gap: 10px; margin-top: 8px; flex-wrap: wrap; }
.tp-pub-info { margin-top: 10px; font-size: 12px; color: var(--text-3); }

/* Sticky preview on desktop */
@media (min-width: 1100px) {
  .tp-preview-wrap {
    position: sticky;
    top: calc(var(--topbar-h) + 16px);
  }
}
.tp-preview-head h3 {
  font-size: 12px; text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--text-3); margin: 0 0 8px;
  border: none; padding: 0;
}

/* Discord-like preview mock */
.tp-preview { padding: 18px; }
.tp-discord-msg { display: flex; gap: 14px; }
.tp-discord-avatar {
  width: 40px; height: 40px; border-radius: 50%;
  background: linear-gradient(135deg, #1fddf0, #0ff29e);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; color: #06080f;
  flex-shrink: 0;
}
.tp-discord-body { flex: 1; min-width: 0; color: #dbdee1; font-family: 'Inter', system-ui, sans-serif; }
.tp-discord-author { color: #fff; font-weight: 600; font-size: 15px; }
.tp-discord-bot {
  display: inline-block; margin-left: 6px;
  padding: 1px 5px 0; border-radius: 3px;
  background: #5865f2; color: #fff; font-size: 10px; font-weight: 600;
}
.tp-discord-embed {
  margin-top: 6px;
  border-left: 4px solid #2dd4bf;
  background: #2b2d31;
  padding: 10px 14px;
  border-radius: 4px;
  max-width: 100%;
}
.tp-discord-title { color: #fff; font-weight: 600; font-size: 15px; margin-bottom: 4px; }
.tp-discord-desc { color: #dbdee1; font-size: 13.5px; line-height: 1.45; white-space: pre-wrap; }
.tp-discord-footer { color: #949ba4; font-size: 11.5px; margin-top: 8px; }
.tp-discord-image { max-width: 100%; border-radius: 4px; margin-top: 8px; }
.tp-discord-components {
  margin-top: 8px;
  display: flex; flex-wrap: wrap; gap: 6px;
}

/* Facturation date input — force visible text */
#facture-date, #facture-month, #facture-amount { color: var(--text) !important; }

/* Login logo nice rounding */
#login-page .login-logo img { filter: drop-shadow(0 8px 28px rgba(236,63,92,.25)); }
.brand-logo .vt-logo { filter: drop-shadow(0 4px 14px rgba(236,63,92,.35)) drop-shadow(0 0 22px rgba(110,62,192,.18)); }

/* ══════════════════════════════════════════════════════════════════
   V-TOOLS DESIGN SYSTEM v2.3 — Light/Dark Theme + Animations
   ══════════════════════════════════════════════════════════════════ */

/* ── SMOOTH THEME TRANSITIONS ─────────────────────────────────── */
.theme-switching,
.theme-switching * {
  transition:
    background-color 240ms ease,
    background 240ms ease,
    border-color 200ms ease,
    color 160ms ease,
    box-shadow 240ms ease !important;
}
/* Always-dark elements must be excluded */
.theme-switching .cc-preview,
.theme-switching .tp-preview,
.theme-switching .wh-preview,
.theme-switching .cc-preview *,
.theme-switching .tp-preview *,
.theme-switching .wh-preview * { transition: none !important; }

/* ── THEME TOGGLE BUTTON ──────────────────────────────────────── */
.theme-toggle {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  border-radius: var(--r-sm);
  color: var(--text-3);
  background: rgba(255,255,255,.04);
  border: 1px solid var(--line-2);
  cursor: pointer;
  transition: all var(--t-base) var(--ease);
  flex-shrink: 0;
}
.theme-toggle svg { pointer-events: none; display: block; }
.theme-toggle:hover {
  background: var(--accent-soft);
  border-color: var(--accent-ring);
  color: var(--accent);
  transform: rotate(18deg);
}

/* ── LIGHT MODE TOKEN OVERRIDES ───────────────────────────────── */
:root { color-scheme: dark; }
[data-theme="light"] {
  color-scheme: light;
  --bg:  #f0f3fc;
  --bg-1: #e6ebf7;
  --bg-2: #dde3f2;
  --bg-3: #d4dcec;
  --surface: rgba(255,255,255,.88);
  --surface-2: rgba(252,253,255,.9);
  --surface-3: rgba(246,249,255,.88);
  --surface-flat: rgba(255,255,255,.97);
  --surface-solid: #ffffff;
  --line: rgba(17,24,39,.068);
  --line-2: rgba(17,24,39,.12);
  --line-3: rgba(17,24,39,.22);
  --text: #0d111c;
  --text-2: #2d3748;
  --text-3: #64748b;
  --muted: #94a3b8;
  --dim: #cbd5e1;
  --sh-xs: 0 1px 3px rgba(0,0,0,.06);
  --sh-sm: 0 2px 10px rgba(0,0,0,.07);
  --sh-md: 0 8px 28px rgba(0,0,0,.09), 0 2px 8px rgba(0,0,0,.05);
  --sh-lg: 0 20px 60px rgba(0,0,0,.11), 0 4px 16px rgba(0,0,0,.07);
  --sh-glow: 0 0 0 1px rgba(31,221,240,.16), 0 6px 24px rgba(15,242,158,.09);
  --sh-inner: inset 0 1px 0 rgba(255,255,255,.5);
  --accent-soft: rgba(13,168,182,.12);
  --accent-softer: rgba(13,168,182,.06);
  --accent-ring: rgba(13,168,182,.40);
  --ok-soft: rgba(21,128,61,.11);
  --ok-ring: rgba(21,128,61,.32);
  --warn-soft: rgba(180,83,9,.11);
  --warn-ring: rgba(180,83,9,.32);
  --danger-soft: rgba(185,28,28,.11);
  --danger-ring: rgba(185,28,28,.32);
  --info-soft: rgba(59,130,246,.11);
  --info-ring: rgba(59,130,246,.32);
}

/* ── BODY / BACKGROUND ────────────────────────────────────────── */
[data-theme="light"] body {
  background:
    radial-gradient(900px 600px at 12% -10%, rgba(31,221,240,.07), transparent 60%),
    radial-gradient(700px 500px at 92% 8%, rgba(15,242,158,.05), transparent 55%),
    var(--bg);
}
[data-theme="light"] body::after { opacity: .18; }

/* ── SIDEBAR ──────────────────────────────────────────────────── */
[data-theme="light"] .sidebar {
  background: var(--bg-1);
  border-right-color: var(--line);
}
[data-theme="light"] .sidebar-brand { border-bottom-color: var(--line); }
[data-theme="light"] .brand-name {
  background: linear-gradient(95deg, #0ba8ba 0%, #09a87e 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
[data-theme="light"] .brand-sub { color: var(--text-3); }
[data-theme="light"] .sidebar-cmdk {
  background: rgba(0,0,0,.04); border-color: var(--line-2); color: var(--text-3);
}
[data-theme="light"] .sidebar-cmdk:hover {
  background: rgba(0,0,0,.07); border-color: var(--line-3); color: var(--text-2);
}
[data-theme="light"] .nav-group-label { color: var(--muted); }
[data-theme="light"] .nav-item { color: var(--text-3); }
[data-theme="light"] .nav-item:hover { background: rgba(0,0,0,.04); color: var(--text-2); }
[data-theme="light"] .nav-item.active {
  background: linear-gradient(90deg, rgba(13,168,182,.13), rgba(10,168,130,.05) 60%, transparent);
  color: var(--text);
}
[data-theme="light"] .nav-item.active .nav-icon { color: var(--text); }
[data-theme="light"] .nav-count { background: rgba(0,0,0,.09); color: var(--text-3); box-shadow: none; }
[data-theme="light"] .nav-count.urgent { background: var(--grad-danger); color: #fff; }
[data-theme="light"] .sidebar-footer { border-top-color: var(--line); }
[data-theme="light"] .health-row { color: var(--text-3); }
[data-theme="light"] .ping { color: var(--accent); }

/* ── TOPBAR ───────────────────────────────────────────────────── */
[data-theme="light"] .topbar {
  background: rgba(248,250,255,.92);
  border-bottom-color: var(--line);
  box-shadow: 0 1px 0 var(--line), 0 4px 20px rgba(0,0,0,.05);
}
[data-theme="light"] .topbar-menu { color: var(--text-3); }
[data-theme="light"] .topbar-menu:hover { background: rgba(0,0,0,.05); color: var(--text-2); }
[data-theme="light"] .push-toggle-btn {
  background: rgba(0,0,0,.05); border-color: var(--line-2); color: var(--text-2);
}
[data-theme="light"] .push-toggle-btn:hover { background: var(--accent-soft); border-color: var(--accent-ring); }
[data-theme="light"] .theme-toggle {
  background: rgba(0,0,0,.05); border-color: var(--line-2); color: var(--text-2);
}
[data-theme="light"] .theme-toggle:hover { background: var(--accent-soft); border-color: var(--accent-ring); color: var(--accent); }
[data-theme="light"] .sse-pill { background: var(--ok-soft); border-color: var(--ok-ring); color: #15803d; }
[data-theme="light"] .sse-pill.offline { background: var(--danger-soft); border-color: var(--danger-ring); color: #b91c1c; }

/* ── BUTTONS ──────────────────────────────────────────────────── */
[data-theme="light"] .btn,
[data-theme="light"] button.btn,
[data-theme="light"] .filter-btn,
[data-theme="light"] .refresh-btn,
[data-theme="light"] .view-btn,
[data-theme="light"] .btn-mini {
  background: rgba(0,0,0,.05);
  border-color: rgba(0,0,0,.13);
  color: var(--text-2);
}
[data-theme="light"] .btn:hover,
[data-theme="light"] .filter-btn:hover:not(.active),
[data-theme="light"] .btn-mini:hover {
  background: rgba(0,0,0,.09);
  border-color: rgba(0,0,0,.20);
  color: var(--text);
}
[data-theme="light"] .btn-ghost { background: transparent; border-color: transparent; color: var(--text-3); }
[data-theme="light"] .btn-ghost:hover { background: rgba(0,0,0,.06); color: var(--text-2); border-color: rgba(0,0,0,.1); }
[data-theme="light"] .filter-btn.active { background: var(--accent-soft); border-color: var(--accent-ring); color: var(--accent); }
[data-theme="light"] #login-btn { background: var(--grad-brand); color: #06080f; border: none; }

/* ── INPUTS ───────────────────────────────────────────────────── */
[data-theme="light"] input[type="text"],
[data-theme="light"] input[type="url"],
[data-theme="light"] input[type="number"],
[data-theme="light"] input[type="password"],
[data-theme="light"] input[type="email"],
[data-theme="light"] input[type="search"],
[data-theme="light"] input[type="date"],
[data-theme="light"] textarea, [data-theme="light"] select,
[data-theme="light"] .tp-input, [data-theme="light"] .wh-input,
[data-theme="light"] #login-input, [data-theme="light"] #comm-search,
[data-theme="light"] #facture-search {
  background: rgba(0,0,0,.04);
  border-color: rgba(0,0,0,.13);
  color: var(--text);
}
[data-theme="light"] input::placeholder,
[data-theme="light"] textarea::placeholder { color: var(--muted); }
[data-theme="light"] input:hover,
[data-theme="light"] textarea:hover,
[data-theme="light"] select:hover { background: rgba(0,0,0,.06); border-color: rgba(0,0,0,.18); }
[data-theme="light"] input:focus,
[data-theme="light"] textarea:focus,
[data-theme="light"] select:focus { background: rgba(13,168,182,.04); }
[data-theme="light"] kbd {
  background: rgba(0,0,0,.07); border-color: rgba(0,0,0,.16);
  color: var(--text-2); box-shadow: inset 0 -1px 0 rgba(0,0,0,.12);
}

/* ── CARDS / SURFACES ─────────────────────────────────────────── */
[data-theme="light"] .card,
[data-theme="light"] .kpi-card,
[data-theme="light"] .stat-card,
[data-theme="light"] .tp-card,
[data-theme="light"] .learn-card,
[data-theme="light"] .facture-card,
[data-theme="light"] .wh-embed-card,
[data-theme="light"] .wh-card,
[data-theme="light"] .cc-section,
[data-theme="light"] .ov-section {
  background: rgba(255,255,255,.82);
  border-color: var(--line);
  box-shadow: 0 1px 4px rgba(0,0,0,.06), 0 4px 16px rgba(0,0,0,.04);
}
[data-theme="light"] .ticket-card {
  background: rgba(255,255,255,.88);
  border-color: var(--line);
  box-shadow: var(--sh-sm);
}
[data-theme="light"] .ticket-card:hover {
  background: rgba(255,255,255,.98);
  border-color: var(--accent-ring);
  box-shadow: var(--sh-md), 0 0 0 1px var(--accent-ring);
}
[data-theme="light"] .ticket-card.urgent:hover { box-shadow: var(--sh-md), 0 0 0 1px var(--danger-ring); }

/* ── CHIPS / BADGES ───────────────────────────────────────────── */
[data-theme="light"] .chip, [data-theme="light"] .badge {
  background: rgba(0,0,0,.06); border-color: rgba(0,0,0,.12); color: var(--text-2);
}
[data-theme="light"] .chip.urgent { background: var(--danger-soft); border-color: var(--danger-ring); color: #b91c1c; }
[data-theme="light"] .chip.high { background: var(--warn-soft); border-color: var(--warn-ring); color: #92400e; }
[data-theme="light"] .chip.ok { background: var(--ok-soft); border-color: var(--ok-ring); color: #15803d; }
[data-theme="light"] .chip.accent { background: var(--accent-soft); border-color: var(--accent-ring); color: #0891b2; }

/* ── PANEL ────────────────────────────────────────────────────── */
[data-theme="light"] .panel, [data-theme="light"] #ticket-panel {
  background: rgba(255,255,255,.97);
  border-left-color: var(--line-2);
  box-shadow: -8px 0 40px rgba(0,0,0,.09);
}
[data-theme="light"] .panel-header { background: rgba(248,250,255,.97); border-bottom-color: var(--line); }
[data-theme="light"] .panel-reply-wrap { background: rgba(248,250,255,.97); border-top-color: var(--line); }
[data-theme="light"] .panel-meta-card { background: rgba(0,0,0,.03); border-color: var(--line); }
[data-theme="light"] .panel-overlay { background: rgba(200,210,230,.4); }

/* ── TABLES (commissions) ─────────────────────────────────────── */
[data-theme="light"] .comm-table-wrap { border-color: var(--line); background: rgba(255,255,255,.88); }
[data-theme="light"] .comm-table th { background: rgba(0,0,0,.03); color: var(--text-3); border-bottom-color: var(--line-2); }
[data-theme="light"] .comm-table td { border-bottom-color: var(--line); color: var(--text-2); }
[data-theme="light"] .comm-table tr:hover td { background: rgba(0,0,0,.025); color: var(--text); }
[data-theme="light"] #view-commissions .comm-stat { border-color: rgba(21,128,61,.18); }
[data-theme="light"] #view-commissions .comm-filter.active { background: rgba(21,128,61,.11); border-color: rgba(21,128,61,.35); color: #15803d; }

/* ── RESOLVED ─────────────────────────────────────────────────── */
[data-theme="light"] .resolved-card { background: rgba(255,255,255,.88); border-color: var(--line); }
[data-theme="light"] .resolved-card:hover { background: rgba(255,255,255,.98); border-color: var(--line-2); }
[data-theme="light"] .resolved-embed { background: rgba(248,250,255,.9); }

/* ── WEBHOOKS ─────────────────────────────────────────────────── */
[data-theme="light"] .wh-subtab { background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.1); color: var(--text-3); }
[data-theme="light"] .wh-subtab.active { background: var(--accent-soft); border-color: var(--accent-ring); color: #0891b2; }
[data-theme="light"] .wh-preset-card { background: rgba(255,255,255,.88); border-color: var(--line); }
[data-theme="light"] .wh-modal { background: rgba(255,255,255,.97); border-color: var(--line-2); }
[data-theme="light"] .wh-modal-overlay { background: rgba(200,210,240,.5); }
[data-theme="light"] .wh-section-title { color: var(--text-3); }

/* ── CMDK ─────────────────────────────────────────────────────── */
[data-theme="light"] .cmdk-backdrop { background: rgba(180,190,220,.45); }
[data-theme="light"] .cmdk-panel {
  background: rgba(255,255,255,.97); border-color: var(--line-2);
  box-shadow: var(--sh-lg), 0 0 0 1px rgba(13,168,182,.07);
}
[data-theme="light"] .cmdk-input-wrap { border-bottom-color: var(--line); }
[data-theme="light"] .cmdk-input { background: transparent !important; }
[data-theme="light"] .cmdk-result-name { color: var(--text); }
[data-theme="light"] .cmdk-result:hover, [data-theme="light"] .cmdk-result.active { background: var(--accent-soft); }
[data-theme="light"] .cmdk-footer { background: rgba(0,0,0,.03); border-top-color: var(--line); }
[data-theme="light"] .cmdk-group-label { color: var(--muted); }
[data-theme="light"] .cmdk-esc { color: var(--muted); }

/* ── TOAST ────────────────────────────────────────────────────── */
[data-theme="light"] .toast {
  background: rgba(255,255,255,.97); border-color: var(--line-2);
  color: var(--text); box-shadow: var(--sh-md);
}
[data-theme="light"] .toast.ok { border-left-color: var(--ok); }
[data-theme="light"] .toast.error { border-left-color: var(--danger); }

/* ── BOTTOM NAV ───────────────────────────────────────────────── */
[data-theme="light"] .bottom-nav { background: rgba(248,250,255,.95); border-top-color: var(--line); }
[data-theme="light"] .bottom-nav-item { color: var(--text-3); }
[data-theme="light"] .bottom-nav-item.active { color: var(--accent); }

/* ── MISC ─────────────────────────────────────────────────────── */
[data-theme="light"] .drop-zone { background: rgba(0,0,0,.03); border-color: rgba(0,0,0,.15); }
[data-theme="light"] .drop-zone:hover { background: var(--accent-soft); border-color: var(--accent-ring); }
[data-theme="light"] .file-item { background: rgba(0,0,0,.03); border-color: var(--line); }
[data-theme="light"] ::-webkit-scrollbar-thumb { background: rgba(0,0,0,.1); }
[data-theme="light"] ::-webkit-scrollbar-thumb:hover { background: rgba(13,168,182,.38); background-clip: padding-box; border: 2px solid transparent; }
[data-theme="light"] .panel-overlay {; }
[data-theme="light"] .tp-cat { border-color: var(--line-2); background: rgba(0,0,0,.03); }
[data-theme="light"] .tp-radio { background: rgba(0,0,0,.03); border-color: var(--line); }
[data-theme="light"] .tp-radio:hover { background: rgba(0,0,0,.06); }
[data-theme="light"] .wh-embed-card { border-color: var(--line); }
[data-theme="light"] .wh-embed-head { border-bottom-color: var(--line); background: rgba(0,0,0,.03); }
[data-theme="light"] .cc-item { background: rgba(0,0,0,.03); border-color: var(--line); }
[data-theme="light"] .cc-item:hover { background: rgba(0,0,0,.05); border-color: var(--line-2); }
[data-theme="light"] .cc-item.active { background: var(--accent-soft); border-color: var(--accent-ring); }
[data-theme="light"] .cc-response-type label { background: rgba(0,0,0,.04); border-color: var(--line); }
[data-theme="light"] .stat-card { background: rgba(255,255,255,.82); border-color: var(--line); }
[data-theme="light"] .stat-card.urgent { background: rgba(239,68,68,.06); }
[data-theme="light"] .stat-card.warn { background: rgba(245,158,11,.06); }
[data-theme="light"] .stat-card.ok { background: rgba(34,197,94,.06); }
[data-theme="light"] .learn-stat { background: rgba(255,255,255,.82); border-color: var(--line); }
[data-theme="light"] .history-row { border-bottom-color: var(--line); }
[data-theme="light"] .history-row:hover { background: rgba(0,0,0,.03); }

/* Login light */
[data-theme="light"] #login-page {
  background: var(--bg);
}
[data-theme="light"] .login-box {
  background: rgba(255,255,255,.95); border-color: var(--line-2);
  box-shadow: var(--sh-lg), 0 0 0 1px rgba(13,168,182,.08);
}
[data-theme="light"] .login-box h2 { color: var(--text); }

/* ═══════════════════════════════════════════════════════════════
   ANIMATIONS v2.3
   ═══════════════════════════════════════════════════════════════ */

/* ── ENTRANCE ANIMATIONS ──────────────────────────────────────── */
@keyframes slide-up   { from { opacity:0; transform:translateY(16px) } to { opacity:1; transform:translateY(0) } }
@keyframes slide-left { from { opacity:0; transform:translateX(20px) } to { opacity:1; transform:translateX(0) } }
@keyframes scale-in   { from { opacity:0; transform:scale(.94) }        to { opacity:1; transform:scale(1) } }
@keyframes float-in   { from { opacity:0; transform:translateY(8px) scale(.97) } to { opacity:1; transform:translateY(0) scale(1) } }
@keyframes shimmer {
  0%   { background-position: -400px 0; }
  100% { background-position:  400px 0; }
}
@keyframes count-up { from { opacity:0; transform:scale(.8) translateY(4px); } to { opacity:1; transform:scale(1) translateY(0); } }
@keyframes halo {
  0%,100% { box-shadow: 0 0 0 0 rgba(31,221,240,.22), var(--sh-glow); }
  50%      { box-shadow: 0 0 0 6px rgba(31,221,240,.04), var(--sh-glow); }
}
@keyframes float {
  0%,100% { transform: translateY(0); }
  50%      { transform: translateY(-6px); }
}
@keyframes gradient-shift {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}
@keyframes border-glow {
  0%,100% { border-color: var(--line-2); }
  50%      { border-color: var(--accent-ring); }
}
@keyframes ripple {
  to { transform: scale(4); opacity: 0; }
}

/* Tab view entrance */
.tab-view.active { animation: slide-up 300ms var(--ease) both; }

/* KPI cards stagger */
.ov-grid .kpi-card:nth-child(1) { animation: float-in 380ms var(--ease) 60ms  both; }
.ov-grid .kpi-card:nth-child(2) { animation: float-in 380ms var(--ease) 120ms both; }
.ov-grid .kpi-card:nth-child(3) { animation: float-in 380ms var(--ease) 180ms both; }
.ov-grid .kpi-card:nth-child(4) { animation: float-in 380ms var(--ease) 240ms both; }

/* KPI number pop */
.kpi-value { animation: count-up 480ms var(--ease) both; }
.ov-kpi-critical, .ov-kpi-high, .ov-kpi-total, .ov-kpi-commands { animation: count-up 420ms var(--ease) 200ms both; }

/* Stat card stagger */
.statsbar .stat-card:nth-child(1) { animation: slide-up 300ms var(--ease) 40ms  both; }
.statsbar .stat-card:nth-child(2) { animation: slide-up 300ms var(--ease) 80ms  both; }
.statsbar .stat-card:nth-child(3) { animation: slide-up 300ms var(--ease) 120ms both; }
.statsbar .stat-card:nth-child(4) { animation: slide-up 300ms var(--ease) 160ms both; }
.statsbar .stat-card:nth-child(5) { animation: slide-up 300ms var(--ease) 200ms both; }

/* Ticket cards stagger (applied via JS class) */
.ticket-card { animation: float-in 320ms var(--ease) both; }
.ticket-card:nth-child(1)  { animation-delay: 30ms;  }
.ticket-card:nth-child(2)  { animation-delay: 60ms;  }
.ticket-card:nth-child(3)  { animation-delay: 90ms;  }
.ticket-card:nth-child(4)  { animation-delay: 120ms; }
.ticket-card:nth-child(5)  { animation-delay: 150ms; }
.ticket-card:nth-child(6)  { animation-delay: 180ms; }
.ticket-card:nth-child(7)  { animation-delay: 210ms; }
.ticket-card:nth-child(8)  { animation-delay: 230ms; }
.ticket-card:nth-child(n+9){ animation-delay: 260ms; }

/* Nav items entrance on sidebar open */
.sidebar.open .nav-item { animation: slide-left 220ms var(--ease) both; }
.sidebar.open .nav-item:nth-child(1) { animation-delay: 30ms; }
.sidebar.open .nav-item:nth-child(2) { animation-delay: 60ms; }
.sidebar.open .nav-item:nth-child(3) { animation-delay: 90ms; }

/* Panel slide-in */
.panel.open { animation: slide-left 280ms var(--ease) both; }
@keyframes panel-in { from { transform: translateX(100%); opacity: .6; } to { transform: translateX(0); opacity: 1; } }
#ticket-panel.open { animation: panel-in 280ms var(--ease) both; }

/* Hero badge float */
.hero-badge { animation: float 4.5s ease-in-out infinite; }
/* Hero title gradient movement */
.hero-title {
  background: linear-gradient(135deg, #ffffff 0%, #b0b9cc 40%, #1fddf0 70%, #0ff29e 100%);
  background-size: 200% 200%;
  -webkit-background-clip: text; background-clip: text; color: transparent;
  animation: gradient-shift 6s ease infinite;
}

/* Login box entrance */
.login-box { animation: scale-in 340ms var(--ease) both; }

/* Shimmer loading skeleton */
.skeleton {
  background: linear-gradient(
    90deg,
    rgba(255,255,255,.04) 25%,
    rgba(255,255,255,.09) 50%,
    rgba(255,255,255,.04) 75%
  );
  background-size: 800px 100%;
  animation: shimmer 1.4s ease-in-out infinite;
  border-radius: var(--r-sm);
}
[data-theme="light"] .skeleton {
  background: linear-gradient(
    90deg,
    rgba(0,0,0,.05) 25%,
    rgba(0,0,0,.09) 50%,
    rgba(0,0,0,.05) 75%
  );
  background-size: 800px 100%;
  animation: shimmer 1.4s ease-in-out infinite;
}

/* KPI card pulsing halo on hover */
.kpi-card:hover { animation: halo 2.5s var(--ease) infinite; }

/* ── HOVER LIFT EFFECTS ────────────────────────────────────────── */
.kpi-card {
  transition: transform var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease), border-color var(--t-base) var(--ease);
}
.kpi-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--sh-md), var(--sh-glow);
  border-color: var(--accent-ring);
}
.stat-card {
  transition: transform var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease);
}
.stat-card:hover { transform: translateY(-2px); box-shadow: var(--sh-md); }

/* Resolved cards entrance */
.resolved-card { animation: float-in 300ms var(--ease) both; }

/* Knowledge items */
.knowledge-item { animation: slide-up 280ms var(--ease) both; }

/* Comm table row subtle entrance */
#comm-tbody tr { animation: slide-up 200ms var(--ease) both; }
#comm-tbody tr:nth-child(1) { animation-delay: 20ms; }
#comm-tbody tr:nth-child(2) { animation-delay: 40ms; }
#comm-tbody tr:nth-child(3) { animation-delay: 60ms; }
#comm-tbody tr:nth-child(n+4) { animation-delay: 80ms; }

/* ── BUTTON RIPPLE ─────────────────────────────────────────────── */
.btn, .filter-btn, .nav-item {
  overflow: hidden;
}
.btn::after, .filter-btn::after {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(circle, rgba(255,255,255,.18) 0%, transparent 70%);
  transform: scale(0);
  opacity: 0;
  transition: transform 0.4s ease, opacity 0.4s ease;
  pointer-events: none;
  border-radius: inherit;
}
.btn:active::after, .filter-btn:active::after {
  transform: scale(1);
  opacity: 1;
  transition: none;
}
[data-theme="light"] .btn::after, [data-theme="light"] .filter-btn::after {
  background: radial-gradient(circle, rgba(0,0,0,.09) 0%, transparent 70%);
}

/* ── TOPBAR HAMBURGER SVG FIX ─────────────────────────────────── */
.topbar-menu {
  display: none;
  width: 40px; height: 40px;
  padding: 0;
  align-items: center; justify-content: center;
  border-radius: var(--r-sm);
  color: var(--text-2);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
@media (max-width: 768px) { .topbar-menu { display: inline-flex; } }
.topbar-menu svg { pointer-events: none; display: block; }
.topbar-menu:hover { background: rgba(255,255,255,.06); color: var(--text); }

/* ── PUSH TOGGLE CLEANUP ──────────────────────────────────────── */
.push-toggle-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 34px; height: 34px;
  border-radius: var(--r-sm);
  background: transparent;
  border: 1px solid var(--line);
  color: var(--text-3);
  transition: all var(--t-base) var(--ease);
  cursor: pointer;
  padding: 0;
}
.push-toggle-btn:hover { background: var(--accent-soft); border-color: var(--accent-ring); }
.push-toggle-btn.push-active {
  background: var(--ok-soft); border-color: var(--ok-ring);
  animation: border-glow 2s ease-in-out infinite;
}

/* ── OVERVIEW HEALTH HOVER ────────────────────────────────────── */
.ov-health-row {
  transition: background var(--t-fast) var(--ease);
  border-radius: var(--r-xs);
  padding: 6px 8px;
  margin: 0 -8px;
}
.ov-health-row:hover { background: rgba(255,255,255,.04); }
[data-theme="light"] .ov-health-row:hover { background: rgba(0,0,0,.03); }

/* ── CMD PREVIEW ANIMATED CARET ──────────────────────────────── */
.cc-preview-cmdbar::after {
  content: '│';
  color: var(--accent);
  animation: pulse-dot 1s ease-in-out infinite;
  margin-left: 2px;
  font-weight: 300;
}

/* ── SECTION HEADER DIVIDER LINE ────────────────────────────── */
.section-header {
  position: relative;
  margin-bottom: 18px;
}
.section-header::after {
  content: '';
  display: block;
  height: 1px;
  background: linear-gradient(90deg, var(--accent-ring), var(--line), transparent);
  margin-top: 10px;
}

/* ── TOPBAR LIVE INDICATOR ──────────────────────────────────── */

/* ── OVERVIEW PRIORITY ITEM HOVER ──────────────────────────── */
.ov-item {
  transition: background var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}
.ov-item:hover { transform: translateX(3px); background: rgba(255,255,255,.04); }
[data-theme="light"] .ov-item:hover { background: rgba(0,0,0,.03); }

/* ── FACTURE HISTORY ROW ─────────────────────────────────── */
.history-row { transition: background var(--t-fast) var(--ease); }
.history-row:hover { background: rgba(255,255,255,.04); }

/* ── STAT BAR VALUES GLOW ───────────────────────────────── */
.stat-card .val {
  transition: color var(--t-base) var(--ease), text-shadow var(--t-base) var(--ease);
}
.stat-card:hover .val { text-shadow: 0 0 20px rgba(31,221,240,.45); }
.stat-card.urgent:hover .val { text-shadow: 0 0 20px rgba(239,68,68,.45); }
.stat-card.warn:hover .val { text-shadow: 0 0 20px rgba(245,158,11,.45); }
.stat-card.ok:hover .val { text-shadow: 0 0 20px rgba(34,197,94,.45); }

/* ── CC BADGE IN LIST ───────────────────────────────────── */
.cc-badge-on   { animation: none; }
.cc-badge-pending { animation: border-glow 2.5s ease-in-out infinite; }

/* ── WIPE-IN FOR FORMS ──────────────────────────────────── */
#cc-editor, .facture-card, .tp-card {
  animation: slide-up 280ms var(--ease) both;
}

/* ── GLOBAL FOCUS RING OVERRIDE ─────────────────────────── */
:focus-visible {
  outline: 2px solid rgba(31,221,240,.55);
  outline-offset: 2px;
  border-radius: 4px;
}
[data-theme="light"] :focus-visible {
  outline-color: rgba(13,168,182,.6);
}

/* End of V-Tools Design System v2.3 */

/* ============ TICKETS COCKPIT ============ */
body.view-tickets .statsbar {
  grid-template-columns: repeat(5, minmax(150px, 1fr));
  gap: 14px;
  padding: 18px var(--gutter) 0;
  margin: 0;
}
body.view-tickets .statsbar .stat-card {
  position: relative;
  min-height: 96px;
  padding: 16px;
  overflow: hidden;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
}
body.view-tickets .statsbar .stat-card::after {
  content: '';
  position: absolute;
  inset: auto 16px 14px 16px;
  height: 2px;
  border-radius: 10px;
  background: var(--accent);
  opacity: .6;
}
body.view-tickets .statsbar .stat-card.urgent::after { background: #ef4444; }
body.view-tickets .statsbar .stat-card.warn::after { background: #f59e0b; }
body.view-tickets .statsbar .stat-card.ok::after { background: #22c55e; }
body.view-tickets .statsbar .val {
  font-size: clamp(26px, 3vw, 38px);
  line-height: 1;
  font-weight: 800;
  letter-spacing: -.04em;
}
body.view-tickets .statsbar .lbl {
  margin-top: 10px;
  color: var(--text-3);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .08em;
}

#view-tickets {
  padding: 20px var(--gutter) 40px;
}
.tickets-hero {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  align-items: flex-end;
  padding: 20px 24px;
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  background: var(--bg-2);
}
.tickets-kicker {
  display: inline-flex;
  margin-bottom: 10px;
  color: #2dd4bf;
  font-size: 12px;
  font-weight: 750;
  letter-spacing: .13em;
  text-transform: uppercase;
}
.tickets-hero h2 {
  margin: 0;
  color: var(--text);
  font-size: clamp(28px, 3.4vw, 44px);
  line-height: .95;
  letter-spacing: -.05em;
}
.tickets-hero p {
  max-width: 720px;
  margin: 12px 0 0;
  color: var(--text-2);
  font-size: 15px;
  line-height: 1.55;
}
.tickets-hero-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.tickets-toolbar,
.tickets-smartbar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 14px 0 0;
  padding: 10px 12px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--r-md);
  background: rgba(255,255,255,.025);
  flex-wrap: wrap;
}
.tickets-toolbar .filter-pills { flex: 1; min-width: 0; }
.tickets-toolbar .toolbar-right { margin-left: auto; flex-shrink: 0; }
.tickets-select select,
.toolbar-search-wrap input[type="search"] {
  width: 100%;
  min-height: 38px;
  padding: 0 14px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 10px;
  background: rgba(255,255,255,.03);
  color: var(--text);
}
.tickets-select {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 220px;
}
.tickets-select span {
  color: var(--text-3);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.tickets-smartbar {
  grid-template-columns: repeat(2, minmax(220px, 280px));
  justify-content: end;
  margin-top: 10px;
}
#view-tickets .filter-btn {
  min-height: 40px;
  border-radius: 12px;
}
#view-tickets .filter-btn.active {
  color: #020d0e;
  background: var(--accent);
  border-color: var(--accent);
}
.tickets-view-toggle .view-btn {
  border-radius: 10px;
  color: var(--text-2);
}

#tickets-grid {
  padding: 18px 0 0;
  gap: 18px;
}
#tickets-grid .ticket-section {
  margin: 0;
}
#tickets-grid .section-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 10px;
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}
#tickets-grid .section-count {
  display: inline-flex;
  min-width: 26px;
  height: 22px;
  align-items: center;
  justify-content: center;
  padding: 0 8px;
  border-radius: 999px;
  background: rgba(45,212,191,.12);
  color: #5eead4;
}
#tickets-grid .section-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(390px, 1fr));
  gap: 14px;
  margin-top: 0;
}
#tickets-grid.list-view .section-cards {
  grid-template-columns: 1fr;
}

.ticket-card.ticket-row {
  --ticket-accent: #2dd4bf;
  display: grid;
  grid-template-columns: 26px 64px minmax(0, 1fr);
  align-items: flex-start;
  gap: 16px;
  min-height: 220px;
  padding: 18px;
  border-left: 1px solid rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.12);
  border-radius: var(--r-md);
  background: rgba(255,255,255,.025);
}
.ticket-card.ticket-row.urgency-critical { --ticket-accent: #ef4444; }
.ticket-card.ticket-row.urgency-high { --ticket-accent: #f59e0b; }
.ticket-card.ticket-row.urgency-medium { --ticket-accent: #eab308; }
.ticket-card.ticket-row.urgency-normal { --ticket-accent: #22c55e; }
.ticket-card.ticket-row:hover {
  border-color: color-mix(in srgb, var(--ticket-accent) 52%, rgba(255,255,255,.12));
  box-shadow: 0 18px 50px rgba(0,0,0,.28), 0 0 0 1px color-mix(in srgb, var(--ticket-accent) 24%, transparent);
  transform: translateY(-1px);
}
.ticket-check {
  width: 22px;
  height: 22px;
  border-radius: 7px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.04);
}
.ticket-avatar {
  width: 64px;
  height: 64px;
  display: grid;
  place-items: center;
  border-radius: var(--r-md);
  color: #07130f;
  font-weight: 800;
  font-size: 22px;
  background: linear-gradient(135deg, var(--ticket-accent), #99f6e4);
  box-shadow: 0 14px 38px color-mix(in srgb, var(--ticket-accent) 22%, transparent);
  overflow: hidden;
}
.ticket-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.ticket-main {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.ticket-title-row {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.ticket-title {
  margin: 0;
  color: #5eead4;
  font-size: 16px;
  font-weight: 800;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ticket-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  color: var(--text-3);
  font-size: 12px;
}
.ticket-meta-row span {
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.045);
  border: 1px solid rgba(255,255,255,.07);
}
.ticket-email {
  color: var(--text-2);
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
}
.ticket-status-pill,
.ticket-dev-badge,
.ticket-merge-badge {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
}
.ticket-status-pill.is-critical { background: rgba(239,68,68,.14); color: #fca5a5; }
.ticket-status-pill.is-high { background: rgba(245,158,11,.14); color: #fcd34d; }
.ticket-status-pill.is-medium { background: rgba(234,179,8,.14); color: #fde68a; }
.ticket-status-pill.is-normal { background: rgba(34,197,94,.13); color: #86efac; }
.ticket-status-pill.is-dev { background: rgba(59,130,246,.15); color: #93c5fd; }
.ticket-side {
  grid-column: 2 / -1;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.ticket-age {
  color: var(--text);
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.ticket-dev-badge {
  background: rgba(255,255,255,.055);
  color: var(--text-2);
}
.ticket-dev-badge.dev-sent,
.ticket-dev-badge.dev-ack,
.ticket-dev-badge.dev-working { background: rgba(59,130,246,.15); color: #93c5fd; }
.ticket-dev-badge.dev-resolved { background: rgba(34,197,94,.14); color: #86efac; }
.ticket-merge-badge { background: rgba(168,85,247,.14); color: #d8b4fe; }
.ticket-actions {
  grid-column: 2 / -1;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  flex-wrap: wrap;
}
.ticket-actions .dev-select {
  min-width: 132px;
  border-radius: 10px;
}
.sla-fill.high { background: linear-gradient(90deg, #f59e0b, #f97316); }
.sla-fill.critical { background: linear-gradient(90deg, #ef4444, #fb7185); }
.sla-fill.medium { background: linear-gradient(90deg, #eab308, #facc15); }
.sla-fill.normal { background: linear-gradient(90deg, #22c55e, #2dd4bf); }

#tickets-grid.list-view .ticket-card.ticket-row {
  grid-template-columns: 26px 58px minmax(0, 1fr) minmax(150px, .26fr) auto;
  align-items: center;
  min-height: 132px;
}
#tickets-grid.list-view .ticket-avatar {
  width: 58px;
  height: 58px;
}
#tickets-grid.list-view .ticket-side {
  grid-column: auto;
  flex-direction: column;
  align-items: flex-start;
}
#tickets-grid.list-view .ticket-actions {
  grid-column: auto;
  justify-content: flex-end;
}

@media (max-width: 1180px) {
  body.view-tickets .statsbar { grid-template-columns: repeat(2, minmax(160px, 1fr)); }
  .tickets-toolbar,
  .tickets-smartbar { flex-direction: column; align-items: stretch; }
  .tickets-toolbar .toolbar-search-wrap { max-width: 100%; }
  .tickets-toolbar .toolbar-right { margin-left: 0; justify-content: flex-end; }
  .tickets-smartbar { justify-content: stretch; }
  .tickets-select { min-width: 0; }
  .ticket-card.ticket-row { grid-template-columns: 48px minmax(0, 1fr); }
  .ticket-check { display: none; }
  .ticket-avatar { width: 48px; height: 48px; border-radius: 14px; }
  .ticket-side, .ticket-actions { grid-column: 2; flex-direction: row; justify-content: flex-start; }
}

@media (max-width: 680px) {
  body.view-tickets .statsbar { grid-template-columns: 1fr; }
  #view-tickets { padding-inline: 14px; }
  .tickets-hero { align-items: flex-start; flex-direction: column; padding: 18px; }
  #tickets-grid .section-cards { grid-template-columns: 1fr; }
}

/* ============ TICKETS V4 - SUPPORT COCKPIT ============ */
body.view-tickets .content,
body.view-tickets #view-tickets {
  max-width: none;
}

body.view-tickets #view-tickets {
  padding: 22px 32px 44px;
}

body.view-tickets .statsbar {
  display: grid;
  grid-template-columns: repeat(5, minmax(160px, 1fr));
  gap: 14px;
  margin: 0 0 18px;
}

body.view-tickets .stat-card {
  min-height: 100px;
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  background: var(--bg-2);
  overflow: hidden;
}



body.view-tickets .stat-number {
  font-size: clamp(28px, 2.6vw, 44px);
  letter-spacing: -.04em;
}

.tickets-hero {
  position: relative;
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  background: var(--bg-2);
}

.tickets-hero::before { display: none;
}

.tickets-kicker {
  color: #2dd4bf;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .10em;
  text-transform: uppercase;
}

.tickets-hero h1 {
  margin: 12px 0 10px;
  font-size: clamp(36px, 4vw, 56px);
  letter-spacing: -.055em;
}

.tickets-hero p {
  max-width: 860px;
  color: rgba(226,232,240,.74);
  font-size: 16px;
  line-height: 1.65;
}

.tickets-hero-actions {
  align-self: flex-end;
  z-index: 1;
}

.tickets-control-deck,
.tickets-smartbar {
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  background: var(--bg-2);
}

.tickets-control-deck {
  display: grid;
  grid-template-columns: minmax(280px, 1fr) minmax(170px, .28fr) repeat(6, auto);
  gap: 10px;
  align-items: center;
  padding: 14px;
  margin-top: 16px;
}

.tickets-control-deck input,
.tickets-control-deck select,
.tickets-smartbar select {
  height: 46px;
  border-radius: 14px;
  background: rgba(255,255,255,.035);
  border-color: rgba(255,255,255,.1);
}

.filter-pill,
.view-btn {
  min-height: 44px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  background: rgba(255,255,255,.045);
  color: rgba(226,232,240,.84);
  font-weight: 800;
}

.filter-pill.active,
.view-btn.active {
  background: var(--accent);
  color: #020d0e;
  border-color: var(--accent);
  box-shadow: 0 4px 14px rgba(31,221,240,.25);
}

.tickets-smartbar {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) minmax(180px, .4fr) minmax(180px, .4fr);
  gap: 12px;
  align-items: end;
  padding: 16px;
  margin: 12px 0 22px;
}

.tickets-smartbar label {
  display: grid;
  gap: 8px;
  color: rgba(148,163,184,.9);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
}

#tickets-grid {
  display: grid;
  gap: 18px;
}

#tickets-grid .ticket-section {
  display: grid;
  gap: 12px;
}

#tickets-grid .section-title,
#tickets-grid .section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 4px 0;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .10em;
  text-transform: uppercase;
}

#tickets-grid .section-count {
  min-width: 32px;
  padding: 4px 10px;
  border: 1px solid rgba(45,212,191,.22);
  border-radius: 999px;
  color: #5eead4;
  text-align: center;
  letter-spacing: 0;
  background: rgba(45,212,191,.08);
}

#tickets-grid .section-title::after {
  content: attr(data-count);
  min-width: 32px;
  padding: 4px 10px;
  border: 1px solid rgba(45,212,191,.22);
  border-radius: 999px;
  color: #5eead4;
  text-align: center;
  letter-spacing: 0;
  background: rgba(45,212,191,.08);
}

#tickets-grid .section-cards {
  display: grid;
  gap: 12px;
}

#tickets-grid:not(.list-view) .section-cards {
  grid-template-columns: repeat(auto-fill, minmax(420px, 1fr));
}

.ticket-card.ticket-row {
  --ticket-accent: #2dd4bf;
  position: relative;
  display: grid;
  grid-template-columns: 28px 74px minmax(320px, 1fr) minmax(130px, .22fr) minmax(315px, auto);
  gap: 16px;
  align-items: center;
  min-height: 120px;
  padding: 18px 20px;
  border: 1px solid var(--line);
  border-left: 3px solid var(--ticket-accent);
  border-radius: var(--r-md);
  background: var(--bg-2);
  cursor: pointer;
  overflow: hidden;
  transition: border-color var(--t-base) var(--ease), transform var(--t-fast) var(--ease), box-shadow var(--t-base) var(--ease);
}



.ticket-card.ticket-row.urgency-critical { --ticket-accent: #fb7185; }
.ticket-card.ticket-row.urgency-high { --ticket-accent: #f59e0b; }
.ticket-card.ticket-row.urgency-medium { --ticket-accent: #eab308; }
.ticket-card.ticket-row.urgency-normal { --ticket-accent: #2dd4bf; }

.ticket-card.ticket-row:hover {
  transform: translateY(-1px);
  border-color: rgba(255,255,255,.14);
  box-shadow: var(--sh-md);
}

.ticket-check {
  width: 22px;
  height: 22px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 8px;
  background: rgba(255,255,255,.025);
}

.ticket-avatar {
  width: 56px;
  height: 56px;
  border-radius: var(--r-md);
  display: grid;
  place-items: center;
  overflow: hidden;
  color: var(--text);
  font-size: 20px;
  font-weight: 700;
  background: var(--bg-3);
  border: 1px solid var(--line);
}

.ticket-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.ticket-title-row,
.ticket-meta-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.ticket-title {
  margin: 0;
  color: #37e6d0;
  font-size: 20px;
  font-weight: 800;
  letter-spacing: -.02em;
}

.ticket-meta-row span,
.ticket-status-pill,
.ticket-dev-badge,
.ticket-merge-badge {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 5px 11px;
  border: 1px solid rgba(255,255,255,.075);
  border-radius: 999px;
  background: rgba(255,255,255,.055);
  color: rgba(203,213,225,.84);
  font-size: 12px;
  font-weight: 800;
}

.ticket-email {
  margin-top: 12px;
  color: rgba(203,213,225,.78);
  font-size: 13px;
  letter-spacing: .015em;
}

.sla-bar-wrap,
.ticket-sla-line {
  margin-top: 14px;
}

.sla-bar {
  height: 4px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
}

.sla-fill {
  height: 100%;
  border-radius: inherit;
}

.ticket-side {
  display: grid;
  gap: 8px;
  align-content: center;
}

.ticket-age {
  color: #f8fafc;
  font-size: 18px;
  font-weight: 800;
  letter-spacing: -.02em;
}

.ticket-actions {
  display: grid;
  grid-template-columns: minmax(150px, 1fr) auto auto;
  gap: 10px;
  justify-content: end;
}

.ticket-actions .dev-select,
.ticket-actions .btn {
  height: 42px;
  border-radius: 13px;
}

.ticket-actions .btn {
  min-width: 88px;
  font-weight: 800;
}

#tickets-grid:not(.list-view) .ticket-card.ticket-row {
  grid-template-columns: 24px 64px minmax(0, 1fr);
  min-height: 230px;
}

#tickets-grid:not(.list-view) .ticket-side,
#tickets-grid:not(.list-view) .ticket-actions {
  grid-column: 2 / -1;
}

#tickets-grid:not(.list-view) .ticket-card.ticket-row::before {
  left: 110px;
  right: 28px;
}

#tickets-grid.list-view .ticket-side,
#tickets-grid.list-view .ticket-actions {
  grid-column: auto;
}

#tickets-grid.list-view .ticket-card.ticket-row {
  grid-template-columns: 28px 74px minmax(320px, 1fr) minmax(130px, .22fr) minmax(315px, auto);
  min-height: 132px;
}

#tickets-grid.list-view .ticket-avatar {
  width: 68px;
  height: 68px;
}

.panel-overlay.open,
.panel-overlay.visible {
  opacity: 1;
  pointer-events: auto;
}

.panel,
.ticket-panel {
  width: min(640px, 100vw);
  border-left: 1px solid var(--line);
  background: var(--bg-1);
}

.panel-header {
  min-height: 96px;
  padding: 24px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.panel-meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  padding: 16px 24px;
}

.panel-meta-card {
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  background: rgba(255,255,255,.02);
}

.panel-meta-card span {
  display: block;
  margin-bottom: 5px;
  color: rgba(148,163,184,.86);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.panel-meta-card strong {
  color: #f8fafc;
  font-size: 13px;
  word-break: break-word;
}

.panel-actions-bar {
  padding: 0 24px 16px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.panel-messages-wrap {
  padding: 18px 20px;
}

.panel-reply-wrap {
  padding: 16px 20px;
  border-top: 1px solid rgba(255,255,255,.08);
  background: rgba(3,7,12,.76);
}

@media (max-width: 1320px) {
  body.view-tickets .statsbar { grid-template-columns: repeat(3, minmax(160px, 1fr)); }
  .tickets-control-deck { grid-template-columns: minmax(260px, 1fr) repeat(3, auto); }
  .ticket-card.ticket-row {
    grid-template-columns: 26px 64px minmax(0, 1fr);
  }
  .ticket-card.ticket-row::before {
    left: 128px;
    right: 26px;
  }
  .ticket-side,
  .ticket-actions,
  #tickets-grid.list-view .ticket-side,
  #tickets-grid.list-view .ticket-actions {
    grid-column: 3;
  }
}

@media (max-width: 820px) {
  body.view-tickets #view-tickets { padding: 16px; }
  body.view-tickets .statsbar { grid-template-columns: 1fr; }
  .tickets-control-deck,
  .tickets-smartbar {
    grid-template-columns: 1fr;
  }
  .ticket-card.ticket-row {
    grid-template-columns: 56px minmax(0, 1fr);
    padding: 16px;
  }
  #tickets-grid.list-view .ticket-card.ticket-row,
  #tickets-grid:not(.list-view) .ticket-card.ticket-row {
    grid-template-columns: 56px minmax(0, 1fr);
    min-height: auto;
  }
  .ticket-check { display: none; }
  .ticket-avatar { width: 54px; height: 54px; border-radius: var(--r-md); }
  #tickets-grid.list-view .ticket-avatar { width: 54px; height: 54px; }
  .ticket-main,
  .ticket-side,
  .ticket-actions,
  #tickets-grid.list-view .ticket-side,
  #tickets-grid.list-view .ticket-actions {
    grid-column: 2;
  }
  .ticket-actions {
    grid-template-columns: 1fr 1fr;
  }
  .ticket-actions .dev-select {
    grid-column: 1 / -1;
  }
  .panel-meta {
    grid-template-columns: 1fr;
  }
}

/* ============ VINTEER INSPIRED DASHBOARD PAGES ============ */
.ticket-category-avatar {
  background: var(--bg-3);
  border: 1px solid var(--line);
  color: var(--text);
  font-size: 28px;
  border: 1px solid color-mix(in srgb, var(--ticket-accent) 35%, rgba(255,255,255,.12));
}

.ticket-category-avatar span {
  filter: drop-shadow(0 8px 16px rgba(0,0,0,.28));
}

.ticket-category-avatar.cat-tech { --ticket-accent: #22d3ee; }
.ticket-category-avatar.cat-billing { --ticket-accent: #fbbf24; }
.ticket-category-avatar.cat-partner { --ticket-accent: #f59e0b; }
.ticket-category-avatar.cat-custom { --ticket-accent: #a78bfa; }
.ticket-category-avatar.cat-default { --ticket-accent: #2dd4bf; }

body.view-overview #view-overview,
body.view-commands #view-commands {
  max-width: none;
  padding: 24px 32px 48px;
}

body.view-overview .page-wrap {
  max-width: none;
  display: grid;
  gap: 20px;
}

body.view-overview .hero,
body.view-commands .tp-header {
  position: relative;
  padding: 24px 0 8px;
  border: none;
  background: transparent;
  min-height: auto;
}

body.view-overview .hero::after, body.view-commands .tp-header::after { display: none; }

body.view-overview .hero-title,
body.view-commands .tp-title {
  margin: 10px 0;
  font-size: clamp(36px, 4vw, 58px);
  line-height: .95;
  letter-spacing: -.06em;
}

body.view-overview .hero-subtitle,
body.view-commands .tp-subtitle {
  max-width: 760px;
  color: rgba(203,213,225,.78);
  font-size: 16px;
  line-height: 1.65;
}

body.view-overview .hero-actions,
body.view-commands .tp-actions {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

body.view-overview .hero-badge,
body.view-commands .cc-scope-badge {
  border: 1px solid rgba(45,212,191,.24);
  border-radius: 999px;
  background: rgba(45,212,191,.08);
  color: #5eead4;
  font-weight: 800;
}

body.view-overview .ov-grid {
  grid-template-columns: repeat(4, minmax(190px, 1fr));
  gap: 14px;
}

body.view-overview .kpi-card {
  min-height: 130px;
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  background: var(--bg-2);
}

body.view-overview .kpi-value {
  font-size: clamp(32px, 3.2vw, 52px);
  letter-spacing: -.055em;
}

body.view-overview .ov-columns {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(360px, .75fr);
  gap: 18px;
}

body.view-overview .ov-section {
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  background: var(--bg-2);
}

body.view-overview .ov-list,
body.view-overview .ov-health,
body.view-overview .shortcuts-grid {
  padding: 16px;
}

body.view-overview .ov-health-row,
body.view-overview .ov-priority-item,
body.view-overview .sc-item {
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  background: rgba(255,255,255,.025);
}

body.view-commands .tp-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 18px;
}

body.view-commands .tp-title {
  font-size: clamp(34px, 3.6vw, 54px);
}

body.view-commands .cc-layout {
  display: grid;
  grid-template-columns: minmax(320px, 420px) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}

body.view-commands .cc-list-col,
body.view-commands .cc-editor,
body.view-commands .cc-empty {
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  background: var(--bg-2);
}

body.view-commands .cc-list-col {
  position: sticky;
  top: 92px;
  padding: 16px;
}

body.view-commands .cc-list {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

body.view-commands .cc-item {
  border: 1px solid rgba(255,255,255,.075);
  border-radius: var(--r-md);
  padding: 16px;
  background: rgba(255,255,255,.035);
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}

body.view-commands .cc-item:hover,
body.view-commands .cc-item.active {
  transform: translateY(-1px);
  border-color: rgba(45,212,191,.38);
  background: rgba(45,212,191,.07);
}

body.view-commands .cc-item-name {
  color: #5eead4;
  font-size: 18px;
  font-weight: 800;
  letter-spacing: -.02em;
}

body.view-commands .cc-item-desc {
  margin-top: 8px;
  color: rgba(203,213,225,.72);
  line-height: 1.45;
}

body.view-commands .cc-badge {
  display: inline-flex;
  margin-top: 12px;
  padding: 5px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
}

body.view-commands .cc-badge-on {
  background: rgba(34,197,94,.14);
  color: #86efac;
}

body.view-commands .cc-badge-off {
  background: rgba(148,163,184,.12);
  color: #cbd5e1;
}

body.view-commands .cc-badge-pending {
  background: rgba(245,158,11,.14);
  color: #fcd34d;
}

body.view-commands .cc-editor,
body.view-commands .cc-empty {
  padding: 18px;
}

body.view-commands .cc-section {
  border: 1px solid rgba(255,255,255,.075);
  border-radius: var(--r-lg);
  padding: 18px;
  margin-bottom: 14px;
  background: rgba(255,255,255,.03);
}

body.view-commands .tp-row2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

body.view-commands .tp-field input,
body.view-commands .tp-field textarea,
body.view-commands .cc-field-row input {
  border-radius: 15px;
  background: rgba(255,255,255,.045);
  border-color: rgba(255,255,255,.1);
}

body.view-commands .cc-response-type,
body.view-commands .cc-switch-row,
body.view-commands .cc-editor-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

body.view-commands .cc-response-type label,
body.view-commands .tp-toggle {
  min-height: 44px;
  padding: 10px 14px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  background: rgba(255,255,255,.035);
  font-weight: 800;
}

body.view-commands .cc-preview {
  border-radius: var(--r-lg);
  background: #2b2d31;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
}

body.view-commands .cc-editor-footer {
  position: sticky;
  bottom: 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--r-md);
  background: rgba(8,11,18,.92);
}

@media (max-width: 1180px) {
  body.view-overview .ov-grid { grid-template-columns: repeat(2, minmax(190px, 1fr)); }
  body.view-overview .ov-columns,
  body.view-commands .cc-layout {
    grid-template-columns: 1fr;
  }
  body.view-commands .cc-list-col {
    position: static;
  }
}

@media (max-width: 760px) {
  body.view-overview #view-overview,
  body.view-commands #view-commands {
    padding: 16px;
  }
  body.view-overview .ov-grid,
  body.view-commands .tp-row2 {
    grid-template-columns: 1fr;
  }
  body.view-commands .tp-header {
    flex-direction: column;
  }
  body.view-commands .cc-editor-footer {
    position: static;
    flex-direction: column;
    align-items: stretch;
  }
}

/* Status center */
#view-status {
  padding: 24px 32px 48px;
}

.status-center {
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.status-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  background: var(--bg-2);
}

.status-hero h1 {
  margin: 6px 0 8px;
  font-size: clamp(32px, 4vw, 52px);
  letter-spacing: -.045em;
}

.status-hero p {
  margin: 0;
  color: var(--muted);
  max-width: 720px;
}

.status-hero-actions,
.status-actions,
.status-sub-add,
.status-alert-box {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.status-kpis {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 14px;
}

.status-kpi {
  padding: 18px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--r-lg);
  background: var(--bg-2);
}

.status-kpi span {
  display: block;
  color: var(--muted);
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: .12em;
}

.status-kpi strong {
  display: block;
  margin-top: 10px;
  font-size: 34px;
  line-height: 1;
}

.status-kpi.ok strong { color: #35e88d; }
.status-kpi.warn strong { color: #f5a524; }
.status-kpi.down strong { color: #ff5c73; }

.status-workspace {
  display: grid;
  grid-template-columns: minmax(320px, 430px) minmax(0, 1fr);
  gap: 18px;
}

.status-list-card,
.status-editor-card,
.status-subservices-card {
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  background: var(--bg-2);
}

.status-list-card,
.status-editor-card {
  padding: 18px;
}

.status-section-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
  margin-bottom: 16px;
}

.status-section-head h2,
.status-section-head h3 {
  margin: 4px 0 0;
}

.status-section-head.compact {
  margin-bottom: 10px;
}

.status-services {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.status-service-card {
  width: 100%;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  grid-template-areas:
    "dot main chip"
    "dot main sub";
  align-items: center;
  gap: 8px 12px;
  padding: 14px;
  text-align: left;
  color: var(--text);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--r-md);
  background: rgba(255,255,255,.035);
  cursor: pointer;
}

.status-service-card.active {
  border-color: rgba(32,255,190,.5);
  box-shadow: 0 0 0 1px rgba(32,255,190,.18), 0 14px 40px rgba(0,0,0,.2);
}

.status-service-card.up { background: linear-gradient(135deg, rgba(30,220,130,.12), rgba(255,255,255,.03)); }
.status-service-card.degraded { background: linear-gradient(135deg, rgba(245,165,36,.13), rgba(255,255,255,.03)); }
.status-service-card.down { background: linear-gradient(135deg, rgba(255,76,105,.15), rgba(255,255,255,.03)); }

.status-dot {
  grid-area: dot;
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: #35e88d;
  box-shadow: 0 0 18px currentColor;
}

.status-service-card.degraded .status-dot { background: #f5a524; }
.status-service-card.down .status-dot { background: #ff5c73; }

.status-service-main {
  grid-area: main;
  min-width: 0;
}

.status-service-main strong,
.status-service-main small {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.status-service-main small,
.status-subcount {
  color: var(--muted);
  font-size: 12px;
}

.status-chip {
  grid-area: chip;
  justify-self: end;
  padding: 5px 9px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
}

.status-chip.up { color: #35e88d; background: rgba(53,232,141,.12); }
.status-chip.degraded { color: #f5a524; background: rgba(245,165,36,.12); }
.status-chip.down { color: #ff5c73; background: rgba(255,92,115,.12); }
.status-subcount { grid-area: sub; justify-self: end; }

.form-grid.two {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.form-grid label {
  display: grid;
  gap: 8px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.form-grid input,
.status-sub-add input {
  width: 100%;
  min-height: 46px;
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 14px;
  color: var(--text);
  background: rgba(255,255,255,.045);
  padding: 0 14px;
}

.status-state-options {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin: 16px 0;
}

.status-state-option {
  min-height: 54px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--r-md);
  color: var(--text);
  background: rgba(255,255,255,.04);
  font-weight: 800;
  cursor: pointer;
}

.status-state-option.active.up { border-color: rgba(53,232,141,.55); background: rgba(53,232,141,.14); }
.status-state-option.active.degraded { border-color: rgba(245,165,36,.55); background: rgba(245,165,36,.14); }
.status-state-option.active.down { border-color: rgba(255,92,115,.55); background: rgba(255,92,115,.14); }

.status-alert-box {
  justify-content: space-between;
  padding: 14px;
  margin-bottom: 16px;
  border: 1px solid rgba(32,255,190,.14);
  border-radius: var(--r-md);
  background: rgba(32,255,190,.055);
}

.status-alert-box span {
  display: block;
  color: var(--muted);
  font-size: 12px;
}

.status-alert-box label {
  color: var(--text);
  font-weight: 800;
}

.status-subservices-card {
  margin-top: 18px;
  padding: 16px;
}

.status-sub-add {
  align-items: stretch;
}

.status-sub-add input {
  flex: 1;
}

.status-sub-list {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.status-sub-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  background: rgba(255,255,255,.035);
}

.btn.btn-mini {
  min-height: 34px;
  padding: 6px 10px;
  font-size: 12px;
}

.btn.btn-mini.danger,
.btn.btn-danger {
  color: #ffb8c4;
  border-color: rgba(255,92,115,.35);
  background: rgba(255,92,115,.09);
}

@media (max-width: 1100px) {
  .status-kpis { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .status-workspace { grid-template-columns: 1fr; }
}

@media (max-width: 720px) {
  #view-status { padding: 16px; }
  .status-hero { align-items: flex-start; flex-direction: column; }
  .form-grid.two,
  .status-state-options { grid-template-columns: 1fr; }
}

/* ============ DESIGN SYSTEM v3 — Unified Components ============ */

/* Page header — consistent for all config/feature tabs */
.page-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 24px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--line);
  flex-wrap: wrap;
}
.ph-left { display: flex; flex-direction: column; gap: 4px; }
.ph-title { font-size: clamp(18px, 2.4vw, 26px); font-weight: 800; letter-spacing: -.03em; color: var(--text); }
.ph-sub { font-size: 13px; color: var(--text-3); max-width: 560px; }
.ph-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; flex-shrink: 0; }
.ph-toggle { flex-shrink: 0; }

/* Unified toolbar — shared across tabs */
.toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 16px;
  flex-wrap: wrap;
}
.toolbar-search-wrap {
  position: relative;
  display: flex;
  align-items: center;
  min-width: 220px;
  flex: 1;
  max-width: 360px;
}
.toolbar-search-icon {
  position: absolute;
  left: 11px;
  pointer-events: none;
  color: var(--text-3);
  flex-shrink: 0;
}
.toolbar-search-wrap input[type="search"] {
  width: 100%;
  min-height: 36px;
  padding: 0 12px 0 34px;
  background: var(--bg-2);
  border: 1px solid var(--line-2);
  border-radius: var(--r-sm);
  color: var(--text);
  font-size: 13px;
  transition: border-color var(--t-fast) var(--ease);
}
.toolbar-search-wrap input[type="search"]:focus {
  outline: none;
  border-color: var(--accent-ring);
}
.toolbar-search-wrap input[type="search"]::placeholder { color: var(--text-3); }

.filter-pills { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }

.toolbar-right { display: flex; align-items: center; gap: 8px; margin-left: auto; flex-shrink: 0; }
.toolbar-left { display: flex; flex-direction: column; gap: 2px; }
.toolbar-heading { font-size: 14px; font-weight: 700; color: var(--text); margin: 0; }
.toolbar-hint { font-size: 12px; color: var(--text-3); }

/* Icon-only button */
.btn-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: var(--r-sm);
  background: transparent;
  border: 1px solid var(--line-2);
  color: var(--text-3);
  cursor: pointer;
  transition: all var(--t-fast) var(--ease);
  flex-shrink: 0;
}
.btn-icon:hover {
  background: var(--accent-soft);
  border-color: var(--accent-ring);
  color: var(--accent);
}

/* Facture card header */
.facture-card-header { margin-bottom: 18px; padding-bottom: 14px; border-bottom: 1px solid var(--line); }
.facture-card-header .facture-title { margin-bottom: 0; }

/* Tickets toolbar overrides for filter-pills layout */
.tickets-toolbar .toolbar-search-wrap { max-width: 300px; }
.tickets-toolbar .filter-pills { flex-wrap: wrap; gap: 6px; }

/* View toggle — SVG icons */
.view-toggle .view-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  padding: 0;
  border-radius: var(--r-xs);
  color: var(--text-3);
  transition: all var(--t-fast) var(--ease);
}
.view-toggle .view-btn.active { background: var(--accent-soft); color: var(--accent); }
.view-toggle .view-btn:hover:not(.active) { color: var(--text); }

/* Webhooks, Panel, Commands — view padding */
#view-webhooks,
#view-ticketpanel,
#view-commands {
  padding: 24px var(--gutter) 40px;
}

/* Tickets toolbar filter-btn sizing */
.tickets-toolbar .filter-btn,
.comm-toolbar .filter-btn {
  min-height: 32px;
  padding: 0 12px;
  font-size: 12.5px;
  border-radius: var(--r-full);
}

/* Comm toolbar */
.comm-toolbar { margin: 12px 0 14px; }
.comm-toolbar .toolbar-search-wrap { max-width: 280px; }

/* Resolved toolbar left/right alignment */
.resolved-toolbar .toolbar-left { flex: 1; }
.resolved-toolbar .toolbar-heading { font-size: 13px; }

@media (max-width: 768px) {
  .page-header { align-items: flex-start; }
  .toolbar-search-wrap { max-width: 100%; }
  .tickets-toolbar .filter-pills { gap: 4px; }
  .ph-actions { width: 100%; }
}

/* ═══════════════════════════════════════════════════════════════════════
   TICKETS — ui-ux-pro-max design system
   Style   : Financial Dashboard + Modern Dark Cinema
   Palette : #020617 bg · #0e1223 card · #334155 border · #94a3b8 muted
   Font    : Plus Jakarta Sans (Friendly SaaS)
   Easing  : cubic-bezier(0.16,1,0.3,1) — spring
   Radius  : 16px card · 10px row · 6px chip
   ═══════════════════════════════════════════════════════════════════════ */

/* ── Tokens ──────────────────────────────────────────────────────────── */
body.view-tickets {
  --ds-bg:        #020617;
  --ds-s0:        #0a0f1e;
  --ds-s1:        #0e1223;
  --ds-s2:        #0f172a;
  --ds-s3:        #1e293b;
  --ds-s4:        #334155;
  --ds-text:      #f8fafc;
  --ds-text2:     #cbd5e1;
  --ds-text3:     #94a3b8;
  --ds-text4:     #64748b;
  --ds-border:    rgba(255,255,255,.08);
  --ds-border2:   #1e293b;
  --ds-border3:   #334155;
  --ds-ease:      cubic-bezier(0.16,1,0.3,1);
  --ds-rc:        16px;
  --ds-rr:        10px;
  --ds-chip:      6px;
  --ds-sh1:       0 1px 2px rgba(0,0,0,.5), 0 4px 16px rgba(0,0,0,.3);
  --ds-sh2:       0 2px 4px rgba(0,0,0,.6), 0 12px 40px rgba(0,0,0,.45);
  --ds-sh3:       0 0px 0px 1px rgba(255,255,255,.06) inset;
}

/* ── Layout ──────────────────────────────────────────────────────────── */
body.view-tickets .content,
body.view-tickets #view-tickets { max-width: none; }
body.view-tickets #view-tickets {
  padding: 20px 28px 60px;
  font-family: 'Plus Jakarta Sans', 'Inter', sans-serif;
}

/* ── Stats bar ───────────────────────────────────────────────────────── */
body.view-tickets .statsbar {
  display: grid;
  grid-template-columns: repeat(5, minmax(140px,1fr));
  gap: 10px;
  margin-bottom: 16px;
  font-family: 'Plus Jakarta Sans', 'Inter', sans-serif;
}
body.view-tickets .stat-card {
  background: var(--ds-s1);
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-rc);
  box-shadow: var(--ds-sh1), var(--ds-sh3);
  min-height: 96px;
  overflow: hidden;
  transition: transform 200ms var(--ds-ease), box-shadow 200ms var(--ds-ease), border-color 200ms var(--ds-ease);
}
body.view-tickets .stat-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--ds-sh2), var(--ds-sh3);
  border-color: var(--ds-border2);
}
body.view-tickets .stat-number {
  font-family: inherit;
  font-size: clamp(26px,2.4vw,40px);
  font-weight: 800;
  letter-spacing: -.04em;
  color: var(--ds-text);
}
body.view-tickets .stat-label {
  font-family: inherit;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--ds-text3);
}

/* ══════════════════════════════════════════════════════════════════════
   TOOLBAR
   ══════════════════════════════════════════════════════════════════════ */
.tk-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 14px;
  background: var(--ds-s1);
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-rc);
  box-shadow: var(--ds-sh1), var(--ds-sh3);
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.tk-bar-left  { display: flex; align-items: center; gap: 8px; flex: 1; min-width: 0; flex-wrap: wrap; }
.tk-bar-right { display: flex; align-items: center; gap: 7px; flex-shrink: 0; flex-wrap: wrap; }

/* Search */
.tk-search-wrap { position: relative; }
.tk-search-ico {
  position: absolute; left: 10px; top: 50%;
  transform: translateY(-50%); color: var(--ds-text4); pointer-events: none;
}
.tk-search-input, #search {
  width: 220px; height: 36px; padding: 0 10px 0 32px;
  background: var(--ds-s2); border: 1px solid var(--ds-border3);
  border-radius: 10px; color: var(--ds-text);
  font-family: 'Plus Jakarta Sans','Inter',sans-serif;
  font-size: 13px; outline: none;
  transition: border-color 160ms var(--ds-ease), box-shadow 160ms var(--ds-ease);
}
.tk-search-input:focus, #search:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(31,221,240,.1);
}
.tk-search-input::placeholder, #search::placeholder { color: var(--ds-text4); }

/* Filter pills */
.tk-pills { display: flex; gap: 3px; flex-wrap: wrap; }
.tk-pills .filter-btn {
  display: inline-flex; align-items: center; gap: 5px;
  height: 32px; padding: 0 12px;
  background: var(--ds-s2); border: 1px solid var(--ds-border);
  border-radius: 10px; color: var(--ds-text3);
  font-family: 'Plus Jakarta Sans','Inter',sans-serif;
  font-size: 12.5px; font-weight: 600;
  cursor: pointer;
  transition: all 160ms var(--ds-ease);
}
.tk-pills .filter-btn:hover {
  background: var(--ds-s3); color: var(--ds-text2);
  border-color: var(--ds-border2);
}
.tk-pills .filter-btn.active {
  background: rgba(31,221,240,.1);
  border-color: rgba(31,221,240,.3);
  color: var(--accent);
}
.tkp-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.tkp-critical { background: #ef4444; box-shadow: 0 0 5px rgba(239,68,68,.7); }
.tkp-high     { background: #f59e0b; box-shadow: 0 0 5px rgba(245,158,11,.6); }

/* Selects */
.tk-ctl-select {
  height: 36px; padding: 0 26px 0 10px;
  background: var(--ds-s2) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2364748b' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 8px center;
  border: 1px solid var(--ds-border3);
  border-radius: 10px; color: var(--ds-text3);
  font-family: 'Plus Jakarta Sans','Inter',sans-serif;
  font-size: 12.5px; font-weight: 500;
  cursor: pointer; appearance: none; outline: none;
  transition: border-color 160ms var(--ds-ease);
}
.tk-ctl-select:focus { border-color: var(--accent); }
.tk-ctl-select option { background: var(--ds-s2); }

/* View toggle */
.tk-view-grp {
  display: flex; gap: 2px; padding: 3px;
  background: var(--ds-s2); border: 1px solid var(--ds-border);
  border-radius: 10px;
}
.tk-view-grp .view-btn {
  display: grid; place-items: center; width: 30px; height: 28px;
  border-radius: 7px; color: var(--ds-text4);
  transition: all 160ms var(--ds-ease);
}
.tk-view-grp .view-btn:hover { background: var(--ds-s3); color: var(--ds-text2); }
.tk-view-grp .view-btn.active { background: rgba(31,221,240,.12); color: var(--accent); }

/* Icon button */
.tk-icon-btn {
  display: grid; place-items: center; width: 36px; height: 36px;
  background: var(--ds-s2); border: 1px solid var(--ds-border3);
  border-radius: 10px; color: var(--ds-text3);
  transition: all 160ms var(--ds-ease);
}
.tk-icon-btn:hover { background: var(--ds-s3); color: var(--ds-text); border-color: var(--ds-border2); }

/* Primary button */
.tk-primary-btn {
  display: inline-flex; align-items: center; gap: 6px;
  height: 36px; padding: 0 14px;
  background: var(--accent); border-radius: 10px;
  color: #03141a; font-family: 'Plus Jakarta Sans','Inter',sans-serif;
  font-size: 12.5px; font-weight: 700; letter-spacing: -.01em;
  transition: all 160ms var(--ds-ease);
}
.tk-primary-btn:hover {
  background: var(--accent-2); transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(31,221,240,.28);
}

/* ══════════════════════════════════════════════════════════════════════
   GRID + SECTIONS
   ══════════════════════════════════════════════════════════════════════ */
#tickets-grid { display: grid; gap: 20px; }

.tk-section { display: grid; gap: 4px; }

.tk-section-hdr {
  display: flex; align-items: center; gap: 9px;
  padding: 0 2px 6px;
}
.tk-section-hdr::after {
  content: ''; flex: 1; height: 1px; background: var(--ds-border);
}
.tk-section-dot {
  width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0;
  background: var(--ds-text4);
}
.section-critical .tk-section-dot { background: #ef4444; box-shadow: 0 0 7px rgba(239,68,68,.65); }
.section-high     .tk-section-dot { background: #f59e0b; box-shadow: 0 0 7px rgba(245,158,11,.55); }
.section-medium   .tk-section-dot { background: #eab308; }
.section-normal   .tk-section-dot { background: #22c55e; }
.section-all      .tk-section-dot { background: var(--accent); box-shadow: 0 0 7px rgba(31,221,240,.55); }

.tk-section-label {
  font-family: 'Plus Jakarta Sans','Inter',sans-serif;
  font-size: 11px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: var(--ds-text4);
}
.section-critical .tk-section-label { color: #fca5a5; }
.section-high     .tk-section-label { color: #fcd34d; }
.section-all      .tk-section-label { color: var(--accent); }

.tk-section-count {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 22px; height: 18px; padding: 0 7px;
  background: rgba(255,255,255,.05); border: 1px solid var(--ds-border);
  border-radius: 999px; color: var(--ds-text4);
  font-family: 'Plus Jakarta Sans','Inter',sans-serif;
  font-size: 11px; font-weight: 700;
}
.section-critical .tk-section-count { background: rgba(239,68,68,.1); border-color: rgba(239,68,68,.22); color: #fca5a5; }
.section-high     .tk-section-count { background: rgba(245,158,11,.1); border-color: rgba(245,158,11,.22); color: #fcd34d; }
.section-all      .tk-section-count { background: rgba(31,221,240,.08); border-color: rgba(31,221,240,.2); color: var(--accent); }

.tk-cards { display: grid; gap: 3px; }
#tickets-grid:not(.list-view) .tk-cards {
  grid-template-columns: repeat(auto-fill, minmax(380px,1fr));
  gap: 12px;
}

/* ══════════════════════════════════════════════════════════════════════
   SHARED — chips · status pills · SLA
   ══════════════════════════════════════════════════════════════════════ */
.tk-chip {
  display: inline-flex; align-items: center;
  height: 19px; padding: 0 7px; border-radius: var(--ds-chip);
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.07);
  color: var(--ds-text3);
  font-family: 'Plus Jakarta Sans','Inter',sans-serif;
  font-size: 11.5px; font-weight: 500; white-space: nowrap;
}
.tk-chip-email { font-family: 'JetBrains Mono',monospace; font-size: 10.5px; color: var(--ds-text2); }
.tk-chip-sub   { background: rgba(31,221,240,.07); border-color: rgba(31,221,240,.16); color: var(--accent); }
.tk-chip-dev,
.tk-chip-dev.dev-sent,
.tk-chip-dev.dev-ack,
.tk-chip-dev.dev-working { background: rgba(96,165,250,.1); border-color: rgba(96,165,250,.2); color: #93c5fd; }
.tk-chip-dev.dev-resolved { background: rgba(34,197,94,.1); border-color: rgba(34,197,94,.2); color: #86efac; }
.tk-chip-merge { background: rgba(168,85,247,.1); border-color: rgba(168,85,247,.2); color: #d8b4fe; }

.tk-status-pill {
  display: inline-flex; align-items: center;
  height: 21px; padding: 0 9px; border-radius: 999px;
  font-family: 'Plus Jakarta Sans','Inter',sans-serif;
  font-size: 11px; font-weight: 700; letter-spacing: .01em; white-space: nowrap;
}
.tk-status-pill.is-critical { background: rgba(239,68,68,.14); border: 1px solid rgba(239,68,68,.24); color: #fca5a5; }
.tk-status-pill.is-high     { background: rgba(245,158,11,.14); border: 1px solid rgba(245,158,11,.24); color: #fcd34d; }
.tk-status-pill.is-medium   { background: rgba(234,179,8,.12);  border: 1px solid rgba(234,179,8,.2);   color: #fde68a; }
.tk-status-pill.is-normal   { background: rgba(34,197,94,.11);  border: 1px solid rgba(34,197,94,.2);   color: #86efac; }
.tk-status-pill.is-dev      { background: rgba(96,165,250,.12); border: 1px solid rgba(96,165,250,.22); color: #93c5fd; }

.tk-sla-wrap {
  height: 2px; margin-top: 7px; border-radius: 2px;
  background: rgba(255,255,255,.05); overflow: hidden;
}
.tk-sla-fill { height: 100%; border-radius: 2px; transition: width .5s var(--ds-ease); }
.tk-sla-fill.normal   { background: linear-gradient(90deg,#22c55e,#2dd4bf); }
.tk-sla-fill.medium   { background: linear-gradient(90deg,#eab308,#facc15); }
.tk-sla-fill.high     { background: linear-gradient(90deg,#f59e0b,#f97316); }
.tk-sla-fill.critical { background: linear-gradient(90deg,#ef4444,#fb7185); }

/* ══════════════════════════════════════════════════════════════════════
   LIST ROW
   ══════════════════════════════════════════════════════════════════════ */
.tk-row {
  --tka: #2dd4bf;
  position: relative;
  display: grid;
  grid-template-columns: 3px 46px minmax(0,1fr) 150px auto;
  align-items: center;
  gap: 0;
  min-height: 70px;
  border: 1px solid transparent;
  border-radius: var(--ds-rr);
  background: transparent;
  cursor: pointer; overflow: hidden;
  transition: background 160ms var(--ds-ease), border-color 160ms var(--ds-ease), box-shadow 200ms var(--ds-ease);
}
.tk-row.urgency-critical { --tka: #ef4444; }
.tk-row.urgency-high     { --tka: #f59e0b; }
.tk-row.urgency-medium   { --tka: #eab308; }
.tk-row.urgency-normal   { --tka: #22c55e; }
.tk-row:hover {
  background: var(--ds-s1);
  border-color: var(--ds-border2);
  box-shadow: var(--ds-sh1);
}
.tk-row:hover .tk-row-actions { opacity: 1; pointer-events: auto; }
.tk-row:hover .tk-meta-col    { opacity: 0; pointer-events: none; }

/* Priority accent bar */
.tk-prio-bar {
  width: 3px; height: 100%;
  background: var(--tka); opacity: .5;
  border-radius: 3px 0 0 3px;
  transition: opacity 160ms var(--ds-ease);
}
.tk-row:hover .tk-prio-bar { opacity: 1; }

/* Category icon */
.tk-cat-icon {
  display: grid; place-items: center;
  width: 36px; height: 36px; border-radius: 12px;
  margin: 0 10px 0 12px;
  background: color-mix(in srgb, var(--tka) 10%, #0e1223);
  color: var(--tka);
  border: 1px solid color-mix(in srgb, var(--tka) 16%, rgba(255,255,255,.06));
  flex-shrink: 0;
  transition: transform 160ms var(--ds-ease), box-shadow 160ms var(--ds-ease);
}
.tk-row:hover .tk-cat-icon {
  transform: scale(1.07);
  box-shadow: 0 4px 14px color-mix(in srgb, var(--tka) 24%, transparent);
}
.tk-cat-icon.cat-billing { --tka: #818cf8; }
.tk-cat-icon.cat-partner { --tka: #f59e0b; }
.tk-cat-icon.cat-custom  { --tka: #a78bfa; }
.tk-cat-icon.cat-tech    { --tka: #22d3ee; }

/* Body */
.tk-body {
  min-width: 0; padding: 12px 14px 12px 0;
  display: flex; flex-direction: column; gap: 5px;
}
.tk-title-ln {
  display: flex; align-items: center; gap: 7px;
  flex-wrap: wrap; min-width: 0;
}
.tk-id {
  font-family: 'Plus Jakarta Sans','Inter',sans-serif;
  font-size: 13.5px; font-weight: 700; color: var(--ds-text);
  letter-spacing: -.02em;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  max-width: 260px;
}
.tk-detail-ln { display: flex; align-items: center; gap: 5px; flex-wrap: wrap; }

/* Meta column */
.tk-meta-col {
  display: flex; flex-direction: column; align-items: flex-end;
  gap: 3px; padding: 0 14px;
  transition: opacity 160ms var(--ds-ease);
}
.tk-age {
  font-family: 'Plus Jakarta Sans','Inter',sans-serif;
  font-size: 12px; font-weight: 700; color: var(--ds-text2);
  font-variant-numeric: tabular-nums; white-space: nowrap;
}
.tk-opener {
  font-family: 'Plus Jakarta Sans','Inter',sans-serif;
  font-size: 11px; color: var(--ds-text3);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  max-width: 130px; text-align: right;
}

/* Row actions — revealed on hover */
.tk-row-actions {
  display: flex; align-items: center; gap: 6px; padding: 0 14px 0 0;
  opacity: 0; pointer-events: none;
  transition: opacity 160ms var(--ds-ease);
}
.tk-dev-sel {
  height: 30px; padding: 0 22px 0 9px;
  background: var(--ds-s2) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2364748b' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 6px center;
  border: 1px solid var(--ds-border3); border-radius: 8px;
  color: var(--ds-text3);
  font-family: 'Plus Jakarta Sans','Inter',sans-serif; font-size: 11.5px; font-weight: 600;
  cursor: pointer; appearance: none; outline: none;
  transition: border-color 160ms var(--ds-ease);
}
.tk-dev-sel:focus { border-color: var(--accent); }

.tk-act-btn {
  display: inline-flex; align-items: center; gap: 5px;
  height: 30px; padding: 0 11px;
  background: var(--ds-s2); border: 1px solid var(--ds-border3);
  border-radius: 8px; color: var(--ds-text3);
  font-family: 'Plus Jakarta Sans','Inter',sans-serif;
  font-size: 11.5px; font-weight: 600; white-space: nowrap;
  transition: all 160ms var(--ds-ease);
}
.tk-act-btn:hover { background: var(--ds-s3); color: var(--ds-text); border-color: var(--ds-s4); }
.tk-act-btn.is-dev:hover   { background: rgba(96,165,250,.14); color: #93c5fd; border-color: rgba(96,165,250,.3); }
.tk-act-btn.is-close:hover { background: rgba(239,68,68,.13);  color: #fca5a5; border-color: rgba(239,68,68,.26); }

/* ══════════════════════════════════════════════════════════════════════
   GRID CARD
   ══════════════════════════════════════════════════════════════════════ */
.tk-card {
  --tka: #2dd4bf;
  position: relative;
  display: flex; flex-direction: column; gap: 10px;
  padding: 16px;
  background: var(--ds-s1);
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-rc);
  box-shadow: var(--ds-sh1), var(--ds-sh3);
  cursor: pointer; overflow: hidden;
  transition: border-color 200ms var(--ds-ease), transform 200ms var(--ds-ease), box-shadow 200ms var(--ds-ease);
}
/* Top accent line — from skill: gradient top border */
.tk-card::before {
  content: ''; position: absolute; inset: 0 0 auto 0;
  height: 2px; background: var(--tka);
  transition: height 200ms var(--ds-ease), opacity 200ms var(--ds-ease);
  opacity: .7;
}
.tk-card.urgency-critical { --tka: #ef4444; }
.tk-card.urgency-high     { --tka: #f59e0b; }
.tk-card.urgency-medium   { --tka: #eab308; }
.tk-card.urgency-normal   { --tka: #22c55e; }
.tk-card:hover {
  border-color: color-mix(in srgb, var(--tka) 30%, var(--ds-border2));
  box-shadow: var(--ds-sh2), 0 0 0 1px color-mix(in srgb, var(--tka) 12%, transparent);
  transform: translateY(-3px) scale(1.004);
}
.tk-card:hover::before { height: 3px; opacity: 1; }

/* Card — top row */
.tkc-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.tkc-icon {
  display: grid; place-items: center;
  width: 36px; height: 36px; border-radius: 12px;
  background: color-mix(in srgb, var(--tka) 10%, #0e1223);
  color: var(--tka);
  border: 1px solid color-mix(in srgb, var(--tka) 16%, rgba(255,255,255,.06));
}
.tkc-icon.cat-billing { --tka: #818cf8; }
.tkc-icon.cat-partner { --tka: #f59e0b; }
.tkc-icon.cat-custom  { --tka: #a78bfa; }
.tkc-icon.cat-tech    { --tka: #22d3ee; }

.tkc-title {
  margin: 0;
  font-family: 'Plus Jakarta Sans','Inter',sans-serif;
  font-size: 14px; font-weight: 800; color: var(--ds-text);
  letter-spacing: -.02em;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.tkc-email {
  font-family: 'JetBrains Mono',monospace;
  font-size: 11px; color: var(--ds-text2);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.tkc-chips { display: flex; flex-wrap: wrap; gap: 4px; }

/* Card SLA */
.tkc-sla {
  height: 3px; border-radius: 3px;
  background: rgba(255,255,255,.05); overflow: hidden;
}

/* Card footer */
.tkc-footer {
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px; padding-top: 8px;
  border-top: 1px solid var(--ds-border); margin-top: auto;
}
.tkc-age {
  font-family: 'Plus Jakarta Sans','Inter',sans-serif;
  font-size: 12px; font-weight: 700; color: var(--ds-text2);
  font-variant-numeric: tabular-nums;
}
.tkc-actions { display: flex; align-items: center; gap: 5px; }
.tkc-act-btn {
  display: grid; place-items: center;
  width: 29px; height: 29px;
  background: var(--ds-s2); border: 1px solid var(--ds-border3);
  border-radius: 8px; color: var(--ds-text3);
  transition: all 160ms var(--ds-ease);
}
.tkc-act-btn:hover { background: var(--ds-s3); color: var(--ds-text); }
.tkc-act-btn.is-dev:hover   { background: rgba(96,165,250,.14); color: #93c5fd; border-color: rgba(96,165,250,.3); }
.tkc-act-btn.is-close:hover { background: rgba(239,68,68,.13);  color: #fca5a5; border-color: rgba(239,68,68,.26); }
.tkc-dev-sel {
  height: 29px; padding: 0 20px 0 8px;
  background: var(--ds-s2) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2364748b' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 5px center;
  border: 1px solid var(--ds-border3); border-radius: 8px;
  color: var(--ds-text3);
  font-family: 'Plus Jakarta Sans','Inter',sans-serif; font-size: 11px;
  cursor: pointer; appearance: none; outline: none;
}

/* ══════════════════════════════════════════════════════════════════════
   EMPTY STATE
   ══════════════════════════════════════════════════════════════════════ */
#empty-state {
  flex-direction: column; align-items: center; justify-content: center;
  gap: 8px; padding: 80px 40px; text-align: center;
}
.tk-empty-icon {
  display: grid; place-items: center;
  width: 60px; height: 60px; border-radius: var(--ds-rc);
  background: var(--ds-s1); border: 1px solid var(--ds-border2);
  color: var(--ds-text4); margin-bottom: 8px;
}
.tk-empty-title {
  font-family: 'Plus Jakarta Sans','Inter',sans-serif;
  font-size: 15px; font-weight: 700; color: var(--ds-text2); margin: 0;
}
.tk-empty-sub {
  font-family: 'Plus Jakarta Sans','Inter',sans-serif;
  font-size: 12.5px; color: var(--ds-text3); margin: 0;
}

/* ══════════════════════════════════════════════════════════════════════
   SKELETON (loading)
   ══════════════════════════════════════════════════════════════════════ */
.tk-section .ticket-card.ticket-skeleton {
  height: 70px; border-radius: var(--ds-rr);
  background: var(--ds-s1); border: 1px solid var(--ds-border);
  animation: pulse 1.4s ease infinite;
}

/* ══════════════════════════════════════════════════════════════════════
   ANIMATION — spring in (Modern Dark Cinema spec)
   ══════════════════════════════════════════════════════════════════════ */
.tk-row, .tk-card {
  animation: tk-spring 380ms var(--ds-ease) both;
}
@keyframes tk-spring {
  from { opacity: 0; transform: translateY(8px) scale(0.985); }
  to   { opacity: 1; transform: none; }
}

/* ══════════════════════════════════════════════════════════════════════
   APERÇU (Vue d'ensemble commissions)
   ══════════════════════════════════════════════════════════════════════ */
/* ── Overview wrapper ────────────────────────────────────────────────────── */
.ovr-wrap {
  padding: 32px 36px 48px;
  max-width: 1400px;
  margin: 0 auto;
  display: flex; flex-direction: column; gap: 24px;
}
.ovr-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 16px;
}
.ovr-greeting {
  font-size: 26px; font-weight: 800; color: var(--text-1); letter-spacing: -.02em;
}
.ovr-header-meta { margin-top: 6px; }
.ovr-unpaid-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; font-weight: 600;
  background: rgba(245,158,11,.12); color: #f59e0b;
  border: 1px solid rgba(245,158,11,.25);
  border-radius: 20px; padding: 3px 10px;
}
.ovr-header-right { display: flex; gap: 8px; flex-shrink: 0; }
.ovr-nav-btn {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12.5px; font-weight: 600; color: var(--text-2);
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: 8px; padding: 7px 13px; cursor: pointer;
  transition: color .15s, border-color .15s, background .15s;
}
.ovr-nav-btn:hover { color: var(--text-1); border-color: rgba(255,255,255,.2); background: var(--bg-3); }
.rwov-layout {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 20px;
  align-items: start;
}
.rwov-main { display: flex; flex-direction: column; gap: 16px; }
.rwov-section-title {
  display: flex; align-items: center; gap: 7px;
  font-size: 12px; font-weight: 700; letter-spacing: .07em;
  text-transform: uppercase; color: var(--text-3);
  margin-bottom: 12px;
}

/* KPI row */
.rwov-kpi-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.rwov-kpi-card {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: 14px; padding: 18px 18px 14px;
  display: flex; flex-direction: column; gap: 4px;
  transition: border-color .2s;
}
.rwov-kpi-card:hover { border-color: rgba(255,255,255,.18); }
.rwov-kpi-label { font-size: 11px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: var(--text-3); }
.rwov-kpi-amount { font-size: 22px; font-weight: 800; color: var(--text-1); font-variant-numeric: tabular-nums; margin: 4px 0 2px; }
.rwov-kpi-meta { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; min-height: 18px; }
.rwov-kpi-conv { font-size: 12px; color: var(--text-3); }
.rwov-kpi-sub  { font-size: 11.5px; color: #34d399; }
.rwov-trend { display: inline-flex; align-items: center; gap: 2px; font-size: 11.5px; font-weight: 700; border-radius: 5px; padding: 1px 5px; }
.rwov-trend.up   { color: #34d399; background: rgba(52,211,153,.12); }
.rwov-trend.down { color: #f87171; background: rgba(248,113,113,.12); }
.rwov-kpi-bar { height: 3px; background: rgba(255,255,255,.07); border-radius: 2px; margin-top: 10px; overflow: hidden; }
.rwov-kpi-bar-fill { height: 100%; border-radius: 2px; transition: width .6s var(--ease); }

/* Chart card */
.rwov-chart-card {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: 14px; padding: 20px;
}
.rwov-bars {
  display: flex; align-items: stretch; gap: 10px;
  height: 160px;
}
.rwov-bar-col {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; gap: 4px; height: 100%;
  cursor: default;
}
.rwov-bar-val {
  font-size: 10px; color: var(--text-3); font-variant-numeric: tabular-nums;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  max-width: 100%; text-align: center; min-height: 14px;
}
.rwov-bar-track {
  flex: 1; width: 100%; display: flex; align-items: flex-end;
  border-radius: 6px 6px 0 0; overflow: hidden;
  background: rgba(255,255,255,.04);
}
.rwov-bar-fill {
  width: 100%; background: rgba(99,102,241,.4);
  border-radius: 6px 6px 0 0;
  transition: height .5s cubic-bezier(.4,0,.2,1), background .15s;
  min-height: 4px;
}
.rwov-bar-col.current .rwov-bar-fill { background: #6366f1; }
.rwov-bar-col:hover .rwov-bar-fill { background: #818cf8; }
.rwov-bar-col.current .rwov-bar-val { color: var(--text-2); }
.rwov-bar-label {
  font-size: 11px; color: var(--text-3); text-align: center;
  white-space: nowrap;
}
.rwov-bar-col.current .rwov-bar-label { color: var(--text-2); font-weight: 600; }
.rwov-chart-totals span { text-align: center; flex: 1; }

/* Bottom stat cards */
.rwov-bottom-row { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; }
.rwov-stat-card {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: 14px; padding: 16px;
  display: flex; flex-direction: column; gap: 3px;
}
.rwov-stat-icon { color: var(--text-3); margin-bottom: 6px; }
.rwov-stat-label { font-size: 10.5px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: var(--text-3); }
.rwov-stat-val { font-size: 17px; font-weight: 800; color: var(--text-1); font-variant-numeric: tabular-nums; margin: 3px 0 1px; }
.rwov-stat-sub { font-size: 11px; color: var(--text-3); }

/* Breakdown cards (plan + codes) */
.rwov-breakdown-card { gap: 6px; }
.rwov-breakdown-list { display: flex; flex-direction: column; gap: 6px; margin-top: 4px; width: 100%; }
.rwov-breakdown-row {
  display: grid;
  grid-template-columns: 8px 90px 1fr 64px 44px;
  align-items: center; gap: 6px;
}
.rwov-breakdown-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.rwov-breakdown-name { font-size: 11.5px; font-weight: 700; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.rwov-breakdown-bar-wrap { height: 4px; background: rgba(255,255,255,.08); border-radius: 99px; overflow: hidden; }
.rwov-breakdown-bar { height: 100%; border-radius: 99px; display: block; transition: width .4s; }
.rwov-breakdown-val { font-size: 11px; font-weight: 700; color: var(--text-1); text-align: right; font-variant-numeric: tabular-nums; white-space: nowrap; }
.rwov-breakdown-sub { font-size: 10px; color: var(--text-3); text-align: right; white-space: nowrap; }

/* Feed column */
.rwov-feed-col {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: 14px; padding: 18px;
  position: sticky; top: 80px;
  max-height: calc(100vh - 120px); overflow: hidden;
  display: flex; flex-direction: column;
}
.rwov-feed {
  overflow-y: auto; flex: 1;
  display: flex; flex-direction: column; gap: 2px;
  scrollbar-width: thin;
}
.rwov-feed-empty { font-size: 13px; color: var(--text-3); padding: 12px 0; text-align: center; }
.rwov-feed-item {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 9px 6px; border-radius: 8px;
  transition: background .12s;
}
.rwov-feed-item:hover { background: rgba(255,255,255,.04); }
.rwov-feed-dot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; margin-top: 5px; }
.rwov-feed-logo { width: 18px; height: 18px; object-fit: contain; flex-shrink: 0; margin-top: 2px; }
.rwov-feed-body { flex: 1; min-width: 0; }
.rwov-feed-top { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.rwov-feed-client { font-size: 12.5px; font-weight: 600; color: var(--text-1); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex: 1; min-width: 0; }
.rwov-feed-amount { font-size: 12.5px; font-weight: 700; color: #34d399; flex-shrink: 0; font-variant-numeric: tabular-nums; }
.rwov-feed-bottom { display: flex; align-items: center; gap: 5px; flex-wrap: wrap; margin-top: 2px; }
.rwov-feed-plan { font-size: 10.5px; color: var(--text-3); }
.rwov-feed-code { font-size: 10px; background: rgba(255,255,255,.08); border-radius: 4px; padding: 1px 5px; color: var(--text-2); font-weight: 600; }
.rwov-feed-when { font-size: 10.5px; color: var(--text-3); margin-left: auto; flex-shrink: 0; }
.rwov-feed-type { font-size: 9.5px; font-weight: 700; border-radius: 4px; padding: 1px 5px; letter-spacing: .03em; }
.rwov-feed-type.new     { background: rgba(52,211,153,.15); color: #34d399; }
.rwov-feed-type.renewal { background: rgba(99,102,241,.15); color: #818cf8; }

/* Mail signal items */
.rwov-feed-mail { opacity: .75; }
.rwov-feed-mail:hover { opacity: 1; }
.rwov-feed-mail-icon {
  width: 24px; height: 24px; border-radius: 6px;
  background: rgba(245,158,11,.12); color: #f59e0b;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.rwov-feed-mail-label { font-size: 12px; font-weight: 600; color: var(--text-2); }
.rwov-feed-mail-time  { font-size: 12px; font-weight: 700; color: #f59e0b; margin-left: auto; flex-shrink: 0; font-variant-numeric: tabular-nums; }

/* ══════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════════════════ */
@media (max-width: 1200px) {
  .tk-row { grid-template-columns: 3px 46px minmax(0,1fr) auto; }
  .tk-meta-col { display: none !important; }
  .tk-row:hover .tk-row-actions { opacity: 1; pointer-events: auto; }
}
@media (max-width: 960px) {
  body.view-tickets .statsbar { grid-template-columns: repeat(3, 1fr); }
  .tk-bar { flex-direction: column; align-items: stretch; }
  .tk-bar-left, .tk-bar-right { flex-wrap: wrap; }
  #tickets-grid:not(.list-view) .tk-cards { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  body.view-tickets #view-tickets { padding: 14px 14px 48px; }
  body.view-tickets .statsbar { grid-template-columns: 1fr 1fr; }
  .tk-row { grid-template-columns: 3px 36px minmax(0,1fr); }
  .tk-row-actions { display: none; }
  #tickets-grid:not(.list-view) .tk-cards { grid-template-columns: 1fr; }
  .tk-search-input, #search { width: 100%; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   NEURAL MAP — version premium
   ═══════════════════════════════════════════════════════════════════════════ */

.nm-tab.active {
  display: flex;
  flex-direction: column;
  height: calc(100vh - var(--topbar-h));
  overflow: hidden;
}

.nm-wrap {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  background: #040810;
}

/* ── Header ─────────────────────────────────────────────────────────────── */
.nm-header {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 14px 26px 12px;
  border-bottom: 1px solid rgba(0,200,190,0.08);
  background: linear-gradient(180deg, #0a1428 0%, #07101e 100%);
  position: relative;
  z-index: 2;
}

.nm-header::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(0,180,200,0.03) 0%, transparent 60%);
  pointer-events: none;
}

.nm-header-left { display: flex; align-items: center; gap: 14px; }

.nm-badge-number {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 1.5px solid rgba(0,210,200,0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 800;
  color: #00d8c8;
  flex-shrink: 0;
  box-shadow: 0 0 12px rgba(0,210,200,0.22), inset 0 0 8px rgba(0,210,200,0.08);
}

.nm-title {
  font-size: 16px;
  font-weight: 700;
  color: #eaf0ff;
  letter-spacing: -0.2px;
  line-height: 1.2;
}

.nm-subtitle {
  font-size: 11px;
  color: rgba(160,180,215,0.65);
  margin-top: 2px;
  letter-spacing: 0.1px;
}

/* ── KPI strip ──────────────────────────────────────────────────────────── */
.nm-kpi-row { display: flex; gap: 8px; flex-shrink: 0; }

.nm-kpi {
  background: rgba(255,255,255,0.035);
  border: 1px solid rgba(0,200,190,0.10);
  border-radius: 10px;
  padding: 7px 14px;
  text-align: center;
  min-width: 84px;
  transition: border-color 0.25s ease, background 0.25s ease;
  position: relative;
  overflow: hidden;
}

.nm-kpi::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(0,210,200,0.3), transparent);
  opacity: 0;
  transition: opacity 0.25s ease;
}

.nm-kpi:hover { border-color: rgba(0,210,200,0.25); background: rgba(0,200,190,0.06); }
.nm-kpi:hover::before { opacity: 1; }

.nm-kpi-val {
  font-size: 13px;
  font-weight: 700;
  color: #ecf2ff;
  white-space: nowrap;
  letter-spacing: -0.2px;
}

.nm-kpi-lbl {
  font-size: 9.5px;
  color: rgba(140,165,210,0.7);
  text-transform: uppercase;
  letter-spacing: 0.45px;
  margin-top: 2px;
  white-space: nowrap;
}

/* ── Canvas zone ────────────────────────────────────────────────────────── */
.nm-canvas-wrap {
  flex: 1;
  position: relative;
  overflow: hidden;
  min-height: 0;
}

#nm-canvas {
  position: absolute;
  inset: 0;
  display: block;
}

/* ── HTML labels ────────────────────────────────────────────────────────── */
.nm-labels { position: absolute; inset: 0; pointer-events: none; }

.nm-label {
  position: absolute;
  transform: translate(-50%, calc(-100% - 16px));
  background: rgba(4,9,22,0.90);
  border: 1px solid rgba(0,210,200,0.28);
  border-radius: 9px;
  padding: 7px 12px;
  pointer-events: none;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  white-space: nowrap;
  box-shadow:
    0 0 20px rgba(0,210,200,0.10),
    0 4px 16px rgba(0,0,0,0.5),
    inset 0 1px 0 rgba(255,255,255,0.04);
  animation: nm-label-in 0.5s cubic-bezier(.22,1,.36,1) both;
}

.nm-label-star {
  border-color: rgba(0,225,210,0.45);
  box-shadow:
    0 0 28px rgba(0,225,210,0.18),
    0 4px 20px rgba(0,0,0,0.55),
    inset 0 1px 0 rgba(255,255,255,0.06);
}

.nm-label::after {
  content: '';
  position: absolute;
  bottom: -5px;
  left: 50%;
  transform: translateX(-50%);
  width: 5px;
  height: 5px;
  background: rgba(0,210,200,0.45);
  border-radius: 50%;
  box-shadow: 0 0 6px rgba(0,210,200,0.6);
}

.nm-label-day {
  font-size: 10.5px;
  color: rgba(190,210,240,0.82);
  font-weight: 500;
  letter-spacing: 0.2px;
}

.nm-label-score {
  font-size: 16px;
  font-weight: 800;
  color: #00e8d8;
  margin-top: 1px;
  letter-spacing: -0.5px;
  text-shadow: 0 0 10px rgba(0,232,216,0.4);
}

.nm-label-amt {
  font-size: 10px;
  color: rgba(130,200,180,0.7);
  margin-top: 1px;
}

@keyframes nm-label-in {
  from { opacity: 0; transform: translate(-50%, calc(-100% - 24px)); filter: blur(3px); }
  to   { opacity: 1; transform: translate(-50%, calc(-100% - 16px)); filter: blur(0); }
}

/* ─── RMSM — Résumé Mensuel Premium ──────────────────────────────────── */

.rmsm-card {
  background: var(--bg-1);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 20px;
  box-shadow: 0 2px 40px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.04);
  overflow: hidden;
  animation: rmsm-in .5s cubic-bezier(.22,1,.36,1) both;
}
@keyframes rmsm-in {
  from { opacity:0; transform:translateY(10px); }
  to   { opacity:1; transform:translateY(0); }
}

/* ── Header ── */
.rmsm-hdr {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 20px 22px 0;
}
.rmsm-hdr-l {
  display: flex;
  align-items: center;
  gap: 12px;
}
.rmsm-icon-box {
  width: 38px; height: 38px;
  border-radius: 12px;
  background: rgba(31,221,240,.07);
  border: 1px solid rgba(31,221,240,.16);
  display: flex; align-items: center; justify-content: center;
  color: #1fddf0;
  flex-shrink: 0;
}
.rmsm-title {
  font-size: 15px; font-weight: 800;
  color: var(--text); letter-spacing: -.01em;
}
.rmsm-sub {
  font-size: 12px; color: var(--text-3); margin-top: 2px;
}

/* ── KPI pill ── */
.rmsm-kpi-pill {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px 10px 16px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(31,221,240,.12);
  border-radius: 14px;
  min-width: 210px;
  transition: border-color .25s, box-shadow .25s;
  flex-shrink: 0;
}
.rmsm-kpi-pill:hover {
  border-color: rgba(31,221,240,.24);
  box-shadow: 0 0 22px rgba(31,221,240,.08);
}
.rmsm-kpi-body { flex: 1; min-width: 0; }
.rmsm-kpi-lbl {
  font-size: 10px; text-transform: uppercase;
  letter-spacing: .06em; color: var(--text-3); font-weight: 600;
}
.rmsm-kpi-val {
  font-size: 19px; font-weight: 800;
  line-height: 1.2; font-variant-numeric: tabular-nums;
  background: linear-gradient(90deg,#1fddf0,#0ff29e);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.rmsm-kpi-meta {
  font-size: 10.5px; color: var(--text-3); margin-top: 2px;
}
.rmsm-spark {
  width: 86px; height: 42px; flex-shrink: 0; display: block;
}

/* ── Chart ── */
.rmsm-chart-outer {
  position: relative;
  margin: 14px 0 0;
  padding: 0 22px;
}
.rmsm-chart-outer canvas {
  display: block; width: 100%;
}
.rmsm-tip {
  position: absolute;
  background: rgba(17,17,17,.97);
  border: 1px solid rgba(31,221,240,.24);
  border-radius: 10px;
  padding: 8px 12px;
  pointer-events: none;
  opacity: 0;
  transition: opacity .15s ease;
  display: flex; flex-direction: column; gap: 2px;
  backdrop-filter: blur(14px);
  white-space: nowrap;
  z-index: 10;
}
.rmsm-tip-mo {
  font-size: 10.5px; color: var(--text-3); text-transform: capitalize;
}
.rmsm-tip-v {
  font-size: 15px; font-weight: 700; color: #1fddf0;
}

/* ── Table ── */
.rmsm-tbl-outer {
  margin: 10px 0 0;
  overflow-y: auto;
  max-height: 290px;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.07) transparent;
}
.rmsm-tbl-outer::-webkit-scrollbar { width: 4px; }
.rmsm-tbl-outer::-webkit-scrollbar-thumb { background: rgba(255,255,255,.09); border-radius:2px; }

.rmsm-tbl {
  width: 100%; border-collapse: collapse; font-size: 12.5px;
}
.rmsm-tbl thead tr {
  position: sticky; top: 0; z-index: 2;
  background: var(--bg-1);
}
.rmsm-tbl th {
  padding: 8px 10px;
  text-align: right;
  font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .05em;
  color: var(--text-3);
  border-bottom: 1px solid rgba(255,255,255,.06);
  white-space: nowrap;
}
.rmsm-th-mo { text-align: left !important; padding-left: 22px !important; }
.rmsm-th-r  { text-align: right !important; }

.rmsm-row {
  border-bottom: 1px solid rgba(255,255,255,.033);
  transition: background .13s;
  animation: rmsm-row-in .45s cubic-bezier(.22,1,.36,1) both;
  animation-delay: calc(var(--i, 0) * 22ms + 180ms);
}
@keyframes rmsm-row-in {
  from { opacity:0; transform:translateX(-5px); }
  to   { opacity:1; transform:translateX(0); }
}
.rmsm-row:hover { background: rgba(31,221,240,.038); }
.rmsm-row:last-child { border-bottom: none; }
.rmsm-cur {
  background: rgba(37,149,190,.045) !important;
  box-shadow: inset 3px 0 0 rgba(37,149,190,.7);
}

.rmsm-tbl td {
  padding: 7px 10px;
  text-align: right;
  color: var(--text-2);
  font-variant-numeric: tabular-nums;
}

/* Month cell */
.rmsm-td-mo { text-align: left !important; padding-left: 22px !important; }
.rmsm-td-mo-in { display: flex; align-items: center; gap: 7px; }
.rmsm-mo-nm { font-weight: 600; color: var(--text); font-size: 12.5px; }
.rmsm-now {
  font-size: 9.5px; font-weight: 700;
  padding: 2px 6px; border-radius: 20px;
  background: rgba(37,149,190,.14);
  color: #2596be;
  border: 1px solid rgba(37,149,190,.32);
  text-transform: uppercase; letter-spacing: .04em; flex-shrink: 0;
}

/* Mini bars */
.rmsm-td-bar { white-space: nowrap; }
.rmsm-bar-wrap {
  display: inline-block;
  width: 48px; height: 5px;
  background: rgba(255,255,255,.06);
  border-radius: 3px;
  vertical-align: middle;
  margin-right: 5px;
  overflow: hidden;
}
.rmsm-bar {
  display: block; height: 100%; border-radius: 3px;
  transition: width .7s cubic-bezier(.22,1,.36,1);
}
.rmsm-bar.c1 { background: rgba(31,221,240,.65); }
.rmsm-bar.c2 { background: rgba(46,230,200,.65); }
.rmsm-bar.c3 { background: rgba(15,242,158,.65); }
.rmsm-bv { font-variant-numeric: tabular-nums; font-size: 12px; color: var(--text-2); }

/* Conv rate pill */
.rmsm-pill {
  font-size: 10.5px; font-weight: 700;
  padding: 2px 7px; border-radius: 20px; white-space: nowrap;
}
.rmsm-p-hi  { background: rgba(15,242,158,.11);  color: #0ff29e; border: 1px solid rgba(15,242,158,.2); }
.rmsm-p-mid { background: rgba(245,158,11,.10);   color: #f59e0b; border: 1px solid rgba(245,158,11,.2); }
.rmsm-p-lo  { background: rgba(239,68,68,.09);    color: #f87171; border: 1px solid rgba(239,68,68,.18); }

/* Amount */
.rmsm-td-amt { font-weight: 700; color: #34d399 !important; font-size: 12.5px; }
.rmsm-tf-amt { font-size: 13px; color: #34d399 !important; }

/* Delta */
.rmsm-td-dt { font-size: 11.5px; font-weight: 600; }
.rmsm-td-dt.pos { color: #22c55e; }
.rmsm-td-dt.neg { color: #f87171; }

/* Tfoot */
.rmsm-tbl tfoot tr {
  border-top: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.016);
}
.rmsm-tbl tfoot td {
  padding: 9px 10px; font-weight: 700;
  color: var(--text-1); font-size: 12.5px; text-align: right;
}
.rmsm-tf-lbl { text-align: left !important; padding-left: 22px !important; color: var(--text-2) !important; }

/* Footer */
.rmsm-footer {
  display: flex; align-items: center; gap: 6px;
  padding: 10px 22px 16px;
  font-size: 10.5px; color: var(--text-3);
  margin-top: 4px; border-top: 1px solid rgba(255,255,255,.04);
}
.rmsm-footer svg { opacity:.45; flex-shrink:0; }

/* ── RMSM — Micro-interactions & animations premium ─────────────── */

/* Stagger d'entrée des blocs header / chart / table / footer */
.rmsm-hdr-l     { animation: rmsm-in .52s cubic-bezier(.22,1,.36,1) .05s  both; }
.rmsm-kpi-pill  { animation: rmsm-in .52s cubic-bezier(.22,1,.36,1) .13s  both; }
.rmsm-chart-outer { animation: rmsm-in .5s  cubic-bezier(.22,1,.36,1) .22s both; }
.rmsm-tbl-outer { animation: rmsm-in .5s  cubic-bezier(.22,1,.36,1) .30s  both; }
.rmsm-footer    { animation: rmsm-in .48s cubic-bezier(.22,1,.36,1) .38s  both; }

/* Badge "Actuel" — pulse subtil */
@keyframes rmsm-pulse-ring {
  0%, 100% { box-shadow: 0 0 0 0   rgba(31,221,240,.45); }
  55%       { box-shadow: 0 0 0 5px rgba(31,221,240,.0);  }
}
.rmsm-now { animation: rmsm-pulse-ring 2.6s ease-in-out infinite; }

/* KPI pill — lift + glow au hover */
.rmsm-kpi-pill {
  transition: border-color .22s ease, box-shadow .22s ease,
              transform .22s cubic-bezier(.22,1,.36,1);
}
.rmsm-kpi-pill:hover {
  transform: translateY(-2px);
  border-color: rgba(31,221,240,.3);
  box-shadow: 0 6px 28px rgba(31,221,240,.11), 0 1px 8px rgba(0,0,0,.45);
}

/* Rows — left accent animé sur td:first-child */
.rmsm-tbl tbody tr td:first-child {
  border-left: 2px solid transparent;
  padding-left: 20px !important;
  transition: border-color .15s cubic-bezier(.22,1,.36,1);
}
.rmsm-tbl tbody tr:hover td:first-child  { border-left-color: rgba(37,149,190,.45); }
.rmsm-cur td:first-child                 { border-left-color: rgba(37,149,190,.7) !important; }

/* Rows — fond hover plus marqué */
.rmsm-row { transition: background .13s ease; }
.rmsm-row:hover { background: rgba(31,221,240,.05) !important; }

/* Pill — micro scale au hover */
.rmsm-pill { transition: transform .14s cubic-bezier(.22,1,.36,1), filter .14s; }
.rmsm-tbl tbody tr:hover .rmsm-pill { transform: scale(1.07); }

/* Tooltip — apparition fluide */
.rmsm-tip { transition: opacity .14s cubic-bezier(.22,1,.36,1); }

/* Amount cells — légère couleur de survol renforcée */
.rmsm-row:hover .rmsm-td-amt { filter: brightness(1.12); }

/* Canvas crosshair */
#rmsm-chart { cursor: crosshair; }

/* ── prefers-reduced-motion ─────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .rmsm-card, .rmsm-hdr-l, .rmsm-kpi-pill,
  .rmsm-chart-outer, .rmsm-tbl-outer, .rmsm-footer,
  .rmsm-row, .rmsm-now { animation: none !important; }
  .rmsm-bar             { transition: none !important; }
  .rmsm-kpi-pill        { transform: none !important; transition: background .2s !important; }
  .rmsm-pill            { transition: none !important; }
}


/* ═══════════════════════════════════════════════════════════════════
   CMD — Commissions Master-Detail Premium
   ═══════════════════════════════════════════════════════════════════ */

.cmd-root { width: 100%; }
.cmd-loading, .cmd-empty {
  padding: 48px 24px; text-align: center; color: var(--text-3); font-size: 13px;
}
.cmd-layout {
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: 0;
  min-height: 560px;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 18px;
  overflow: hidden;
  background: var(--bg-card);
  animation: cmd-in .45s cubic-bezier(.22,1,.36,1) both;
}
@keyframes cmd-in {
  from { opacity:0; transform:translateY(8px); }
  to   { opacity:1; transform:translateY(0); }
}

/* ── LEFT column ─────────────────────────────────────────────────── */
.cmd-list-col {
  display: flex; flex-direction: column;
  border-right: 1px solid rgba(255,255,255,.07);
  background: var(--bg-1);
  min-height: 0;
}
.cmd-list-meta {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 14px 8px;
  border-bottom: 1px solid rgba(255,255,255,.05);
  flex-shrink: 0;
}
.cmd-lm-count {
  font-size: 11px; font-weight: 700; color: var(--text-3);
  text-transform: uppercase; letter-spacing: .05em;
}
.cmd-lm-sort {
  font-size: 11px; color: var(--text-3); display: flex; align-items: center; gap: 3px; cursor: pointer;
  transition: color .15s;
}
.cmd-lm-sort:hover { color: var(--text-2); }
.cmd-list-body {
  flex: 1; overflow-y: auto;
  scrollbar-width: thin; scrollbar-color: rgba(255,255,255,.07) transparent;
}
.cmd-list-body::-webkit-scrollbar { width: 3px; }
.cmd-list-body::-webkit-scrollbar-thumb { background: rgba(255,255,255,.09); border-radius:2px; }

/* List item */
.cmd-item {
  padding: 11px 14px;
  border-bottom: 1px solid rgba(255,255,255,.04);
  cursor: pointer;
  transition: background .12s ease;
  position: relative;
}
.cmd-item:last-child { border-bottom: none; }
.cmd-item:hover { background: rgba(255,255,255,.03); }
.cmd-item-active {
  background: rgba(31,221,240,.05) !important;
  box-shadow: inset 2px 0 0 #1fddf0;
}
.cmd-item-r1, .cmd-item-r2, .cmd-item-r3 {
  display: flex; align-items: center; justify-content: space-between;
}
.cmd-item-r1 { margin-bottom: 5px; }
.cmd-item-r2 { margin-bottom: 4px; }
.cmd-item-comm {
  font-size: 13px; font-weight: 800; color: #34d399;
  font-variant-numeric: tabular-nums;
}
.cmd-item-cust {
  font-size: 12px; color: var(--text); font-weight: 500;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 170px;
}
.cmd-item-date { font-size: 11px; color: var(--text-3); flex-shrink: 0; }
.cmd-item-sale { font-size: 11px; color: var(--text-3); }

/* Pagination */
.cmd-pagination {
  display: flex; align-items: center; justify-content: center; gap: 4px;
  padding: 10px 14px; border-top: 1px solid rgba(255,255,255,.05); flex-shrink: 0;
}
.cmd-pg-n, .cmd-pg-arr {
  min-width: 28px; height: 28px; padding: 0 6px;
  border-radius: 8px; border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03); color: var(--text-3);
  font-size: 12px; cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: background .13s, border-color .13s, color .13s;
}
.cmd-pg-n:hover:not([disabled]), .cmd-pg-arr:hover:not([disabled]) {
  background: rgba(31,221,240,.08); border-color: rgba(31,221,240,.2); color: #1fddf0;
}
.cmd-pg-cur {
  background: rgba(31,221,240,.12) !important;
  border-color: rgba(31,221,240,.3) !important;
  color: #1fddf0 !important;
}
.cmd-pg-n[disabled], .cmd-pg-arr[disabled] { opacity:.3; cursor:default; }
.cmd-pg-dots { color: var(--text-3); font-size: 12px; padding: 0 2px; }

/* ── RIGHT column ────────────────────────────────────────────────── */
.cmd-detail-col {
  overflow-y: auto;
  scrollbar-width: thin; scrollbar-color: rgba(255,255,255,.07) transparent;
  background: var(--bg-card);
}
.cmd-detail-col::-webkit-scrollbar { width: 4px; }
.cmd-detail-col::-webkit-scrollbar-thumb { background: rgba(255,255,255,.09); border-radius:2px; }

.cmd-dp { padding: 22px 24px 32px; }
.cmd-dp-anim { animation: cmd-dp-in .32s cubic-bezier(.22,1,.36,1) both; }
@keyframes cmd-dp-in {
  from { opacity:0; transform:translateX(8px); }
  to   { opacity:1; transform:translateX(0); }
}

/* Detail header */
.cmd-dp-hdr {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 12px;
  margin-bottom: 22px; padding-bottom: 18px; border-bottom: 1px solid rgba(255,255,255,.06);
}
.cmd-dp-txid { display: flex; align-items: center; gap: 8px; margin-bottom: 4px; }
.cmd-dp-id-txt { font-size: 15px; font-weight: 800; color: var(--text); letter-spacing:.02em; }
.cmd-cp-btn {
  padding: 4px 6px; border-radius: 6px;
  border: 1px solid rgba(255,255,255,.1); background: rgba(255,255,255,.04);
  color: var(--text-3); cursor: pointer; flex-shrink:0;
  transition: background .13s, border-color .13s, color .13s;
}
.cmd-cp-btn:hover { background: rgba(31,221,240,.08); border-color: rgba(31,221,240,.2); color:#1fddf0; }
.cmd-cp-ok { font-size:10.5px; color:#22c55e; font-weight:600; opacity:0; transition:opacity .2s; pointer-events:none; }
.cmd-cp-ok-visible { opacity:1; }
.cmd-dp-date { font-size:12px; color:var(--text-3); }
.cmd-dp-badge { font-size:12px !important; padding:4px 10px !important; }

/* Sections */
.cmd-sec { margin-bottom: 22px; }
.cmd-sec-lbl {
  font-size: 10.5px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; color: var(--text-3); margin-bottom: 10px;
}

/* Client card */
.cmd-client-card {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 16px; border-radius: 14px;
  background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.07);
}
.cmd-avatar {
  width: 40px; height: 40px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 15px; font-weight: 800; flex-shrink: 0;
  background: rgba(255,255,255,.06); color: var(--text); border: 1px solid rgba(255,255,255,.1);
}
.cmd-avatar-performance { background: rgba(64,254,90,.1);  color: #40fe5a; border-color: rgba(64,254,90,.2); }
.cmd-avatar-advanced    { background: rgba(75,4,145,.2);   color: #a855f7; border-color: rgba(109,13,174,.35); }
.cmd-avatar-sniper      { background: rgba(31,221,240,.09); color: #1fddf0; border-color: rgba(31,221,240,.2); }
.cmd-client-name { font-size:13.5px; font-weight:600; color:var(--text); margin-bottom:6px; }
.cmd-client-badges { display:flex; flex-wrap:wrap; gap:5px; align-items:center; }

/* Financial KPI grid */
.cmd-fin-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(120px,1fr)); gap:8px;
}
.cmd-fin-card {
  padding: 12px 14px; border-radius: 12px;
  border: 1px solid rgba(255,255,255,.07); background: rgba(255,255,255,.03);
  animation: cmd-fin-in .4s cubic-bezier(.22,1,.36,1) both;
}
.cmd-fin-card:nth-child(1) { animation-delay:.04s; }
.cmd-fin-card:nth-child(2) { animation-delay:.09s; }
.cmd-fin-card:nth-child(3) { animation-delay:.14s; }
.cmd-fin-card:nth-child(4) { animation-delay:.18s; }
@keyframes cmd-fin-in {
  from { opacity:0; transform:translateY(6px); }
  to   { opacity:1; transform:translateY(0); }
}
.cmd-fin-lbl { font-size:10.5px; color:var(--text-3); margin-bottom:5px; font-weight:600; }
.cmd-fin-val { font-size:16px; font-weight:800; font-variant-numeric:tabular-nums; color:var(--text); }
.cmd-fin-sale .cmd-fin-val  { color:#34d399; }
.cmd-fin-disc .cmd-fin-val  { color:#f59e0b; }
.cmd-fin-net-paid .cmd-fin-val    { color:#34d399; }
.cmd-fin-net-due .cmd-fin-val     { color:#1fddf0; }
.cmd-fin-net-pending .cmd-fin-val { color:var(--text-2); }

/* Formula */
.cmd-formula {
  display: flex; flex-wrap: wrap; align-items: center; gap: 6px;
  padding: 14px 16px; border-radius: 14px; margin-bottom: 8px;
  background: rgba(255,255,255,.025); border: 1px solid rgba(255,255,255,.06);
}
.cmd-fo-card {
  padding: 8px 12px; border-radius: 9px;
  border: 1px solid rgba(255,255,255,.07); background: rgba(255,255,255,.04); text-align:center;
}
.cmd-fo-lbl { font-size:9.5px; text-transform:uppercase; letter-spacing:.04em; color:var(--text-3); margin-bottom:3px; font-weight:600; }
.cmd-fo-val { font-size:13.5px; font-weight:800; font-variant-numeric:tabular-nums; color:var(--text); }
.cmd-fo-sale   .cmd-fo-val { color:#34d399; }
.cmd-fo-disc   .cmd-fo-val { color:#f59e0b; }
.cmd-fo-rate   .cmd-fo-val { color:#1fddf0; }
.cmd-fo-result .cmd-fo-val { color:#34d399; }
.cmd-fo-op { font-size:18px; font-weight:700; color:var(--text-3); padding:0 2px; }
.cmd-formula-note { font-size:11px; color:var(--text-3); padding:0 2px; }

/* Timeline */
.cmd-timeline { display:flex; flex-direction:column; }
.cmd-tl-step  { display:flex; align-items:flex-start; gap:12px; }
.cmd-tl-track { display:flex; flex-direction:column; align-items:center; flex-shrink:0; }
.cmd-tl-dot {
  width:22px; height:22px; border-radius:50%;
  border: 2px solid rgba(255,255,255,.15); background: rgba(255,255,255,.04);
  display:flex; align-items:center; justify-content:center; color:var(--text-3); flex-shrink:0;
  transition: border-color .2s, background .2s;
}
.cmd-tl-done   .cmd-tl-dot { border-color:#22c55e; background:rgba(34,197,94,.14); color:#22c55e; }
.cmd-tl-active .cmd-tl-dot {
  border-color:#1fddf0; background:rgba(31,221,240,.14); color:#1fddf0;
  box-shadow:0 0 12px rgba(31,221,240,.25);
  animation: cmd-tl-pulse 2s ease-in-out infinite;
}
@keyframes cmd-tl-pulse {
  0%,100% { box-shadow:0 0 10px rgba(31,221,240,.25); }
  50%     { box-shadow:0 0 20px rgba(31,221,240,.45); }
}
.cmd-tl-line {
  width:2px; flex:1; min-height:18px;
  background:rgba(255,255,255,.08); margin:3px 0;
}
.cmd-tl-done .cmd-tl-line { background:rgba(34,197,94,.28); }
.cmd-tl-body { padding:2px 0 18px; }
.cmd-tl-lbl  { font-size:13px; font-weight:600; color:var(--text-3); line-height:1.3; }
.cmd-tl-done   .cmd-tl-lbl { color:var(--text); }
.cmd-tl-active .cmd-tl-lbl { color:#1fddf0; }
.cmd-tl-sub  { font-size:11px; color:var(--text-3); margin-top:2px; }

/* Details grid */
.cmd-dg { display:grid; gap:1px; border-radius:12px; overflow:hidden; border:1px solid rgba(255,255,255,.06); }
.cmd-dr {
  display:flex; align-items:center; justify-content:space-between;
  padding:9px 14px; background:rgba(255,255,255,.02); transition:background .12s;
}
.cmd-dr:hover { background:rgba(255,255,255,.04); }
.cmd-dk { font-size:12px; color:var(--text-3); }
.cmd-dv { font-size:12.5px; font-weight:600; color:var(--text-2); text-align:right; }
.cmd-dv-green  { color:#34d399 !important; }
.cmd-dv-accent { color:#1fddf0 !important; }
.cmd-dv-orange { color:#f59e0b !important; }
.cmd-dv-muted  { color:var(--text-3) !important; font-size:11.5px !important; }

/* Payment banner */
.cmd-pay-banner {
  display:flex; align-items:flex-start; gap:9px; padding:12px 16px; border-radius:12px; margin-top:4px;
  background:rgba(255,255,255,.025); border:1px solid rgba(31,221,240,.14);
  font-size:12px; color:var(--text-2); line-height:1.5;
}
.cmd-pay-banner svg { color:#1fddf0; flex-shrink:0; opacity:.8; margin-top:1px; }
.cmd-pay-banner strong { color:var(--text); font-weight:700; }
.cmd-pay-paid { background:rgba(34,197,94,.04); border-color:rgba(34,197,94,.16); }
.cmd-pay-paid svg { color:#22c55e; }

/* prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
  .cmd-layout, .cmd-dp-anim, .cmd-fin-card { animation:none !important; }
  .cmd-tl-active .cmd-tl-dot { animation:none !important; }
  .cmd-item, .cmd-pg-n, .cmd-pg-arr, .cmd-cp-btn { transition:none !important; }
}

/* ═══════════════════════════════════════════════════════════════════
   RPT — Répartition Premium
   ═══════════════════════════════════════════════════════════════════ */

@keyframes rpt-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes rpt-orbit-spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
@keyframes rpt-breathe {
  0%, 100% { opacity: .55; transform: scale(1); }
  50%       { opacity: 1;   transform: scale(1.06); }
}
@keyframes rpt-dot-pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: .5; }
}
@keyframes rpt-pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: .3; transform: scale(.55); }
}
@keyframes rpt-kpi-pop {
  from { opacity: 0; transform: translateY(10px) scale(.95); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes rpt-pc-in {
  from { opacity: 0; transform: translateY(18px) scale(.94); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes rpt-pc-shimmer {
  0%   { transform: translateX(-160%) skewX(-8deg); }
  38%  { transform: translateX(180%) skewX(-8deg); }
  100% { transform: translateX(180%) skewX(-8deg); }
}
@keyframes rpt-kpi-glow-pulse {
  0%, 100% { opacity: .07; }
  50%       { opacity: .22; }
}
@keyframes rpt-banner-in {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Header ─────────────────────────────────────────────────────── */
.rpt-hdr {
  display: flex; flex-direction: column; align-items: flex-start;
  padding: 0 0 4px 0; gap: 3px;
  animation: rpt-in .45s cubic-bezier(.22,1,.36,1) both;
}
.rpt-hdr .rw-heatmap-sub { margin-top: 0; }
.rpt-hdr-l { display: flex; align-items: center; gap: 10px; }
.rpt-icon-box {
  width: 36px; height: 36px; border-radius: 11px;
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08);
  display: flex; align-items: center; justify-content: center;
  color: #1fddf0; flex-shrink: 0;
}
.rpt-title { font-size: 14.5px; font-weight: 800; color: var(--text); letter-spacing: -.01em; }
.rpt-sub   { font-size: 11.5px; color: var(--text-3); margin-top: 1px; }

.rpt-toggle {
  display: flex; align-items: center;
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.07);
  border-radius: 10px; padding: 3px; flex-shrink: 0;
}
.rpt-tog-btn {
  padding: 5px 14px; border-radius: 8px;
  font-size: 12px; font-weight: 600; cursor: pointer;
  border: none; background: transparent; color: var(--text-3);
  transition: background .15s, color .15s;
}
.rpt-tog-btn:hover:not(.rpt-tog-active) { color: var(--text-2); }
.rpt-tog-active {
  background: rgba(255,255,255,.09) !important;
  color: var(--text) !important;
  box-shadow: 0 1px 4px rgba(0,0,0,.3);
}

/* ── Body centré (mode plans) ───────────────────────────────────── */
.rpt-body-plans {
  display: flex; flex-direction: column; align-items: center;
  gap: 10px; padding: 20px 0 4px; width: 100%;
}
.rpt-center-row {
  display: flex; align-items: center; justify-content: center;
  gap: 20px; width: 100%;
}
.rpt-orbital-wrap {
  display: flex; flex-direction: column; align-items: center;
  gap: 8px; flex-shrink: 0;
}
.rpt-body-plans .rpt-ins-panel { width: 100%; box-sizing: border-box; }

/* ── Orbital visual ──────────────────────────────────────────────── */

.rpt-orbital-scene {
  position: relative; width: 290px; height: 290px;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}

/* Canvas aura 120Hz — derrière le logo */
.rpt-aura-canvas {
  position: absolute; inset: 0; z-index: 1;
  width: 100%; height: 100%;
  pointer-events: none;
}

.rpt-logo-center {
  position: relative; z-index: 2;
  width: 270px; height: 270px;
  flex-shrink: 0; cursor: crosshair;
}
.rpt-logo-center .rw-logo-seg,
.rpt-logo-center .rw-logo-shine {
  position: absolute; inset: 0;
  mask-repeat: no-repeat; mask-size: contain; mask-position: center;
  -webkit-mask-repeat: no-repeat; -webkit-mask-size: contain; -webkit-mask-position: center;
}
.rpt-logo-overlay {
  position: absolute; inset: 0; z-index: 10; cursor: crosshair;
}

/* Nombre TOTAL flottant en bas du logo orbital */
.rpt-scene-total {
  position: absolute; bottom: 2px; left: 50%; transform: translateX(-50%);
  z-index: 5; display: flex; flex-direction: column; align-items: center;
  gap: 1px; pointer-events: none;
}

.rpt-ring {
  position: absolute; border-radius: 50%;
  pointer-events: none;
}
.rpt-ring-1 {
  width: 272px; height: 272px;
  top: calc(50% - 136px); left: calc(50% - 136px);
  border: 1px solid rgba(63,255,91,.13);
  animation: rpt-breathe 5s ease-in-out infinite;
}
.rpt-ring-2 {
  width: 210px; height: 210px;
  top: calc(50% - 105px); left: calc(50% - 105px);
  border: 1px solid rgba(83,0,164,.11);
  animation: rpt-breathe 7s ease-in-out infinite reverse;
}

.rpt-orbit-track {
  position: absolute; border-radius: 50%; pointer-events: none;
}
.rpt-orbit-perf {
  width: 272px; height: 272px;
  top: calc(50% - 136px); left: calc(50% - 136px);
  animation: rpt-orbit-spin 18s linear infinite;
}
.rpt-orbit-adv {
  width: 210px; height: 210px;
  top: calc(50% - 105px); left: calc(50% - 105px);
  animation: rpt-orbit-spin 12s linear infinite reverse;
}
.rpt-orbit-dot {
  position: absolute;
  width: 14px; height: 14px; border-radius: 50%;
  top: -7px; left: 50%; transform: translateX(-50%);
  animation: rpt-dot-pulse 2.5s ease-in-out infinite;
}

.rpt-vis-center {
  position: relative; z-index: 2;
  display: flex; align-items: center; flex-direction: column; gap: 6px;
}
.rpt-vis-pct { font-size: 18px; font-weight: 800; font-variant-numeric: tabular-nums; line-height: 1; }
.rpt-vis-sep { width: 22px; height: 1px; background: rgba(255,255,255,.12); }

.rpt-vis-legend {
  display: flex; justify-content: center; gap: 14px;
  margin-top: 10px;
}
.rpt-vis-leg-item {
  display: flex; align-items: center; gap: 5px;
  font-size: 10.5px; color: var(--text-3);
}
.rpt-vis-dot {
  display: inline-block; width: 6px; height: 6px; border-radius: 50%;
}

/* ── Compact insight banner ─────────────────────────────────────── */
.rpt-banner {
  display: flex; flex-direction: column; gap: 5px;
  padding: 9px 12px; border-radius: 13px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.08);
  border-left: 2.5px solid var(--dom-color, #40fe5a);
  animation: rpt-banner-in .4s cubic-bezier(.22,1,.36,1) .06s both;
}
.rpt-banner-top { display: flex; align-items: center; gap: 7px; }
.rpt-banner-dot {
  width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0;
  background: var(--dom-color, #40fe5a);
  animation: rpt-pulse-dot 2.4s ease-in-out infinite;
}
.rpt-banner-title { font-size: 11.5px; font-weight: 700; color: var(--text); flex: 1; }
.rpt-banner-pills { display: flex; gap: 4px; flex-shrink: 0; }
.rpt-banner-pill {
  font-size: 8.5px; font-weight: 800; text-transform: uppercase; letter-spacing: .05em;
  padding: 2px 7px; border-radius: 5px;
  color: var(--pill-color, #40fe5a);
  background: rgba(255,255,255,.06);
  border: 1px solid var(--pill-color, #40fe5a);
  border-color: color-mix(in srgb, var(--pill-color, #40fe5a) 35%, transparent);
}
.rpt-banner-text { font-size: 10.5px; color: var(--text-3); line-height: 1.45; }

/* ── Plan cards — 2 colonnes verticales ─────────────────────────── */
.rpt-plan-cards {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px; flex: 1;
}

.rpt-plan-card {
  display: flex; flex-direction: column; align-items: center;
  padding: 13px 11px 11px; border-radius: 18px;
  position: relative; overflow: hidden;
  background: rgba(255,255,255,.034);
  border: 1px solid rgba(255,255,255,.08);
  border-bottom: 2px solid var(--plan-color, #40fe5a);
  transition: transform .24s cubic-bezier(.22,1,.36,1), background .24s;
  animation: rpt-pc-in .52s cubic-bezier(.22,1,.36,1) both;
}
.rpt-plan-card:nth-child(1) { animation-delay: .12s; }
.rpt-plan-card:nth-child(2) { animation-delay: .22s; }
.rpt-plan-card.rpt-pc-dom {
  background: rgba(255,255,255,.05);
  border-color: var(--plan-color, #40fe5a);
}
.rpt-plan-card:hover {
  transform: translateY(-4px);
  background: rgba(255,255,255,.06);
}

/* En-tête plan (logo + nom + badge) */
.rpt-pc-header {
  display: flex; align-items: center; gap: 6px;
  width: 100%; margin-bottom: 10px; position: relative; z-index: 2;
}
.rpt-pc-logo { width: 18px; height: 18px; object-fit: contain; flex-shrink: 0; }
.rpt-pc-name { font-size: 11.5px; font-weight: 800; color: var(--plan-color, #40fe5a); flex: 1; }
.rpt-pc-dom-badge {
  font-size: 7px; font-weight: 900; text-transform: uppercase; letter-spacing: .06em;
  padding: 2px 5px; border-radius: 4px; line-height: 1.5;
  background: var(--plan-color, #40fe5a); color: #000;
}

/* Grande jauge SVG — hero de la carte */
.rpt-pc-gauge {
  position: relative; width: 86px; height: 86px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 10px; position: relative; z-index: 2;
}
.rpt-pc-gauge-svg {
  width: 86px; height: 86px;
  transform: rotate(-90deg);
  position: absolute; inset: 0;
}
.rpt-pc-gauge-inner {
  position: relative; z-index: 3; text-align: center; pointer-events: none;
}
.rpt-pc-pct {
  font-size: 17px; font-weight: 900; letter-spacing: -.02em;
  font-variant-numeric: tabular-nums; line-height: 1;
  color: var(--plan-color, #40fe5a);
}

/* Grand nombre de conversions */
.rpt-pc-count {
  font-size: 40px; font-weight: 900; line-height: 1;
  font-variant-numeric: tabular-nums; letter-spacing: -.02em;
  background: linear-gradient(155deg, #fff 20%, var(--plan-color, #40fe5a) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 2px; position: relative; z-index: 2;
}
.rpt-pc-count-lbl {
  font-size: 8px; font-weight: 800; text-transform: uppercase; letter-spacing: .09em;
  color: var(--text-3); margin-bottom: 10px; position: relative; z-index: 2;
}

/* Barre de progression */
.rpt-pc-bar-wrap {
  width: 100%; height: 5px; background: rgba(255,255,255,.08);
  border-radius: 5px; overflow: hidden;
  margin-top: auto; position: relative; z-index: 2;
}
.rpt-pc-bar {
  height: 100%; border-radius: 5px;
  background: var(--plan-color, #40fe5a);
  width: 0%; transition: width 1.35s cubic-bezier(.22,1,.36,1);
}

/* ── KPI row ─────────────────────────────────────────────────────── */
.rpt-kpi-row {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 7px;
}
.rpt-kpi-card {
  padding: 12px; border-radius: 14px;
  background: rgba(255,255,255,.034);
  border: 1px solid rgba(255,255,255,.07);
  border-bottom: 2px solid rgba(255,255,255,.1);
  position: relative; overflow: hidden;
  animation: rpt-kpi-pop .48s cubic-bezier(.22,1,.36,1) both;
  transition: background .22s, transform .22s cubic-bezier(.22,1,.36,1), box-shadow .22s;
}
.rpt-kpi-card:hover {
  background: rgba(255,255,255,.06);
  transform: translateY(-3px);
}
.rpt-kpi-icon { margin-bottom: 8px; line-height: 1; position: relative; z-index: 2; }
.rpt-kpi-val {
  font-size: 14px; font-weight: 900;
  font-variant-numeric: tabular-nums; line-height: 1.2;
  background: linear-gradient(145deg, #fff 10%, var(--kpi-color, #fff) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
  position: relative; z-index: 2;
}
.rpt-kpi-code {
  background: linear-gradient(145deg, #fff 10%, #19f0d7 100%) !important;
  -webkit-background-clip: text !important; -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  letter-spacing: .02em;
}
.rpt-kpi-lbl { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--text-3); margin-top: 3px; position: relative; z-index: 2; }

/* ── Donut row (plans mode right panel) ─────────────────────────── */

.rpt-ps {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  flex: 1;
  min-width: 0;
}
.rpt-ps-l { align-items: flex-end; text-align: right; }
.rpt-ps-r { align-items: flex-start; text-align: left; }

.rpt-ps-pct {
  font-size: 44px;
  font-weight: 900;
  line-height: 1;
  font-variant-numeric: tabular-nums;
  animation: rpt-pc-in .45s ease both;
}
.rpt-ps-name {
  font-size: 12px;
  font-weight: 700;
  color: var(--text-2);
  text-transform: uppercase;
  letter-spacing: .06em;
  white-space: nowrap;
  margin-top: 6px;
}
.rpt-ps-conv {
  font-size: 13px;
  color: var(--text-3);
  font-variant-numeric: tabular-nums;
  margin-top: 2px;
}

/* Logo TOTAL (sous le grand logo orbital) */
.rpt-dr-total {
  font-size: 26px;
  font-weight: 900;
  color: var(--text);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.rpt-dr-lbl {
  font-size: 9px;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-top: -4px;
}

/* ── Insight panel ──────────────────────────────────────────────── */
.rpt-ins-panel {
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 10px;
  padding: 10px 12px 8px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.rpt-ins-hdr {
  font-size: 9px;
  font-weight: 700;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: .07em;
}
.rpt-ins-gap {
  font-size: 20px;
  font-weight: 900;
  line-height: 1.1;
  margin-top: 2px;
  font-variant-numeric: tabular-nums;
}
.rpt-ins-sub {
  font-size: 10px;
  color: var(--text-3);
  margin-bottom: 2px;
}
.rpt-ins-spark {
  width: 100%;
  height: 40px;
  display: block;
  margin-top: 4px;
}

/* ── Codes mode ─────────────────────────────────────────────────── */
.rpt-body-codes { padding: 4px 18px 18px; }
.rpt-codes-list {
  display: flex; flex-direction: column; gap: 5px; margin-bottom: 14px;
  max-height: 230px; overflow-y: auto;
  scrollbar-width: thin; scrollbar-color: rgba(255,255,255,.07) transparent;
}
.rpt-codes-list::-webkit-scrollbar { width: 3px; }
.rpt-codes-list::-webkit-scrollbar-thumb { background: rgba(255,255,255,.09); border-radius: 2px; }
.rpt-code-row {
  display: flex; align-items: center; gap: 9px; padding: 7px 4px;
  border-bottom: 1px solid rgba(255,255,255,.03);
  animation: rpt-in .35s cubic-bezier(.22,1,.36,1) both;
}
.rpt-code-dot  { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.rpt-code-name { font-size: 12px; color: var(--text-2); font-weight: 500; min-width: 64px; }
.rpt-code-bar-wrap {
  flex: 1; height: 4px; background: rgba(255,255,255,.06);
  border-radius: 2px; overflow: hidden;
}
.rpt-code-bar {
  height: 100%; border-radius: 2px;
  transition: width .7s cubic-bezier(.22,1,.36,1);
}
.rpt-code-stat  { font-size: 11.5px; color: var(--text-2); font-variant-numeric: tabular-nums; min-width: 56px; text-align: right; }
.rpt-code-pct   { color: var(--text-3); font-size: 10.5px; }

/* ── prefers-reduced-motion ─────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .rpt-orbit-track, .rpt-ring, .rpt-orbit-dot { animation: none !important; }
  .rpt-hdr, .rpt-banner, .rpt-plan-card, .rpt-kpi-card, .rpt-code-row { animation: none !important; }
  .rpt-banner-dot, .rpt-plan-card::after, .rpt-kpi-card::before { animation: none !important; }
  .rpt-plan-card, .rpt-kpi-card { transition: none !important; }
  .rpt-pc-bar, .rpt-code-bar { transition: none !important; }
  .rpt-ps-pct, .rpt-dr-total, .rpt-ps-conv { animation: none !important; }
}
