/* css/production.css — Cockpit Production */

.prod-wrap { padding: 24px; font-family: -apple-system, system-ui, sans-serif; color: #e5e7eb; max-width: 1600px; margin: 0 auto; }

/* ─── Title ─── */
.prod-title { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 20px; }
.prod-title h1 { font-size: 24px; font-weight: 800; color: #fff; letter-spacing: -.5px; }
.prod-sub { font-size: 12px; color: #6b7280; text-transform: uppercase; letter-spacing: .8px; margin-top: 4px; }
.prod-title-actions { display: flex; gap: 8px; }
.prod-btn { padding: 8px 16px; background: rgba(34,211,238,.08); border: 1px solid #164e63; color: #67e8f9; font-size: 11px; text-transform: uppercase; letter-spacing: .5px; border-radius: 6px; cursor: pointer; font-weight: 600; transition: background .12s; }
.prod-btn:hover { background: rgba(34,211,238,.15); }
.prod-btn.primary { background: rgba(168,85,247,.1); border-color: #6d28d9; color: #c4b5fd; }
.prod-btn.primary:hover { background: rgba(168,85,247,.2); }
.prod-btn.danger  { background: rgba(239,68,68,.08); border-color: #7f1d1d; color: #f87171; }
.prod-btn.danger:hover { background: rgba(239,68,68,.15); }

/* ─── Sous-nav ─── */
.prod-subnav { display: flex; gap: 4px; background: #0b0f17; padding: 6px; border: 1px solid #1f2937; border-radius: 10px; margin-bottom: 20px; width: fit-content; flex-wrap: wrap; }
.prod-subnav-btn { background: transparent; border: none; color: #9ca3af; font-size: 12px; font-weight: 600; padding: 9px 18px; border-radius: 7px; cursor: pointer; transition: all .15s; letter-spacing: .2px; }
.prod-subnav-btn:hover { color: #fff; background: rgba(255,255,255,.03); }
.prod-subnav-btn.active { background: linear-gradient(135deg, #4c1d95, #6d28d9); color: #fff; box-shadow: 0 2px 12px rgba(109,40,217,.3); }

/* ─── KPI strip (reutilise de home mais scoped) ─── */
.prod-kpi-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-bottom: 22px; }
@media (max-width: 1100px) { .prod-kpi-strip { grid-template-columns: repeat(2, 1fr); } }
.prod-kpi { background: #0b0f17; border: 1px solid #1f2937; border-radius: 10px; padding: 18px 20px; position: relative; overflow: hidden; }
.prod-kpi .lbl { font-size: 10px; color: #6b7280; text-transform: uppercase; letter-spacing: 1px; }
.prod-kpi .val { font-size: 30px; font-weight: 800; color: #fff; font-family: ui-monospace, monospace; margin-top: 6px; line-height: 1; }
.prod-kpi .sub { font-size: 10px; color: #4b5563; margin-top: 6px; }
.prod-kpi.accent { border-color: #4c1d95; background: radial-gradient(ellipse at top right, rgba(168,85,247,.1), #0b0f17 70%); }
.prod-kpi.accent .val { color: #fbbf24; }
.prod-kpi.accent .lbl { color: #a5b4fc; }

.prod-block-head .count.ok { background: rgba(16,185,129,.1) !important; color: #34d399 !important; border-color: #065f46 !important; }

/* ─── Pipeline strip ─── */
.prod-pipeline { display: grid; grid-template-columns: repeat(6, 1fr); gap: 0; margin-bottom: 22px; background: #0b0f17; border: 1px solid #1f2937; border-radius: 12px; padding: 18px 8px; position: relative; }
@media (max-width: 1100px) { .prod-pipeline { grid-template-columns: repeat(3, 1fr); gap: 12px 0; } }
.prod-pipe-step { display: flex; flex-direction: column; align-items: center; padding: 0 10px; position: relative; }
.prod-pipe-step:not(:last-child)::after { content: '→'; position: absolute; right: -8px; top: 28px; color: #374151; font-size: 18px; font-weight: 700; }
@media (max-width: 1100px) { .prod-pipe-step::after { display: none !important; } }
.prod-pipe-icon { font-size: 22px; margin-bottom: 6px; filter: grayscale(.2); }
.prod-pipe-val { font-size: 24px; font-weight: 800; color: #fff; font-family: ui-monospace, monospace; line-height: 1; }
.prod-pipe-lbl { font-size: 9px; color: #6b7280; text-transform: uppercase; letter-spacing: .8px; margin-top: 4px; }
.prod-pipe-step.alert .prod-pipe-val { color: #f87171; }
.prod-pipe-step.warn  .prod-pipe-val { color: #fbbf24; }
.prod-pipe-step.ok    .prod-pipe-val { color: #34d399; }

/* ─── Agents compact row ─── */
.prod-agents-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-bottom: 22px; }
@media (max-width: 1100px) { .prod-agents-row { grid-template-columns: repeat(2, 1fr); } }
.prod-agent {
  background: linear-gradient(160deg, rgba(var(--ag-rgb),.08) 0%, #0b0f17 55%);
  border: 1px solid rgba(var(--ag-rgb),.25); border-radius: 14px; padding: 14px; position: relative; overflow: hidden;
  transition: transform .2s, border-color .2s, box-shadow .2s;
}
.prod-agent:hover { transform: translateY(-2px); border-color: rgba(var(--ag-rgb),.5); box-shadow: 0 6px 24px rgba(var(--ag-rgb),.15); }
.prod-agent.running { border-color: rgba(var(--ag-rgb),.6); animation: prodAgentPulse 1.5s ease-in-out infinite; }
@keyframes prodAgentPulse { 0%,100% { box-shadow: 0 0 0 0 rgba(var(--ag-rgb),.3); } 50% { box-shadow: 0 0 0 6px rgba(var(--ag-rgb),0); } }
.prod-agent-head { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.prod-agent-avatar { width: 42px; height: 42px; border-radius: 50%; background: rgba(var(--ag-rgb),.12); border: 1.5px solid rgba(var(--ag-rgb),.4); display: flex; align-items: center; justify-content: center; flex-shrink: 0; box-shadow: 0 0 12px rgba(var(--ag-rgb),.2); }
.prod-agent-avatar svg { width: 32px; height: 32px; }
.prod-agent-id { flex: 1; min-width: 0; }
.prod-agent-name { font-size: 12px; font-weight: 800; color: #fff; letter-spacing: .2px; }
.prod-agent-class { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.5px; color: rgba(var(--ag-rgb),.8); margin-top: 2px; }
.prod-agent-level { background: rgba(var(--ag-rgb),.2); border: 1px solid rgba(var(--ag-rgb),.4); border-radius: 6px; padding: 2px 8px; font-size: 11px; font-weight: 800; color: rgba(var(--ag-rgb),1); text-shadow: 0 0 6px rgba(var(--ag-rgb),.5); flex-shrink: 0; }
.prod-agent-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; margin-bottom: 10px; }
.prod-agent-stat { background: rgba(0,0,0,.25); border: 1px solid rgba(var(--ag-rgb),.1); border-radius: 8px; padding: 6px 4px; text-align: center; }
.prod-agent-stat .k { font-size: 8px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: #6b7280; }
.prod-agent-stat .v { font-size: 14px; font-weight: 800; color: #fff; font-family: ui-monospace, monospace; margin-top: 2px; }
.prod-agent-foot { display: flex; align-items: center; gap: 8px; }
.prod-agent-status { display: flex; align-items: center; gap: 5px; font-size: 10px; color: #9ca3af; flex: 1; }
.prod-agent-status .dot { width: 6px; height: 6px; border-radius: 50%; background: #4b5563; }
.prod-agent-status.running .dot { background: rgba(var(--ag-rgb),1); animation: prodDot 1s infinite; }
.prod-agent-status.error .dot { background: #ef4444; }
@keyframes prodDot { 0%,100% { box-shadow: 0 0 0 0 rgba(var(--ag-rgb),.5); } 50% { box-shadow: 0 0 0 4px rgba(var(--ag-rgb),0); } }
.prod-agent-btn { background: rgba(var(--ag-rgb),.15); border: 1px solid rgba(var(--ag-rgb),.3); color: rgba(var(--ag-rgb),1); font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .8px; padding: 5px 10px; border-radius: 6px; cursor: pointer; transition: background .12s; }
.prod-agent-btn:hover { background: rgba(var(--ag-rgb),.3); }

/* ─── Block générique ─── */
.prod-block { background: #0b0f17; border: 1px solid #1f2937; border-radius: 12px; padding: 18px 20px; margin-bottom: 14px; }
.prod-block-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 14px; }
.prod-block-head h2 { font-size: 13px; font-weight: 700; color: #fff; text-transform: uppercase; letter-spacing: .8px; }
.prod-block-head .sub { font-size: 10px; color: #6b7280; text-transform: uppercase; letter-spacing: .5px; }
.prod-block-head .count { font-size: 11px; color: #a855f7; font-weight: 700; padding: 2px 8px; background: rgba(168,85,247,.1); border: 1px solid #4c1d95; border-radius: 6px; }
.prod-empty { padding: 24px; text-align: center; color: #4b5563; font-size: 12px; }

.prod-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 14px; }
@media (max-width: 1100px) { .prod-grid-2 { grid-template-columns: 1fr; } }

/* ─── Grille references scrapées (Veille) ─── */
.prod-ref-filters { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; margin-bottom: 12px; }
.prod-ref-filter { padding: 6px 12px; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; background: #0b1020; border: 1px solid #1f2937; color: #9ca3af; border-radius: 20px; cursor: pointer; transition: all .12s; }
.prod-ref-filter:hover { border-color: #4c1d95; color: #c4b5fd; }
.prod-ref-filter.active { background: linear-gradient(135deg, #6d28d9, #7c3aed); border-color: #7c3aed; color: #fff; }
.prod-ref-acc-select { margin-left: auto; background: #0b1020; border: 1px solid #1f2937; color: #e5e7eb; padding: 6px 10px; border-radius: 6px; font-size: 11px; font-family: inherit; cursor: pointer; }
.prod-ref-acc-select:focus { outline: none; border-color: #7c3aed; }

.prod-ref-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 10px; }
.prod-ref-card { background: #060913; border: 1px solid #1f2937; border-radius: 10px; overflow: hidden; transition: border-color .12s, transform .12s; }
.prod-ref-card:hover { border-color: #7c3aed; transform: translateY(-2px); }
.prod-ref-card.used { opacity: .5; }
.prod-ref-thumb { position: relative; aspect-ratio: 4/5; background: #0a0a0f; cursor: pointer; overflow: hidden; }
.prod-ref-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.prod-ref-fb { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 28px; color: #4b5563; }
.prod-ref-play { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 36px; height: 36px; background: rgba(0,0,0,.65); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: #fff; font-size: 13px; pointer-events: none; }
.prod-ref-score { position: absolute; top: 6px; right: 6px; padding: 2px 7px; border-radius: 8px; font-size: 10px; font-weight: 800; font-family: ui-monospace, monospace; background: rgba(0,0,0,.75); }
.prod-ref-score.hi { color: #34d399; }
.prod-ref-score.mi { color: #fbbf24; }
.prod-ref-score.lo { color: #f87171; }
.prod-ref-used { position: absolute; top: 6px; left: 6px; padding: 2px 7px; border-radius: 8px; font-size: 9px; font-weight: 700; text-transform: uppercase; background: rgba(107,114,128,.85); color: #fff; }
.prod-ref-body { padding: 8px 10px; display: flex; flex-direction: column; gap: 6px; }
.prod-ref-acc { font-size: 11px; color: #fff; font-weight: 700; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.prod-ref-sub { font-size: 9px; color: #6b7280; font-family: ui-monospace, monospace; }
.prod-ref-use { width: 100%; padding: 6px 8px; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .4px; background: rgba(124,58,237,.1); border: 1px solid #4c1d95; color: #c4b5fd; border-radius: 6px; cursor: pointer; transition: all .12s; }
.prod-ref-use:hover { background: linear-gradient(135deg, #6d28d9, #7c3aed); color: #fff; }

.prod-gen-pending { padding: 8px 12px; background: rgba(124,58,237,.08); border: 1px solid #4c1d95; border-radius: 8px; font-size: 11px; color: #c4b5fd; font-weight: 600; }

/* ─── Génération manuelle ─── */
.prod-gen-wrap { display: flex; flex-direction: column; gap: 12px; padding: 4px 2px; }
.prod-gen-row { display: flex; flex-direction: column; gap: 6px; }
.prod-gen-lbl { font-size: 10px; color: #9ca3af; font-weight: 600; text-transform: uppercase; letter-spacing: .5px; }
.prod-gen-select, .prod-gen-input { background: #0b1020; border: 1px solid #1f2937; color: #e5e7eb; padding: 8px 10px; border-radius: 8px; font-size: 12px; font-family: inherit; transition: border-color .12s; }
.prod-gen-select:focus, .prod-gen-input:focus { outline: none; border-color: #7c3aed; }
.prod-gen-input { resize: vertical; }
.prod-gen-tabs { display: flex; gap: 6px; }
.prod-gen-tab { flex: 1; padding: 8px 12px; background: #0b1020; border: 1px solid #1f2937; color: #9ca3af; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; border-radius: 8px; cursor: pointer; transition: all .12s; }
.prod-gen-tab:hover { border-color: #4c1d95; color: #c4b5fd; }
.prod-gen-tab.active { background: linear-gradient(135deg, #6d28d9, #7c3aed); border-color: #7c3aed; color: #fff; }
.prod-gen-actions { display: flex; align-items: center; gap: 10px; }
.prod-gen-cost { font-size: 10px; color: #6b7280; }
.prod-gen-hint { font-size: 10px; color: #6b7280; font-style: italic; }
.prod-gen-status { min-height: 18px; font-size: 11px; font-weight: 600; padding: 6px 0; }
.prod-gen-status.busy { color: #fbbf24; }
.prod-gen-status.ok { color: #34d399; }
.prod-gen-status.err { color: #f87171; }
.prod-gen-status.busy::before { content: '● '; animation: prodGenPulse 1.4s ease-in-out infinite; }
@keyframes prodGenPulse { 0%,100% { opacity: 1; } 50% { opacity: .3; } }

/* ─── Validation queue ─── */
.prod-val-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 12px; }
.prod-val-card { background: #060913; border: 1px solid #1f2937; border-radius: 10px; overflow: hidden; transition: border-color .12s; }
.prod-val-card:hover { border-color: #4c1d95; }
.prod-val-thumb { width: 100%; aspect-ratio: 4/5; background: #111827; object-fit: cover; display: block; }
.prod-val-body { padding: 10px 12px; }
.prod-val-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; }
.prod-val-acc { font-size: 11px; color: #fff; font-weight: 700; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.prod-val-score { font-size: 11px; font-weight: 800; font-family: ui-monospace, monospace; padding: 2px 7px; border-radius: 8px; }
.prod-val-score.hi { background: rgba(16,185,129,.12); color: #34d399; }
.prod-val-score.mi { background: rgba(251,191,36,.12); color: #fbbf24; }
.prod-val-score.lo { background: rgba(239,68,68,.1); color: #f87171; }
.prod-val-cap { font-size: 10px; color: #9ca3af; line-height: 1.4; margin-bottom: 10px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.prod-val-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }
.prod-val-actions button { padding: 6px 8px; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; border-radius: 6px; cursor: pointer; border: 1px solid; transition: background .12s; }
.prod-val-ok { background: rgba(16,185,129,.08); border-color: #065f46; color: #34d399; }
.prod-val-ok:hover { background: rgba(16,185,129,.2); }
.prod-val-ko { background: rgba(239,68,68,.08); border-color: #7f1d1d; color: #f87171; }
.prod-val-ko:hover { background: rgba(239,68,68,.2); }

/* ─── Agents big cards (onglet Agents) ─── */
.prod-agents-big-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 18px; }
@media (max-width: 1100px) { .prod-agents-big-grid { grid-template-columns: repeat(2, 1fr); } }
.prod-agent-big {
  background: linear-gradient(160deg, rgba(var(--ag-rgb),.1) 0%, #0b0f17 55%);
  border: 1px solid rgba(var(--ag-rgb),.3); border-radius: 18px; padding: 22px 20px; position: relative; overflow: hidden;
  display: flex; flex-direction: column; align-items: center; text-align: center;
  animation: prodAgentBreathe 4s ease-in-out infinite;
}
@keyframes prodAgentBreathe { 0%,100% { box-shadow: 0 4px 20px rgba(var(--ag-rgb),.08); } 50% { box-shadow: 0 4px 32px rgba(var(--ag-rgb),.22); } }
.prod-agent-big.running { border-color: rgba(var(--ag-rgb),.7); animation: prodBigRun 1.2s ease-in-out infinite; }
@keyframes prodBigRun { 0%,100% { box-shadow: 0 4px 20px rgba(var(--ag-rgb),.25), 0 0 40px rgba(var(--ag-rgb),.12); } 50% { box-shadow: 0 8px 40px rgba(var(--ag-rgb),.45), 0 0 60px rgba(var(--ag-rgb),.22); } }
.prod-agent-big-head { display: flex; justify-content: space-between; align-items: center; width: 100%; margin-bottom: 12px; }
.prod-agent-big-avatar { width: 70px; height: 70px; border-radius: 50%; background: rgba(var(--ag-rgb),.12); border: 2px solid rgba(var(--ag-rgb),.5); display: flex; align-items: center; justify-content: center; box-shadow: 0 0 22px rgba(var(--ag-rgb),.25); }
.prod-agent-big-avatar svg { width: 56px; height: 56px; }
.prod-agent-big-level { background: rgba(var(--ag-rgb),.2); border: 1px solid rgba(var(--ag-rgb),.5); border-radius: 8px; padding: 5px 12px; font-size: 14px; font-weight: 800; color: rgba(var(--ag-rgb),1); text-shadow: 0 0 8px rgba(var(--ag-rgb),.5); }
.prod-agent-big-name { font-size: 17px; font-weight: 800; color: #fff; margin-bottom: 3px; }
.prod-agent-big-class { font-size: 10px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: rgba(var(--ag-rgb),.85); margin-bottom: 14px; }
.prod-xp-bar { width: 100%; height: 8px; background: rgba(0,0,0,.3); border-radius: 4px; overflow: hidden; margin-bottom: 4px; }
.prod-xp-bar-fill { height: 100%; background: linear-gradient(90deg, rgba(var(--ag-rgb),.6), rgba(var(--ag-rgb),1)); box-shadow: 0 0 10px rgba(var(--ag-rgb),.5); transition: width .6s; }
.prod-xp-txt { font-size: 9px; color: #6b7280; margin-bottom: 12px; letter-spacing: .3px; }
.prod-big-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; width: 100%; margin-bottom: 12px; }
.prod-big-stat { background: rgba(0,0,0,.25); border: 1px solid rgba(var(--ag-rgb),.15); border-radius: 10px; padding: 9px 4px; text-align: center; }
.prod-big-stat .k { font-size: 9px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: #6b7280; margin-bottom: 3px; }
.prod-big-stat .v { font-size: 18px; font-weight: 800; font-family: ui-monospace, monospace; line-height: 1; color: #fff; }
.prod-hp { width: 100%; margin-bottom: 12px; }
.prod-hp-head { display: flex; justify-content: space-between; font-size: 10px; color: #9ca3af; margin-bottom: 4px; }
.prod-hp-track { width: 100%; height: 5px; background: rgba(0,0,0,.3); border-radius: 3px; overflow: hidden; }
.prod-hp-fill { height: 100%; border-radius: 3px; transition: width .6s; }
.prod-big-foot { display: flex; align-items: center; justify-content: space-between; width: 100%; margin-bottom: 6px; }
.prod-big-schedule { font-size: 9px; color: #4b5563; }
.prod-big-last { font-size: 9px; color: #4b5563; text-align: center; margin-bottom: 12px; width: 100%; }
.prod-agent-big-btn { width: 100%; padding: 10px; border-radius: 10px; border: 1px solid rgba(var(--ag-rgb),.4); background: rgba(var(--ag-rgb),.1); color: rgba(var(--ag-rgb),1); font-size: 11px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; cursor: pointer; transition: all .15s; }
.prod-agent-big-btn:hover { background: rgba(var(--ag-rgb),.2); border-color: rgba(var(--ag-rgb),.6); box-shadow: 0 0 15px rgba(var(--ag-rgb),.25); }

/* ─── Validation meta pills ─── */
.prod-val-meta { display: flex; gap: 5px; margin-bottom: 8px; }
.prod-val-pill { font-size: 8px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; padding: 2px 6px; border-radius: 4px; background: rgba(107,114,128,.15); color: #9ca3af; border: 1px solid #1f2937; }

/* ─── Veille big list ─── */
.prod-comp-list-big .prod-comp-row { grid-template-columns: 40px 1fr auto 80px 70px auto 24px; padding: 12px; border-bottom: 1px solid #111827; border-radius: 0; }
.prod-comp-list-big .prod-comp-row .avatar { width: 40px; height: 40px; }
.prod-comp-list-big .prod-comp-row .u { font-size: 13px; }
.prod-comp-list-big .role-sub { font-size: 9px; color: #6b7280; text-transform: uppercase; letter-spacing: .5px; margin-top: 2px; }
.prod-comp-add select { background: #060913; border: 1px solid #1f2937; border-radius: 6px; padding: 8px 12px; color: #fff; font-size: 12px; font-family: inherit; cursor: pointer; }

/* ─── Comptes auto table ─── */
.prod-acc-table { display: flex; flex-direction: column; }
.prod-acc-row { display: grid; grid-template-columns: minmax(200px, 1.5fr) 80px 110px 90px 110px 80px 80px 36px; gap: 12px; align-items: center; padding: 10px 12px; border-bottom: 1px solid #111827; cursor: pointer; transition: background .12s; font-size: 11px; }
.prod-acc-row:hover { background: rgba(34,211,238,.04); }
.prod-acc-row.head { cursor: default; background: transparent; border-bottom: 1px solid #1f2937; padding-bottom: 8px; }
.prod-acc-row.head:hover { background: transparent; }
.prod-acc-row.head > div { font-size: 9px; color: #6b7280; text-transform: uppercase; letter-spacing: .8px; font-weight: 700; }
.prod-acc-user { display: flex; align-items: center; gap: 10px; min-width: 0; }
.prod-acc-user .avatar { width: 32px; height: 32px; border-radius: 50%; background: linear-gradient(135deg, #6366f1, #a855f7); overflow: hidden; flex-shrink: 0; position: relative; border: 1.5px solid #1e1b4b; }
.prod-acc-user .avatar img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.prod-acc-user .avatar .fb { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-weight: 800; color: #fff; font-size: 12px; }
.prod-acc-user .name { font-size: 12px; font-weight: 700; color: #fff; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.prod-acc-user .sub { font-size: 9px; color: #6b7280; margin-top: 1px; }
.prod-acc-pill { padding: 2px 7px; border-radius: 6px; font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .4px; display: inline-block; }
.prod-acc-pill.live { background: rgba(16,185,129,.1); color: #34d399; border: 1px solid #065f46; }
.prod-acc-pill.pause { background: rgba(107,114,128,.1); color: #9ca3af; border: 1px solid #374151; }
.prod-acc-pill.alert { background: rgba(239,68,68,.1); color: #f87171; border: 1px solid #7f1d1d; }
.prod-acc-stock { font-family: ui-monospace, monospace; font-size: 12px; color: #fff; font-weight: 700; }
.prod-acc-stock.lo { color: #f87171; }
.prod-acc-stock.mi { color: #fbbf24; }
.prod-acc-sub { font-size: 9px; color: #6b7280; margin-top: 1px; }
.prod-acc-chev { color: #4b5563; font-size: 14px; text-align: right; }

/* ─── Comptes auto big (onglet Comptes auto) ─── */
.prod-acc-row-big {
  display: grid;
  grid-template-columns: minmax(200px, 1.6fr) 90px 90px 110px 130px 110px 100px 70px 28px;
  gap: 12px; align-items: center; padding: 12px; border-bottom: 1px solid #111827;
  cursor: pointer; transition: background .12s; font-size: 11px;
}
.prod-acc-row-big:hover { background: rgba(34,211,238,.04); }
.prod-acc-row-big.head { cursor: default; background: transparent; border-bottom: 1px solid #1f2937; padding-bottom: 10px; }
.prod-acc-row-big.head:hover { background: transparent; }
.prod-acc-row-big.head > div { font-size: 9px; color: #6b7280; text-transform: uppercase; letter-spacing: .8px; font-weight: 700; }
.prod-acc-progress { display: flex; flex-direction: column; gap: 4px; }
.prod-acc-progress .pv { font-size: 13px; font-weight: 800; color: #fff; font-family: ui-monospace, monospace; line-height: 1; }
.prod-acc-progress .pbar { width: 100%; height: 4px; background: rgba(255,255,255,.05); border-radius: 2px; overflow: hidden; }
.prod-acc-progress .pfill { height: 100%; background: linear-gradient(90deg, #4c1d95, #a855f7); border-radius: 2px; transition: width .4s; }
.prod-acc-cell .v { font-size: 11px; color: #e5e7eb; font-weight: 600; font-family: ui-monospace, monospace; line-height: 1.2; }
.prod-acc-oneup { font-size: 10px; font-weight: 700; padding: 4px 8px; border-radius: 6px; text-align: center; letter-spacing: .3px; }
.prod-acc-oneup.ok { background: rgba(16,185,129,.1); color: #34d399; border: 1px solid #065f46; }
.prod-acc-oneup.ko { background: rgba(239,68,68,.08); color: #f87171; border: 1px solid #7f1d1d; }

/* ─── Runs feed ─── */
.prod-runs { display: flex; flex-direction: column; gap: 6px; max-height: 340px; overflow-y: auto; }
.prod-run-row { display: grid; grid-template-columns: 8px 80px 90px 1fr auto; gap: 10px; align-items: center; padding: 8px 10px; background: #060913; border: 1px solid #111827; border-radius: 6px; font-size: 11px; }
.prod-run-row .dot { width: 8px; height: 8px; border-radius: 50%; }
.prod-run-row .time { font-family: ui-monospace, monospace; font-size: 10px; color: #6b7280; }
.prod-run-row .agent { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; }
.prod-run-row .msg { color: #9ca3af; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.prod-run-row .pill { font-size: 9px; padding: 2px 7px; border-radius: 8px; text-transform: uppercase; letter-spacing: .5px; font-weight: 700; }
.prod-run-row .pill.ok  { background: rgba(16,185,129,.12); color: #34d399; border: 1px solid #065f46; }
.prod-run-row .pill.err { background: rgba(239,68,68,.1); color: #f87171; border: 1px solid #7f1d1d; }

/* ─── Anomalies ─── */
.prod-anom { display: flex; flex-direction: column; gap: 6px; max-height: 340px; overflow-y: auto; }
.prod-anom-row { display: grid; grid-template-columns: 18px 1fr auto; gap: 10px; align-items: center; padding: 8px 10px; background: #060913; border: 1px solid #111827; border-left: 3px solid #7f1d1d; border-radius: 6px; font-size: 11px; cursor: pointer; transition: border-color .12s; }
.prod-anom-row:hover { border-left-color: #ef4444; }
.prod-anom-row.warn { border-left-color: #78350f; }
.prod-anom-row.warn:hover { border-left-color: #fbbf24; }
.prod-anom-row .sev { font-weight: 800; color: #f87171; text-align: center; }
.prod-anom-row.warn .sev { color: #fbbf24; }
.prod-anom-row .txt { color: #e5e7eb; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.prod-anom-row .acc { color: #fff; font-weight: 700; }
.prod-anom-row .tag { font-size: 9px; padding: 2px 7px; border-radius: 6px; background: rgba(107,114,128,.1); color: #9ca3af; text-transform: uppercase; letter-spacing: .5px; }

/* ─── Concurrents veille ─── */
.prod-comp { display: flex; flex-direction: column; }
.prod-comp-add { display: flex; gap: 8px; margin-bottom: 12px; }
.prod-comp-add input { flex: 1; background: #060913; border: 1px solid #1f2937; border-radius: 6px; padding: 8px 12px; color: #fff; font-size: 12px; font-family: inherit; }
.prod-comp-add input:focus { outline: none; border-color: #4c1d95; }
.prod-comp-list { display: flex; flex-direction: column; gap: 4px; max-height: 420px; overflow-y: auto; }
.prod-comp-row { display: grid; grid-template-columns: 32px 1fr auto auto 24px; gap: 10px; align-items: center; padding: 8px 10px; border-radius: 6px; transition: background .12s; }
.prod-comp-row:hover { background: rgba(34,211,238,.04); }
.prod-comp-row.failing { background: rgba(239,68,68,.05); }
.prod-comp-row .avatar { width: 32px; height: 32px; border-radius: 50%; overflow: hidden; background: linear-gradient(135deg, #6366f1, #a855f7); position: relative; border: 1.5px solid #1e1b4b; }
.prod-comp-row .avatar img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.prod-comp-row .avatar .fb { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-weight: 800; color: #fff; font-size: 12px; }
.prod-comp-row .u { font-size: 12px; color: #fff; font-weight: 600; }
.prod-comp-row .refs { font-size: 10px; color: #9ca3af; font-family: ui-monospace, monospace; }
.prod-comp-row .score { font-size: 11px; font-weight: 800; font-family: ui-monospace, monospace; min-width: 40px; text-align: right; }
.prod-comp-row .del { background: none; border: none; color: #4b5563; cursor: pointer; font-size: 14px; padding: 2px 6px; border-radius: 4px; transition: all .12s; }
.prod-comp-row .del:hover { color: #ef4444; background: rgba(239,68,68,.1); }
.prod-comp-row .fail-tag { font-size: 8px; font-weight: 700; padding: 2px 5px; border-radius: 4px; background: rgba(239,68,68,.15); color: #f87171; letter-spacing: .3px; }
