/* ═══════════════════════════════════════════════════════════
   LQ Dark — Design system gestion.lequai56.fr
   Remplace CRT shell + subpage + tweaks
   ═══════════════════════════════════════════════════════════ */

/* ── Remapping complet des variables CRT de gestion.css ──
   gestion.css définit des vars vertes à :root. On les écrase
   ici (lq-dark.css chargé après gestion.css) pour que TOUTES
   les sous-pages héritent du dark theme sans modifier leurs HTML.
   ──────────────────────────────────────────────────────────── */
:root {
  /* Remapper les vars CRT → dark */
  --gold:        #818cf8;   /* CRT green → indigo */
  --gold-lt:     #c084fc;   /* CRT bright → violet */
  --gold-dim:    rgba(129,140,248,.5);
  --surface:     rgba(99,102,241,.06);
  --surface2:    rgba(99,102,241,.10);
  --bd:          rgba(42,53,80,.9);
  --bd-str:      rgba(99,102,241,.25);
  --txt:         #e8edf5;
  --txt-mid:     #7a8ba8;
  --txt-dim:     #3d4f6a;
  --red:         #ef4444;
  --green:       #22c55e;
  --warn:        #f59e0b;
  --phos:        #818cf8;   /* pour les éléments crt-subpage.css restants */
  --phos-hi:     #c084fc;
  --phos-dim:    rgba(129,140,248,.5);
  --phos-low:    rgba(42,53,80,.9);
  --phos-bg:     #0d1117;
}

/* Body : écraser fond CRT, police monospace et taille de base */
body {
  background: #0d1117 !important;
  background-image: none !important;
  color: #e8edf5 !important;
  font-family: -apple-system, BlinkMacSystemFont, 'Inter', 'Segoe UI', sans-serif !important;
  font-size: 16px !important;
}

/* ── Tokens dark ── */
:root {
  --bg:        #0d1117;
  --bg-card:   #161b27;
  --bg-card2:  #1a2035;
  --border:    #2a3550;
  --border-dim:#1a2538;
  --txt:       #e8edf5;
  --txt-dim:   #7a8ba8;
  --txt-muted: #3d4f6a;
  --c-indigo:  #6366f1;
  --c-indigo-l:#818cf8;
  --c-violet:  #8b5cf6;
  --c-violet-l:#c084fc;
  --c-cyan:    #06b6d4;
  --c-cyan-l:  #22d3ee;
  --c-amber:   #f59e0b;
  --c-amber-l: #fbbf24;
  --c-red:     #ef4444;
  --c-red-l:   #f87171;
  --c-green:   #22c55e;
  --c-green-l: #4ade80;
  --c-pink:    #ec4899;
  --c-orange:  #f97316;
}

/* ── Shell ── */
.lqd-root {
  height: 100vh; height: 100dvh;
  overflow: hidden;
  background: var(--bg);
  color: var(--txt);
  font-family: -apple-system, BlinkMacSystemFont, 'Inter', 'Segoe UI', sans-serif;
}
.lqd-inner { height: 100%; display: flex; flex-direction: column; }

/* ── Neutraliser CRT sans casser ── */
.crtE-root { background: var(--bg) !important; color: var(--txt) !important; font-family: -apple-system, BlinkMacSystemFont, 'Inter', 'Segoe UI', sans-serif !important; }
.crtE-inner { height: 100% !important; }
.crtE-bulge, .crtE-noise, .crtE-rollbar, .crtE-shim, .crtE-glitch { display: none !important; }
/* Override CRT text colors */
.crtE-root * { text-shadow: none !important; }

/* ── Sous-page container ── */
.csp {
  padding: 4px 18px 12px;
  flex: 1; display: flex; flex-direction: column; min-height: 0;
  background: var(--bg);
}

/* ── Nav bar sous-page (sticky) ── */
.csp-nav {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 0 12px;
  border-bottom: 1px solid var(--border);
  gap: 10px;
  position: sticky; top: 0; z-index: 90;
  background: var(--bg); /* avoid content bleed-through */
}
.csp-nav .code {
  font-size: 11px; letter-spacing: .1em; text-transform: uppercase;
  color: var(--txt-muted);
}
.csp-nav .anc { color: var(--txt-muted); letter-spacing: .2em; }
.csp-nav-btns {
  display: flex; gap: 6px; align-items: center;
}

/* ── Bouton fermer (croix) ── */
.csp-off {
  width: 44px; height: 44px; border-radius: 12px;
  background: rgba(22,27,39,.85); border: 1px solid var(--border);
  color: var(--txt-dim); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-family: inherit; text-decoration: none;
  transition: all .25s cubic-bezier(.34,1.56,.64,1);
  backdrop-filter: blur(8px);
}
.csp-off:hover { background: rgba(239,68,68,.15); color: var(--c-red-l, #f87171); border-color: rgba(239,68,68,.4); transform: scale(1.1); }
.csp-off:active { transform: scale(.9); }
.csp-off svg { display: block; }

/* ── Header sous-page ── */
.csp-hdr { margin-top: 8px; text-align: center; }
.csp-hdr .eb {
  font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
  color: var(--txt-muted); display: block;
}
.csp-hdr .t {
  font-size: 28px; font-weight: 800; letter-spacing: -.02em;
  color: var(--txt); margin-top: 4px; display: block;
}
.csp-rule { display: flex; align-items: center; gap: 10px; margin: 8px auto 0; width: 60%; }
.csp-rule .l { flex: 1; height: 1px; background: var(--border); }
.csp-rule .d { font-size: 12px; color: var(--txt-muted); }

/* ── Corps scrollable ── */
.csp-body {
  margin-top: 14px; flex: 1; min-height: 0;
  overflow-y: auto; overflow-x: hidden; scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
  padding-right: 2px;
  display: flex; flex-direction: column; gap: 14px;
}
.csp-body::-webkit-scrollbar { width: 4px; }
.csp-body::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }

/* ── Section heading ── */
.csp-sect {
  font-size: 11px; font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; color: var(--txt-muted);
  display: flex; align-items: center; gap: 8px;
  margin: 4px 0 8px;
}
.csp-sect::before {
  content: ''; width: 3px; height: 14px;
  background: var(--c-indigo); border-radius: 2px; flex-shrink: 0;
}
.csp-sect::after { content: ''; flex: 1; height: 1px; background: var(--border); }

/* ── KPI grid ── */
.csp-kgrid { display: grid; grid-template-columns: repeat(2,1fr); gap: 10px; }
.csp-kgrid.three { grid-template-columns: repeat(3,1fr); }
.csp-kbox {
  padding: 14px; background: var(--bg-card);
  border: 1px solid var(--border); border-radius: 14px;
  position: relative; overflow: hidden;
}
.csp-kbox::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: var(--kbox-color, var(--c-indigo));
  border-radius: 14px 14px 0 0;
}
.csp-kbox .v {
  font-size: 24px; font-weight: 800; letter-spacing: -.03em;
  line-height: 1; color: var(--txt); font-variant-numeric: tabular-nums;
}
.csp-kbox .l {
  font-size: 10px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: var(--txt-muted); margin-top: 3px;
}
.csp-kbox .d { font-size: 12px; font-weight: 500; margin-top: 4px; color: var(--txt-dim); }
.csp-kbox .d.up   { color: var(--c-green); }
.csp-kbox .d.dn   { color: var(--c-red); }
.csp-kbox .v.bad  { color: var(--c-red); }
.csp-kbox .v.warn { color: var(--c-amber); }
.csp-kbox .v.ok   { color: var(--c-green); }

/* ── Toolbar ── */
.csp-toolbar { display: flex; gap: 6px; }
.csp-tbtn {
  flex: 1; text-align: center; padding: 8px 4px;
  background: var(--bg-card); border: 1px solid var(--border); border-radius: 10px;
  cursor: pointer; color: var(--txt-dim);
  font-family: inherit; font-size: 12px; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase;
  transition: all .15s;
}
.csp-tbtn:hover { background: var(--bg-card2); color: var(--txt); }
.csp-tbtn.on { background: var(--c-indigo); color: #fff; border-color: var(--c-indigo); }

/* ── List rows ── */
.csp-row {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 4px;
  border-bottom: 1px solid var(--border-dim);
  font-size: 14px; cursor: pointer;
}
.csp-row:hover { background: rgba(255,255,255,.03); border-radius: 8px; }
.csp-row .lbl  { flex: 1; color: var(--txt); }
.csp-row .sub  { font-size: 11px; color: var(--txt-dim); }
.csp-row .val  { color: var(--txt); font-weight: 600; font-variant-numeric: tabular-nums; }
.csp-row .dot  { width: 8px; height: 8px; border-radius: 50%; background: var(--c-green); flex-shrink: 0; }
.csp-row .dot.warn { background: var(--c-amber); }
.csp-row .dot.bad  { background: var(--c-red); }

/* ── Chips ── */
.csp-chip {
  display: inline-flex; align-items: center;
  padding: 3px 10px; border-radius: 20px;
  font-size: 11px; font-weight: 700; letter-spacing: .06em;
  text-transform: uppercase; border: 1px solid;
}
.csp-chip, .csp-chip.ok { background: rgba(34,197,94,.12); color: var(--c-green); border-color: rgba(34,197,94,.3); }
.csp-chip.warn { background: rgba(245,158,11,.12); color: var(--c-amber); border-color: rgba(245,158,11,.3); }
.csp-chip.bad  { background: rgba(239,68,68,.12);  color: var(--c-red);   border-color: rgba(239,68,68,.3); }

/* ── Bar chart ── */
.csp-barchart {
  display: flex; align-items: flex-end; gap: 3px;
  padding: 4px 0; border-bottom: 1px solid var(--border);
}
.csp-barchart .bar {
  flex: 1; min-height: 3px;
  background: linear-gradient(180deg, var(--c-indigo-l), var(--c-indigo));
  border-radius: 3px 3px 0 0; transition: opacity .2s;
}
.csp-barchart .bar.hi { background: linear-gradient(180deg, var(--c-violet-l), var(--c-violet)); }
.csp-barchart .bar.dim { opacity: .3; }

/* ── Progress bar ── */
.csp-pbar { display: flex; align-items: center; gap: 8px; font-size: 12px; }
.csp-pbar .pbar-lbl { width: 80px; color: var(--txt); font-weight: 500; }
.csp-pbar .pbar-track {
  flex: 1; height: 8px; background: var(--bg-card2);
  border: 1px solid var(--border); border-radius: 4px; overflow: hidden;
}
.csp-pbar .pbar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--c-indigo), var(--c-violet));
  border-radius: 4px; transition: width .3s;
}
.csp-pbar .pbar-fill.warn { background: linear-gradient(90deg, var(--c-amber), var(--c-orange)); }
.csp-pbar .pbar-fill.bad  { background: linear-gradient(90deg, var(--c-red), var(--c-pink)); }
.csp-pbar .pbar-val { width: 50px; text-align: right; color: var(--txt); font-weight: 600; font-variant-numeric: tabular-nums; }

/* ── Stub ── */
.csp-stub { padding: 32px 16px; text-align: center; color: var(--txt-dim); font-size: 13px; line-height: 1.6; }
.csp-stub .stub-t { font-size: 22px; font-weight: 700; color: var(--txt); letter-spacing: -.02em; margin-bottom: 12px; }
.csp-stub .stub-cur { display: none; }

/* ── Info box ── */
.csp-info {
  padding: 12px 14px; border: 1px solid var(--border);
  border-radius: 12px; background: var(--bg-card);
  font-size: 13px; line-height: 1.6;
}
.csp-info b { color: var(--txt); font-weight: 600; }
.csp-info > div { margin: 2px 0; }

/* ── Calendrier ── */
.csp-cal { display: grid; grid-template-columns: repeat(7,1fr); gap: 3px; }
.csp-cal .head { text-align: center; font-size: 9px; color: var(--txt-muted); letter-spacing: .1em; padding: 2px 0; }
.csp-cal .day {
  aspect-ratio: 1/1; border: 1px solid var(--border);
  border-radius: 6px; display: flex; align-items: center; justify-content: center;
  font-size: 10px; color: var(--txt-dim); position: relative; cursor: pointer;
}
.csp-cal .day.today { border-color: var(--c-indigo); color: var(--c-indigo-l); }
.csp-cal .day.hot { background: var(--c-indigo); color: #fff; border-color: var(--c-indigo); }

/* ── Dock (hub) ── */
.crtE-dock {
  margin-top: 10px; padding: 6px 14px;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 16px;
  display: grid; grid-template-columns: repeat(4,1fr); gap: 4px;
  position: relative;
}
.crtE-dock::before { display: none !important; }
.crtE-dbtn {
  position: relative; z-index: 1;
  display: flex; flex-direction: column; align-items: center;
  gap: 4px; padding: 10px 4px 8px;
  background: transparent; border: 0;
  color: var(--txt-muted);
  font-family: inherit; font-size: 10px; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase;
  cursor: pointer; border-radius: 12px;
  transition: all .15s;
}
.crtE-dbtn:hover { background: rgba(255,255,255,.05); color: var(--txt-dim); }
.crtE-dbtn.on { background: rgba(99,102,241,.15); color: var(--c-indigo-l); box-shadow: none; }
.crtE-dbtn.on svg { stroke: var(--c-indigo-l) !important; filter: none !important; }
.crtE-dbtn .lbl { line-height: 1; font-weight: 700; }
.crtE-dbdg {
  position: absolute; top: 6px; right: 6px;
  min-width: 16px; height: 16px; padding: 0 4px;
  background: var(--c-red); color: #fff;
  font-size: 10px; line-height: 16px; text-align: center;
  font-weight: 700; border-radius: 8px; box-shadow: none;
}

/* ── Offline bar ── */
.offline-bar {
  position: fixed; top: 0; left: 0; right: 0;
  background: rgba(13,17,23,.96); color: var(--c-amber);
  text-align: center; padding: 8px; font-size: 12px; font-weight: 600;
  z-index: 100; transform: translateY(-100%); transition: transform .3s;
  border-bottom: 1px solid var(--border);
}
.offline-bar.show { transform: translateY(0); }
.offline-bar span { color: var(--txt-muted); margin-left: 8px; font-size: 11px; }

/* ── Toast ── */
.toast {
  position: fixed; bottom: 80px; left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: var(--bg-card2); color: var(--txt);
  border: 1px solid var(--border); border-radius: 12px;
  padding: 10px 16px; font-size: 13px; z-index: 200;
  opacity: 0; pointer-events: none;
  transition: opacity .3s, transform .3s;
}
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); pointer-events: auto; }

/* ── Flash animation ── */
.crtE-root.crt-flash .crtE-inner,
.lqd-root.crt-flash .lqd-inner { animation: lq-flash .25s ease-out !important; }
@keyframes lq-flash { 0%,100%{opacity:1} 40%{opacity:.6} }

/* ── Ripple (neutraliser) ── */
.cv-ripple { display: none !important; }
.cv-spark  { display: none !important; }

/* ── Catalogue portrait ── */
.catalogue-portrait-only { max-width: 430px; margin: 0 auto; }

/* ── Icônes modules néon — couleur gérée inline par crt-icons.js ── */
.crt-frame svg { display: block; overflow: visible; }

/* ── Bouton compte SSO — coin top-right fixe ── */
#lequai-account-btn {
  position: fixed !important;
  top: 10px !important;
  right: 14px !important;
  left: auto !important;
  z-index: 9000 !important;
  background: var(--bg-card) !important;
  border-color: var(--border) !important;
  color: var(--txt-dim) !important;
}
body.spa-open #lequai-account-btn { display: none !important; }

/* ── Header hub — espace pour le bouton SSO ── */
.lq-hdr-right { padding-right: 48px; }

/* ── Vue ordi — responsive desktop sub-pages ── */
@media (min-width: 700px) {
  .csp { padding: 8px 32px 18px; }
  .csp-hdr .t { font-size: 38px; }
  .csp-kbox .v { font-size: 30px; }
  .csp-kgrid { gap: 14px; }
  .csp-kgrid:not(.three) { grid-template-columns: repeat(3,1fr); }
  .csp-kgrid.three { grid-template-columns: repeat(3,1fr); }
  .kpi-grid { grid-template-columns: repeat(auto-fit, minmax(160px,1fr)); gap: 14px; }
  .sub-tabs { gap: 8px; }
  .sub-tab { padding: 10px 20px; font-size: 14px; }
  .ops-toolbar { gap: 12px; }
  .csp-toolbar { gap: 10px; }
  .csp-barchart { gap: 5px; min-height: 180px; }
  .csp-pbar .pbar-lbl { width: 140px; }
  .csp-row { padding: 12px 8px; font-size: 15px; }
  .catalogue-portrait-only { max-width: 430px; }
}

/* ── Bouton wide toggle — supprimé, toujours plein écran ── */
.csp-wide-btn { display: none !important; }

/* ── Polish — KPI cards entrance ── */
.csp-kbox {
  animation: kbox-in .4s cubic-bezier(.25,1,.5,1) both;
}
.csp-kbox:nth-child(1) { animation-delay: .05s; }
.csp-kbox:nth-child(2) { animation-delay: .1s; }
.csp-kbox:nth-child(3) { animation-delay: .15s; }
.csp-kbox:nth-child(4) { animation-delay: .2s; }
@keyframes kbox-in { from { opacity: 0; transform: translateY(12px) scale(.97); } to { opacity: 1; transform: none; } }

/* ── Polish — KPI card hover ── */
.csp-kbox { transition: transform .2s, box-shadow .2s, border-color .2s; }
.csp-kbox:hover { transform: translateY(-2px); box-shadow: 0 4px 16px rgba(0,0,0,.25); border-color: var(--border); }

/* ── Polish — Row hover ── */
.csp-row { transition: all .15s; }
.csp-row:hover { background: rgba(99,102,241,.06); border-radius: 8px; padding-left: 8px; }

/* ── Polish — Toolbar button active ── */
.csp-tbtn { transition: all .2s cubic-bezier(.25,1,.5,1); }
.csp-tbtn:active { transform: scale(.95); }

/* ── Polish — Body fade-in ── */
.csp-body { animation: body-fade .4s ease both; }
@keyframes body-fade { from { opacity: 0; } to { opacity: 1; } }

/* ── Polish — Toast progress bar ── */
.toast { position: relative; overflow: hidden; }
.toast::after {
  content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 2px;
  background: var(--c-indigo);
  animation: toast-progress 3s linear forwards;
}
@keyframes toast-progress { from { transform: scaleX(1); transform-origin: left; } to { transform: scaleX(0); transform-origin: left; } }

/* ═══════════════════════════════════════════════════════════
   DESIGN POLISH v3 — Animations & Effects
   ═══════════════════════════════════════════════════════════ */

/* ── Ambient background ── */
.ambient { position: fixed; inset: 0; pointer-events: none; z-index: 0; overflow: hidden; }
.orb { position: absolute; border-radius: 50%; filter: blur(80px); opacity: .12; will-change: transform; }
.orb-1 { width: 300px; height: 300px; background: var(--c-indigo); top: -80px; left: -60px; animation: orb1 12s ease-in-out infinite; }
.orb-2 { width: 250px; height: 250px; background: var(--c-violet); bottom: 20%; right: -80px; animation: orb2 15s ease-in-out infinite; }
.orb-3 { width: 200px; height: 200px; background: var(--c-cyan-l); top: 40%; left: 50%; animation: orb3 18s ease-in-out infinite; opacity: .07; }
@keyframes orb1 { 0%,100%{transform:translate(0,0) scale(1)} 33%{transform:translate(60px,40px) scale(1.1)} 66%{transform:translate(-20px,80px) scale(.95)} }
@keyframes orb2 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(-80px,-60px) scale(1.15)} }
@keyframes orb3 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(-60px,40px)} }

/* ── Floating particles ── */
.particles { position: fixed; inset: 0; pointer-events: none; z-index: 0; }
.particle {
  position: absolute; width: 2px; height: 2px;
  background: var(--c-indigo-l); border-radius: 50%;
  opacity: 0; animation: particle-float linear infinite;
}
@keyframes particle-float {
  0%   { opacity: 0; transform: translateY(0) scale(0); }
  10%  { opacity: .6; transform: scale(1); }
  90%  { opacity: .3; }
  100% { opacity: 0; transform: translateY(-100vh) scale(0); }
}

/* ── Entrance animations ── */
@keyframes slam-in  { 0%{opacity:0;transform:translateY(30px) scale(.92)} 60%{opacity:1;transform:translateY(-4px) scale(1.01)} 100%{opacity:1;transform:translateY(0) scale(1)} }
@keyframes slide-r   { 0%{opacity:0;transform:translateX(-40px)} 100%{opacity:1;transform:translateX(0)} }
@keyframes pop-in    { 0%{opacity:0;transform:scale(.3)} 70%{transform:scale(1.08)} 100%{opacity:1;transform:scale(1)} }
@keyframes fade-up   { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }
@keyframes reveal-in { 0%{opacity:0;transform:translateY(12px);filter:blur(8px)} 100%{opacity:1;transform:translateY(0);filter:blur(0)} }

.e-slam  { opacity:0; animation: slam-in .6s cubic-bezier(.16,1,.3,1) forwards; }
.e-slide { opacity:0; animation: slide-r .5s cubic-bezier(.16,1,.3,1) forwards; }
.e-pop   { opacity:0; animation: pop-in .5s cubic-bezier(.34,1.56,.64,1) forwards; }
.e-fade  { opacity:0; animation: fade-up .5s cubic-bezier(.16,1,.3,1) forwards; }
.e-reveal{ opacity:0; animation: reveal-in .6s cubic-bezier(.16,1,.3,1) forwards; }

.d1{animation-delay:.05s} .d2{animation-delay:.1s} .d3{animation-delay:.15s}
.d4{animation-delay:.2s} .d5{animation-delay:.25s} .d6{animation-delay:.3s}
.d7{animation-delay:.35s} .d8{animation-delay:.4s} .d9{animation-delay:.45s} .d10{animation-delay:.5s}

/* ── Ripple on touch ── */
.ripple-host { position: relative; overflow: hidden; }
.ripple {
  position: absolute; border-radius: 50%;
  background: rgba(129,140,248,.25);
  transform: scale(0); animation: ripple-expand .6s ease-out forwards;
  pointer-events: none;
}
@keyframes ripple-expand { to { transform: scale(4); opacity: 0; } }

/* ── Header gradient title ── */
.lq-title {
  background: linear-gradient(135deg, var(--txt) 0%, var(--c-indigo-l) 100%) !important;
  background-size: 200% 200% !important;
  -webkit-background-clip: text !important; -webkit-text-fill-color: transparent !important;
  animation: grad-shift 4s ease-in-out infinite !important;
}
@keyframes grad-shift { 0%,100%{background-position:0% 50%} 50%{background-position:100% 50%} }

/* ── Typing cursor ── */
.typing-cursor { display: inline-block; width: 2px; height: 14px; background: var(--c-indigo-l); margin-left: 2px; vertical-align: middle; animation: blink .8s step-end infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0} }

/* ── KPI Band upgrade — animated border + shimmer + tilt ── */
.lq-kpi-band {
  position: relative !important;
  background: rgba(22,27,39,.85) !important;
  backdrop-filter: blur(16px);
  border: none !important;
  border-radius: 20px !important;
  padding: 22px 0 !important;
  overflow: hidden;
  z-index: 1;
  transition: box-shadow .3s, transform .15s ease-out !important;
  transform-style: preserve-3d; perspective: 600px;
}
.lq-kpi-band::before {
  content:''; position:absolute; inset:0; border-radius:20px; padding:1px;
  background: linear-gradient(135deg, var(--c-indigo), var(--c-violet), var(--c-cyan-l), var(--c-indigo));
  background-size: 300% 300%; animation: border-rot 5s linear infinite;
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
}
@keyframes border-rot { 0%{background-position:0% 50%} 50%{background-position:100% 50%} 100%{background-position:0% 50%} }
.lq-kpi-band::after {
  content:''; position:absolute; inset:0;
  background: linear-gradient(105deg, transparent 30%, rgba(129,140,248,.08) 45%, rgba(139,92,246,.12) 50%, rgba(129,140,248,.08) 55%, transparent 70%);
  background-size: 250% 100%; animation: shimmer 4s ease-in-out infinite;
  pointer-events:none; border-radius:20px;
}
@keyframes shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }
.lq-kpi-band:active { transform: scale(.98) !important; }
.lq-kpi-item { position: relative; z-index: 2; }
.lq-kpi-sep { background: linear-gradient(180deg, transparent, rgba(99,102,241,.3), transparent) !important; }

/* ── Slot machine digits ── */
.slot-value { display: flex; justify-content: center; align-items: center; gap: 0; height: 36px; overflow: hidden; }
.slot-digit {
  display: inline-block; width: .62em; height: 36px;
  overflow: hidden; position: relative;
  font-size: 28px; font-weight: 800; letter-spacing: -.03em;
  font-variant-numeric: tabular-nums; line-height: 36px;
  color: var(--txt);
}
.slot-digit.gradient { background: linear-gradient(135deg, #4ade80, #22d3ee); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
.slot-digit-inner {
  position: absolute; left: 0; width: 100%; text-align: center;
  transition: transform .8s cubic-bezier(.16,1,.3,1);
}
.slot-static {
  display: inline-block;
  font-size: 28px; font-weight: 800; letter-spacing: -.03em;
  font-variant-numeric: tabular-nums; line-height: 36px;
}
.slot-static.unit { font-size: 16px; font-weight: 400; opacity: .5; margin-left: 2px; }
.slot-static.gradient { background: linear-gradient(135deg, #4ade80, #22d3ee); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }

/* ── Push card upgrade ── */
.lq-push-card {
  background: rgba(22,27,39,.8) !important;
  backdrop-filter: blur(16px);
  border-color: rgba(42,53,80,.6) !important;
  border-radius: 16px !important;
  transition: all .25s !important;
}
.lq-push-card:hover { border-color: rgba(99,102,241,.25) !important; }
.lq-push-dot {
  width: 8px; height: 8px; background: var(--c-indigo-l); border-radius: 50%;
  animation: pulse-dot 2s ease-in-out infinite;
  box-shadow: 0 0 8px rgba(129,140,248,.5);
  display: inline-block; margin-left: 4px;
}
@keyframes pulse-dot { 0%,100%{transform:scale(1);box-shadow:0 0 4px rgba(129,140,248,.4)} 50%{transform:scale(1.3);box-shadow:0 0 12px rgba(129,140,248,.6)} }
.lq-push-arr { transition: transform .3s cubic-bezier(.34,1.56,.64,1) !important; }
.lq-push-card.open .lq-push-arr { transform: rotate(90deg); }
.lq-push-body {
  max-height: 0 !important; overflow: hidden !important;
  transition: max-height .4s cubic-bezier(.4,0,.2,1), padding .4s !important;
  padding: 0 14px !important;
}
.lq-push-card.open .lq-push-body { max-height: 300px !important; padding: 12px 14px 16px !important; display: block !important; }

/* ── Section divider gradient ── */
.lq-sect::after { background: linear-gradient(90deg, var(--border), transparent 80%) !important; }

/* ── Module grid — rotating conic border + inner glow ── */
@property --angle { syntax:'<angle>'; initial-value:0deg; inherits:false; }
@keyframes spin-b { to{--angle:360deg} }

.crt-frame::before {
  content:''; position:absolute; inset:0;
  border-radius:20px; padding:1px;
  background: conic-gradient(from var(--angle,0deg), transparent 40%, var(--glow, #818cf8) 50%, transparent 60%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  animation: spin-b 4s linear infinite; opacity:.6;
}
.crt-frame::after {
  content:''; position:absolute; inset:0; border-radius:20px;
  background: radial-gradient(circle at center, var(--glow-dim, #818cf8) 0%, transparent 70%);
  opacity:.12; transition:opacity .3s;
}

/* ── Module data-color vars ── */
.crt-app[data-color="indigo"]  { --glow:#818cf8; --glow-dim:#818cf8; }
.crt-app[data-color="cyan"]    { --glow:#22d3ee; --glow-dim:#22d3ee; }
.crt-app[data-color="pink"]    { --glow:#f472b6; --glow-dim:#f472b6; }
.crt-app[data-color="amber"]   { --glow:#fbbf24; --glow-dim:#fbbf24; }
.crt-app[data-color="violet"]  { --glow:#a78bfa; --glow-dim:#a78bfa; }
.crt-app[data-color="green"]   { --glow:#4ade80; --glow-dim:#4ade80; }
.crt-app[data-color="orange"]  { --glow:#fb923c; --glow-dim:#fb923c; }
.crt-app[data-color="sky"]     { --glow:#38bdf8; --glow-dim:#38bdf8; }
.crt-app[data-color="lime"]    { --glow:#a3e635; --glow-dim:#a3e635; }
.crt-app[data-color="rose"]    { --glow:#f43f5e; --glow-dim:#f43f5e; }

/* ── SVG stroke draw on entrance ── */
.crt-app svg path, .crt-app svg circle, .crt-app svg rect, .crt-app svg line, .crt-app svg polyline {
  stroke-dasharray: 200;
  stroke-dashoffset: 200;
  animation: svg-draw .8s cubic-bezier(.16,1,.3,1) forwards;
}
.crt-app.d3 svg path, .crt-app.d3 svg circle, .crt-app.d3 svg line, .crt-app.d3 svg polyline { animation-delay: .15s; }
.crt-app.d4 svg path, .crt-app.d4 svg circle, .crt-app.d4 svg line, .crt-app.d4 svg polyline { animation-delay: .2s; }
.crt-app.d5 svg path, .crt-app.d5 svg circle, .crt-app.d5 svg line, .crt-app.d5 svg polyline { animation-delay: .25s; }
.crt-app.d6 svg path, .crt-app.d6 svg circle, .crt-app.d6 svg line, .crt-app.d6 svg polyline { animation-delay: .3s; }
.crt-app.d7 svg path, .crt-app.d7 svg circle, .crt-app.d7 svg line, .crt-app.d7 svg polyline { animation-delay: .35s; }
.crt-app.d8 svg path, .crt-app.d8 svg circle, .crt-app.d8 svg line, .crt-app.d8 svg polyline { animation-delay: .4s; }
.crt-app.d9 svg path, .crt-app.d9 svg circle, .crt-app.d9 svg line, .crt-app.d9 svg polyline { animation-delay: .45s; }
.crt-app.d10 svg path, .crt-app.d10 svg circle, .crt-app.d10 svg line, .crt-app.d10 svg polyline { animation-delay: .5s; }
.crt-app.d11 svg path, .crt-app.d11 svg circle, .crt-app.d11 svg line, .crt-app.d11 svg polyline { animation-delay: .55s; }
@keyframes svg-draw { to { stroke-dashoffset: 0; } }

/* ── Icon idle animations ── */
@keyframes heartbeat { 0%,100%{transform:scale(1)} 14%{transform:scale(1.15)} 28%{transform:scale(1)} 42%{transform:scale(1.1)} }
@keyframes spin-slow { to{transform:rotate(360deg)} }
@keyframes breathe   { 0%,100%{opacity:.8} 50%{opacity:1} }
@keyframes float     { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-3px)} }
@keyframes pulse-s   { 0%,100%{transform:scale(1)} 50%{transform:scale(1.08)} }
@keyframes swing     { 0%,100%{transform:rotate(0)} 25%{transform:rotate(8deg)} 75%{transform:rotate(-8deg)} }
@keyframes wiggle    { 0%,100%{transform:translateX(0)} 25%{transform:translateX(2px)} 75%{transform:translateX(-2px)} }

.crt-app[data-color="indigo"] .crt-frame svg { animation: heartbeat 2.5s ease-in-out infinite .8s; }
.crt-app[data-color="cyan"]   .crt-frame svg { animation: spin-slow 10s linear infinite .8s; }
.crt-app[data-color="pink"]   .crt-frame svg { animation: breathe 3s ease-in-out infinite .8s; }
.crt-app[data-color="amber"]  .crt-frame svg { animation: float 2.5s ease-in-out infinite .8s; }
.crt-app[data-color="violet"] .crt-frame svg { animation: pulse-s 2s ease-in-out infinite .8s; }
.crt-app[data-color="green"]  .crt-frame svg { animation: swing 3s ease-in-out infinite .8s; }
.crt-app[data-color="orange"] .crt-frame svg { animation: spin-slow 6s linear infinite .8s; }
.crt-app[data-color="sky"]    .crt-frame svg { animation: wiggle 3s ease-in-out infinite .8s; }
.crt-app[data-color="lime"]   .crt-frame svg { animation: float 2s ease-in-out infinite .8s; }

/* ── Hover burst ── */
.crt-app:hover .crt-frame {
  transform: translateY(-5px) scale(1.1) !important;
  box-shadow: 0 10px 40px color-mix(in srgb, var(--glow, #818cf8) 35%, transparent) !important;
  border-color: transparent !important;
}
.crt-app:hover .crt-frame::after { opacity:.4; }
.crt-app:hover .crt-frame svg {
  animation: none !important;
  transform: scale(1.25) !important;
  filter: drop-shadow(0 0 12px var(--glow, #818cf8));
}
.crt-app:hover .crt-label { color: var(--glow, #818cf8) !important; text-shadow: 0 0 16px color-mix(in srgb, var(--glow, #818cf8) 50%, transparent); }
.crt-app:active .crt-frame { transform: scale(.88) !important; transition-duration:.1s !important; }

/* ── Frame base transition upgrade ── */
.crt-frame {
  transition: all .35s cubic-bezier(.34,1.56,.64,1) !important;
  background: rgba(10,14,23,.8) !important;
}
.crt-frame svg { position: relative; z-index: 2; transition: all .35s cubic-bezier(.34,1.56,.64,1); }

/* ── Stat boxes — gradient border + hover (sub-pages) ── */
.csp-kbox {
  transition: all .3s cubic-bezier(.34,1.56,.64,1) !important;
  backdrop-filter: blur(12px);
}
.csp-kbox:hover { transform: translateY(-3px) scale(1.03); box-shadow: 0 8px 24px rgba(0,0,0,.3); }

/* ── KPI cards — glass + hover ── */
.kpi-card {
  background: rgba(22,27,39,.85);
  backdrop-filter: blur(12px);
  border: 1px solid var(--border);
  border-radius: 14px;
  transition: all .3s cubic-bezier(.34,1.56,.64,1);
  position: relative; overflow: hidden;
}
.kpi-card::before {
  content:''; position:absolute; top:0; left:-100%; width:60%; height:100%;
  background: linear-gradient(90deg, transparent, rgba(129,140,248,.06), transparent);
  transition: left .6s ease;
}
.kpi-card:hover::before { left: 150%; }
.kpi-card:hover {
  border-color: rgba(99,102,241,.3);
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 8px 24px rgba(0,0,0,.3), 0 0 0 1px rgba(99,102,241,.1);
}

/* ── Sub-tabs — glass upgrade ── */
.sub-tab {
  transition: all .25s cubic-bezier(.34,1.56,.64,1) !important;
}
.sub-tab:hover { transform: translateY(-1px); }
.sub-tab:active { transform: scale(.96); }

/* ── Buttons — shimmer on primary ── */
.btn-gold {
  position: relative; overflow: hidden;
  transition: all .25s cubic-bezier(.34,1.56,.64,1) !important;
}
.btn-gold::after {
  content:''; position:absolute; inset:0;
  background: linear-gradient(135deg, transparent 40%, rgba(255,255,255,.12) 50%, transparent 60%);
  background-size: 250% 100%; animation: shimmer 3s ease-in-out infinite;
}
.btn-gold:hover { transform: translateY(-2px) scale(1.03); }
.btn-gold:active { transform: scale(.96); }
.btn-outline {
  transition: all .25s cubic-bezier(.34,1.56,.64,1) !important;
}
.btn-outline:hover { transform: translateY(-2px); }

/* ── CSP rule diamond pulse ── */
.csp-rule .d { animation: pulse-s 2s ease-in-out infinite; display: inline-block; }

/* ── Sub-page header gradient ── */
.csp-hdr .t {
  background: linear-gradient(135deg, var(--c-indigo-l) 0%, var(--c-violet) 50%, var(--c-cyan-l) 100%) !important;
  background-size: 200% 200% !important;
  -webkit-background-clip: text !important; -webkit-text-fill-color: transparent !important;
  animation: grad-shift 4s ease-in-out infinite;
}

/* ── COUTS — Bar KPI cards ── */
.bar-kpi {
  background: linear-gradient(135deg, rgba(99,102,241,.08), rgba(129,140,248,.04));
  border: 1px solid rgba(99,102,241,.15);
  border-radius: 12px; padding: 14px 12px; text-align: center;
  transition: transform .25s, box-shadow .25s, opacity .4s;
}
.bar-kpi:hover { transform: translateY(-3px); box-shadow: 0 8px 24px rgba(99,102,241,.15); }
.bar-kpi-label { font-size: .7rem; color: var(--c-indigo-l); text-transform: uppercase; letter-spacing: .5px; margin-bottom: 4px; }
.bar-kpi-val { font-size: 1.5rem; font-weight: 800; color: #fff; }
.bar-kpi-sub { font-size: .68rem; color: var(--txt-dim); margin-top: 2px; }

/* ── COUTS — Marge badges glow ── */
.marge-badge { padding: 2px 8px; border-radius: 6px; font-weight: 700; font-size: .76rem; white-space: nowrap; }
.marge-hi { background: rgba(76,202,122,.12); color: #4cca7a; }
.marge-mid { background: rgba(251,191,36,.12); color: #fbbf24; }
.marge-lo { background: rgba(224,112,112,.12); color: #e07070; }
.marge-na { background: rgba(255,255,255,.04); color: var(--txt-dim); }

/* ── COUTS — Table rows ── */
.dem-table tbody tr {
  transition: background .15s, transform .15s;
}
.dem-table tbody tr:hover { background: rgba(99,102,241,.06); }

/* ── COUTS — Fournisseur cards ── */
.f-card {
  transition: transform .2s, box-shadow .2s, border-color .2s;
}
.f-card:hover { transform: translateX(4px); border-color: rgba(99,102,241,.3); box-shadow: 0 4px 20px rgba(99,102,241,.1); }

/* ── COUTS — Hausse items ── */
.hausse-item {
  transition: transform .2s, background .2s;
}
.hausse-item:hover { transform: translateX(4px); }

/* ── COUTS — Prix product rows ── */
.prod-row {
  transition: transform .15s, background .15s;
}
.prod-row:hover { transform: translateX(3px); }

/* ── Section titles ── */
.section-title {
  position: relative;
}

/* ── COUTS — Price chart ── */
.line-chart svg { transition: opacity .4s; }
.price-line { stroke: var(--c-indigo); stroke-width: 2; fill: none; filter: drop-shadow(0 0 4px rgba(99,102,241,.4)); }
.price-area { fill: url(#priceGrad); opacity: .15; }
.price-dot { fill: var(--c-indigo-l); filter: drop-shadow(0 0 3px rgba(99,102,241,.5)); transition: r .15s; }
.price-dot:hover { r: 5; }
.grid-line { stroke: rgba(255,255,255,.06); stroke-width: 1; }
.axis-label { fill: var(--txt-dim); font-size: 10px; }

/* ── PRODUITS — table rows ── */
#mainTable tbody tr {
  transition: background .15s, transform .15s;
}
#mainTable tbody tr:nth-child(odd) { background: rgba(99,102,241,.02); }
#mainTable tbody tr:hover { background: rgba(99,102,241,.06); }

/* ═══════════════════════════════════════════════════════════
   IFRAME MODE — Hide redundant close/back/wide buttons
   The parent (index.html) toolbar handles close + fullscreen.
   ═══════════════════════════════════════════════════════════ */
.csp-nav { display: none !important; }
.sent-close-fixed { display: none !important; }
.sante-close { display: none !important; }
.pl-close { display: none !important; }
.page-header .back { display: none !important; }

/* ── prefers-reduced-motion ── */
@media (prefers-reduced-motion:reduce) {
  *,*::before,*::after { animation-duration:.01ms!important; animation-iteration-count:1!important; transition-duration:.01ms!important; }
  .ambient,.particles { display:none; }
}
