/* ZYRAN V6.3.3 — Editions spécialisées durcies */
/* Bloc historique stabilisé */
:root {
  --blue: #1e40af;
  --blue-2: #2563eb;
  --blue-soft: #eff6ff;
  --green: #059669;
  --green-soft: #dcfce7;
  --orange: #f97316;
  --orange-soft: #ffedd5;
  --violet: #7c3aed;
  --violet-soft: #ede9fe;
  --cyan: #06b6d4;
  --cyan-soft: #cffafe;
  --red: #e11d48;
  --red-soft: #ffe4e6;
  --bg: #f3f7fc;
  --panel: #ffffff;
  --text: #0f172a;
  --muted: #64748b;
  --soft-text: #7c8ba1;
  --line: #dbe5f1;
  --shadow: 0 16px 38px rgba(15, 23, 42, .070);
  --shadow-soft: 0 10px 24px rgba(15, 23, 42, .055);
  --radius: 22px;
  --radius-sm: 16px;
  --sidebar: 278px;
  --topbar: 76px;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
}

* { box-sizing: border-box; }
html, body { min-height: 100%; }
body {
  margin: 0;
  color: var(--text);
  background: radial-gradient(circle at 35% 0%, #ffffff 0, #f8fbff 28%, var(--bg) 74%);
  overflow: hidden;
}
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }
img { max-width: 100%; }

.zyran-app { display: grid; grid-template-columns: var(--sidebar) minmax(0, 1fr); min-height: 100vh; }
.sidebar {
  background: rgba(255, 255, 255, .86);
  border-right: 1px solid var(--line);
  box-shadow: 12px 0 36px rgba(15, 23, 42, .045);
  min-width: 0;
  position: sticky;
  top: 0;
  height: 100vh;
  overflow-y: auto;
  z-index: 30;
}

body.sidebar-collapsed .zyran-app { grid-template-columns: 1fr; }
body.sidebar-collapsed .sidebar {
  position: fixed;
  inset: 0 auto 0 0;
  width: min(310px, 86vw);
  transform: translateX(-105%);
  transition: transform .22s ease;
}
body.sidebar-collapsed .sidebar.open { transform: translateX(0); }
body.sidebar-collapsed .mobile-menu { display: inline-grid; }
body.sidebar-collapsed .view { padding-left: 30px; padding-right: 30px; }

.sidebar-brand { height: var(--topbar); display: flex; align-items: center; gap: 12px; padding: 14px 18px; border-bottom: 1px solid var(--line); }
.brand-mark { width: 38px; height: 38px; border-radius: 13px; background: #eef4ff; display: grid; place-items: center; overflow: hidden; flex: 0 0 auto; }
.brand-mark img { width: 28px; height: 28px; object-fit: contain; }
.brand-title { color: var(--blue); font-weight: 950; letter-spacing: .05em; font-size: 24px; line-height: 1; }
.brand-sub { color: #577091; font-size: 10px; font-weight: 850; letter-spacing: .10em; margin-top: 3px; white-space: nowrap; }
.icon-btn {
  width: 40px;
  height: 40px;
  border-radius: 13px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--blue);
  font-weight: 900;
  display: inline-grid;
  place-items: center;
  box-shadow: var(--shadow-soft);
}
.icon-btn.ghost { border: 0; box-shadow: none; background: transparent; color: #31547a; }
.mobile-menu { display: none; }
.side-nav { padding: 14px; }
.nav-section-title { font-size: 11px; font-weight: 950; color: #8294ae; letter-spacing: .12em; text-transform: uppercase; margin: 22px 8px 8px; }
.nav-item {
  width: 100%;
  border: 0;
  border-radius: 12px;
  background: transparent;
  color: #314767;
  padding: 12px 12px;
  display: flex;
  align-items: center;
  gap: 12px;
  text-align: start;
  font-weight: 780;
  margin-bottom: 5px;
}
.nav-item:hover { background: #f5f9ff; color: var(--blue); }
.nav-item.active { background: #eaf2ff; color: var(--blue); box-shadow: inset 3px 0 0 var(--cyan); }
.nav-ico { width: 24px; text-align: center; font-size: 17px; }
.nav-label { flex: 1; }
.badge-mini { display: inline-flex; align-items: center; padding: 3px 8px; border-radius: 999px; font-size: 10px; font-weight: 950; background: #dbeafe; color: var(--blue); }
.badge-mini.beta { background: var(--violet-soft); color: var(--violet); }
.badge-mini.pro { background: var(--orange-soft); color: #c2410c; }
.badge-mini.soon { background: #f1f5f9; color: #64748b; }
.badge-mini.lab { background: var(--cyan-soft); color: #0284c7; }

.app-area { min-width: 0; height: 100vh; display: grid; grid-template-rows: var(--topbar) minmax(0, 1fr); }
.topbar {
  background: rgba(255, 255, 255, .90);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--line);
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 12px 22px;
  gap: 14px;
  position: sticky;
  top: 0;
  z-index: 20;
}
.topbar h1 { margin: 0; text-align: center; font-size: 21px; font-weight: 950; letter-spacing: -.02em; color: #0b244c; }
.top-actions { justify-self: end; display: flex; align-items: center; gap: 10px; flex-wrap: nowrap; }
.primary-top {
  border: 0;
  color: #fff;
  background: linear-gradient(135deg, var(--blue), var(--blue-2));
  box-shadow: 0 16px 34px rgba(30, 64, 175, .22);
  border-radius: 12px;
  padding: 12px 18px;
  font-weight: 950;
}
.currency-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 64px;
  padding: 10px 14px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--blue);
  box-shadow: var(--shadow-soft);
  font-weight: 950;
  letter-spacing: .03em;
}
.segmented { display: inline-flex; padding: 4px; border: 1px solid var(--line); border-radius: 14px; background: #fff; box-shadow: var(--shadow-soft); gap: 4px; }
.segmented button { border: 0; border-radius: 10px; background: transparent; color: #61718a; padding: 8px 12px; font-weight: 900; font-size: 13px; }
.segmented button.active { color: #fff; background: var(--blue); box-shadow: 0 8px 20px rgba(30,64,175,.18); }
.view { padding: 28px 34px 34px; overflow-y: auto; min-width: 0; }
.view-inner { max-width: 1440px; margin: 0 auto; }

.hero { margin: 0 0 22px; }
.hero h2 { margin: 0; color: #0b244c; font-size: clamp(30px, 3.1vw, 48px); letter-spacing: -.06em; line-height: 1; }
.hero p { margin: 10px 0 0; color: var(--muted); font-size: 16px; }
.dashboard-kpis { display: grid; grid-template-columns: repeat(4, minmax(160px, 1fr)); gap: 18px; margin: 22px 0 28px; }
.stat-card, .module-card, .card, .mini-card, .info-strip {
  background: rgba(255, 255, 255, .94);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.stat-card { padding: 22px; display: flex; align-items: center; gap: 18px; min-height: 126px; }
.stat-icon, .module-icon, .round-icon {
  width: 58px;
  height: 58px;
  border-radius: 22px;
  display: grid;
  place-items: center;
  font-size: 25px;
  flex: 0 0 auto;
  border: 1px solid rgba(30,64,175,.08);
}
.stat-icon.blue, .module-icon.blue, .round-icon.blue { background: var(--blue-soft); color: var(--blue); }
.stat-icon.green, .module-icon.green, .round-icon.green { background: var(--green-soft); color: var(--green); }
.stat-icon.orange, .module-icon.orange, .round-icon.orange { background: var(--orange-soft); color: var(--orange); }
.stat-icon.violet, .module-icon.violet, .round-icon.violet { background: var(--violet-soft); color: var(--violet); }
.stat-icon.cyan, .module-icon.cyan, .round-icon.cyan { background: var(--cyan-soft); color: #0284c7; }
.stat-icon.red, .module-icon.red, .round-icon.red { background: var(--red-soft); color: var(--red); }
.stat-value { font-size: 31px; font-weight: 950; letter-spacing: -.06em; line-height: 1; color: var(--blue); }
.stat-label { color: #657894; margin-top: 4px; font-weight: 700; }
.stat-trend { color: var(--green); font-size: 12px; font-weight: 850; margin-top: 14px; }
.section-title { font-size: 21px; margin: 0 0 16px; color: #1d2b4f; letter-spacing: -.03em; }
.modules-grid { display: grid; grid-template-columns: repeat(4, minmax(220px, 1fr)); gap: 18px; }
.module-card { min-height: 162px; padding: 20px; display: grid; grid-template-rows: auto 1fr auto; gap: 14px; text-align: start; border: 1px solid var(--line); transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease; }
.module-card:hover { transform: translateY(-2px); border-color: #bfdbfe; box-shadow: 0 20px 48px rgba(30,64,175,.10); }
.module-card button, button.module-card { cursor: pointer; }
.module-card:hover { transform: translateY(-2px); box-shadow: 0 18px 42px rgba(15, 23, 42, .10); }
.module-card.featured { border-color: #94b8ff; box-shadow: 0 16px 44px rgba(30,64,175,.12); }
.module-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.module-title { font-size: 16px; font-weight: 950; color: #15233f; }
.module-desc { color: #71839d; line-height: 1.45; font-size: 13px; }
.card-action { margin-top: 8px; display: flex; align-items: center; justify-content: space-between; gap: 12px; color: var(--blue); font-weight: 950; }
.card-action.muted-action { color: #64748b; }
.card-cta { width: 100%; border: 0; border-radius: 12px; background: var(--blue); color: #fff; padding: 11px 14px; font-weight: 950; display: flex; justify-content: space-between; align-items: center; }
.info-strip { margin-top: 18px; padding: 14px 18px; display: flex; align-items: center; justify-content: space-between; gap: 18px; color: #314767; }
.info-strip b { color: var(--blue); }

.page-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; margin-bottom: 20px; }
.page-head h2 { margin: 0; color: #0b244c; font-size: 34px; letter-spacing: -.05em; }
.page-head p { margin: 7px 0 0; color: var(--muted); }
.kpi-row { display: grid; grid-template-columns: repeat(4, minmax(170px, 1fr)); gap: 16px; margin-bottom: 18px; }
.kpi-card { padding: 18px; min-height: 100px; display: flex; align-items: center; gap: 16px; }
.kpi-value { display: block; color: var(--blue); font-size: 25px; font-weight: 950; letter-spacing: -.04em; margin-top: 4px; }
.kpi-label { color: #556986; font-weight: 850; }
.workspace { display: grid; grid-template-columns: minmax(0, 1.15fr) 420px; gap: 18px; align-items: start; }
.left-stack, .right-stack { display: grid; gap: 16px; }
.top-formulation-row { display: grid; grid-template-columns: minmax(0, 1.3fr) minmax(340px, .9fr); gap: 18px; margin-bottom: 18px; align-items: start; }
.compact-card { padding: 18px; }
.compact-form-lines { grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }
.compact-field-group { display: grid; gap: 8px; align-content: start; }
.compact-field-group label { color: #455a78; font-weight: 820; font-size: 13px; }
.compact-badge-row { min-height: 42px; display: flex; align-items: center; }
.card { padding: 20px; }
.card h3 { margin: 0 0 16px; font-size: 17px; color: #13213b; display: flex; align-items: center; gap: 9px; }
.form-lines { display: grid; gap: 12px; }
.form-line { display: grid; grid-template-columns: 92px minmax(0, 1fr); gap: 10px; align-items: center; }
.form-line label { color: #455a78; font-weight: 820; font-size: 13px; }
.field, .table-input, .select-input {
  width: 100%;
  border: 1px solid #cad8eb;
  border-radius: 12px;
  background: #fff;
  color: var(--text);
  padding: 10px 12px;
  outline: none;
}
.field:focus, .table-input:focus, .select-input:focus { border-color: var(--blue); box-shadow: 0 0 0 4px rgba(30, 64, 175, .10); }
.badge { display: inline-flex; align-items: center; justify-content: center; gap: 5px; border-radius: 999px; padding: 5px 11px; font-size: 12px; font-weight: 950; background: var(--violet-soft); color: var(--violet); width: fit-content; }
.actions-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.action-btn {
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 14px;
  color: var(--blue);
  font-weight: 950;
  padding: 13px 10px;
  text-align: start;
  min-height: 58px;
  box-shadow: var(--shadow-soft);
}
.action-btn.green { color: var(--green); }
.action-btn.orange { color: var(--orange); }
.action-btn.red { color: var(--red); }
.action-btn:hover { background: #f8fbff; transform: translateY(-1px); }
.center-card { min-width: 0; }
.card-title-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.card-title-row h3 { margin: 0; }
.secondary-btn, .small-btn, .danger-btn {
  border: 1px solid #bfdbfe;
  border-radius: 12px;
  background: #fff;
  color: var(--blue);
  padding: 10px 13px;
  font-weight: 950;
}
.danger-btn { color: var(--red); border-color: #fecdd3; }
.table-wrap { width: 100%; overflow: auto; border: 1px solid var(--line); border-radius: 18px; }
table { width: 100%; border-collapse: separate; border-spacing: 0; font-size: 13px; }
th { background: #f4f8ff; color: #344764; text-align: start; font-size: 11px; letter-spacing: .05em; text-transform: uppercase; }
th, td { padding: 12px; border-bottom: 1px solid var(--line); vertical-align: middle; }
tr:last-child td { border-bottom: 0; }
td { background: #fff; }
tr:hover td { background: #fbfdff; }
.edit-table { min-width: 650px; }
.table-input { min-width: 100px; padding: 9px 11px; }
.table-input.percent { padding-right: 30px; }
.input-wrap { position: relative; }
.input-wrap span { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); color: var(--muted); font-weight: 850; }
.row-actions { display: flex; gap: 8px; align-items: center; }
.icon-mini { width: 34px; height: 34px; border: 1px solid #bfdbfe; background: #fff; color: var(--blue); border-radius: 11px; font-weight: 950; }
.icon-mini.danger { color: var(--red); border-color: #fecdd3; }
.total-line { display: flex; justify-content: space-between; align-items: center; padding: 12px; border-top: 1px solid var(--line); background: #f8fbff; font-weight: 950; color: var(--blue); }
.alert-box { border-radius: 16px; padding: 14px; border: 1px solid transparent; margin-bottom: 9px; line-height: 1.4; }
.alert-box.ok { background: var(--green-soft); border-color: #86efac; color: #047857; }
.alert-box.warning { background: var(--orange-soft); border-color: #fed7aa; color: #9a3412; }
.alert-box.danger { background: var(--red-soft); border-color: #fecdd3; color: #9f1239; }
.nutrient-row { display: grid; grid-template-columns: 94px minmax(0,1fr) auto; gap: 12px; align-items: center; margin-bottom: 14px; }
.nutrient-row b { color: #263c5f; font-size: 13px; }
.nutrient-row span { color: var(--blue); font-weight: 850; font-size: 13px; white-space: nowrap; }
.progress { height: 8px; border-radius: 999px; background: #e2e8f0; overflow: hidden; }
.progress i { display: block; height: 100%; border-radius: 999px; background: linear-gradient(90deg, var(--blue), var(--cyan)); }
.progress i.warn { background: var(--orange); }
.progress i.danger { background: var(--red); }
.tip-card { margin-top: 18px; padding: 16px 20px; display: flex; align-items: center; gap: 14px; }
.tip-card p { margin: 0; color: #435878; }
.tip-card b { color: var(--blue); }

.simple-grid { display: grid; grid-template-columns: repeat(3, minmax(260px, 1fr)); gap: 18px; }
.data-table { min-width: 850px; }
.placeholder { padding: 30px; text-align: center; color: var(--muted); }
.muted { color: var(--muted); }
.small-note { font-size: 12px; color: var(--soft-text); line-height: 1.45; }
.report-card { display: grid; gap: 10px; padding: 16px; border-radius: 16px; background: #f8fbff; border: 1px solid var(--line); }
.formula-list { display: grid; gap: 10px; }
.formula-tile { border: 1px solid var(--line); background: #fff; border-radius: 14px; padding: 12px; display: flex; justify-content: space-between; gap: 12px; align-items: center; }
.formula-tile b { color: #0b244c; }

.toast { position: fixed; right: 24px; bottom: 24px; transform: translateY(18px); opacity: 0; pointer-events: none; background: #0f172a; color: #fff; border-radius: 16px; padding: 12px 16px; box-shadow: 0 20px 55px rgba(15,23,42,.22); z-index: 80; transition: .22s ease; max-width: min(480px, 92vw); }
.toast.show { opacity: 1; transform: translateY(0); }
.toast.ok { background: var(--green); }
.toast.danger { background: var(--red); }
.modal { position: fixed; inset: 0; background: rgba(15,23,42,.52); display: none; place-items: center; padding: 20px; z-index: 90; }
.modal.open { display: grid; }
.modal-card { width: min(820px, 96vw); max-height: 86vh; overflow: auto; background: #fff; border-radius: 24px; padding: 24px; box-shadow: 0 28px 78px rgba(15,23,42,.30); }
.modal-head { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-bottom: 16px; }
.modal-head h3 { margin: 0; font-size: 22px; }
.close-modal { width: 38px; height: 38px; border: 0; border-radius: 12px; background: var(--blue-soft); color: var(--blue); font-size: 22px; }
body.dark {
  --bg: #0f172a;
  --panel: #111c2f;
  --text: #e5eefc;
  --muted: #a9b8cf;
  --soft-text: #8ba0bd;
  --line: rgba(148, 163, 184, .22);
  background: #0f172a;
}
body.dark .sidebar, body.dark .topbar, body.dark .stat-card, body.dark .module-card, body.dark .card, body.dark .mini-card, body.dark .info-strip, body.dark td, body.dark .field, body.dark .table-input, body.dark .select-input, body.dark .segmented, body.dark .icon-btn, body.dark .secondary-btn, body.dark .action-btn, body.dark .currency-pill { background: #111c2f; color: var(--text); }
body.dark th, body.dark .total-line { background: #17243a; }
body.dark .balance-table th { background: #17243a; }
body.dark .balance-table td { background: #111c2f; }
body.dark .balance-danger td, body.dark .balance-warn td, body.dark .balance-watch td { background: #162034; }
body.dark .hero h2, body.dark .page-head h2, body.dark .topbar h1, body.dark .module-title, body.dark .card h3 { color: #f4f8ff; }



.template-strip { display:grid; grid-template-columns: minmax(260px, 1fr) minmax(260px, 420px) auto; gap:14px; align-items:center; margin-bottom:18px; }
.template-strip h3 { margin-bottom:4px; }

.top-inline-actions { display:flex; gap:10px; flex-wrap:wrap; align-items:center; }
.premix-layout { display:grid; grid-template-columns: 280px minmax(0,1fr); gap:18px; align-items:start; }
.premix-left-card, .premix-main-card { min-width:0; }
.premix-left-fields { display:grid; gap:14px; }
.premix-field { display:grid; gap:8px; }
.premix-field label { color:#6b7f9d; font-size:12px; font-weight:850; text-transform:uppercase; letter-spacing:.04em; }
.inset-card { background:#fbfdff; border:1px solid var(--line); box-shadow:none; }
.premix-summary { margin-top:18px; }
.mini-lines { display:grid; gap:12px; }
.mini-lines div { display:flex; align-items:center; justify-content:space-between; gap:12px; }
.mini-lines span { color:#64748b; }
.mini-lines b { color:var(--blue); }
.premix-tabs { display:flex; gap:8px; flex-wrap:wrap; padding-bottom:14px; margin-bottom:18px; border-bottom:1px solid var(--line); }
.premix-tab { border:1px solid var(--line); background:#f8fbff; color:#375173; border-radius:12px; padding:10px 14px; font-weight:900; }
.premix-tab.active { background:#eef4ff; color:var(--blue); border-color:#bfdbfe; }
.premix-tab-body { display:grid; gap:16px; }
.premix-results-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
.textarea-field { min-height:140px; resize:vertical; }


.balance-table-wrap { width: 100%; overflow: auto; border: 1px solid var(--line); border-radius: 16px; }
.balance-table { min-width: 760px; width: 100%; border-collapse: separate; border-spacing: 0; font-size: 12px; }
.compact-report-table { min-width: 620px; }
.balance-table th { background: #f4f8ff; color: #344764; text-align: start; font-size: 10px; letter-spacing: .06em; text-transform: uppercase; white-space: nowrap; }
.balance-table th, .balance-table td { padding: 11px 12px; border-bottom: 1px solid var(--line); vertical-align: middle; }
.balance-table tr:last-child td { border-bottom: 0; }
.balance-table td:first-child b { display: block; color: #0f2c5a; font-size: 13px; }
.balance-table td:first-child span { display: block; color: var(--muted); margin-top: 2px; }
.balance-table strong { color: #0f172a; }
.status-pill { display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; padding: 4px 9px; font-size: 11px; font-weight: 950; white-space: nowrap; }
.status-pill.ok { background: var(--green-soft); color: #047857; }
.status-pill.danger { background: var(--red-soft); color: var(--red); }
.status-pill.warn { background: var(--orange-soft); color: #c2410c; }
.status-pill.watch { background: var(--cyan-soft); color: #0284c7; }
.balance-ok td { background: #effaf3; }
.balance-danger td { background: #fff4f4; }
.balance-warn td { background: #fff8ed; }
.balance-watch td { background: #f7feff; }
.nutrient-balance-card { min-width: 0; }
.nutrient-balance-card .muted { color: var(--muted); }

@media (max-width: 1240px) {
  .dashboard-kpis, .modules-grid, .kpi-row { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .top-formulation-row, .workspace, .premix-layout, .template-strip { grid-template-columns: 1fr; }
  .compact-form-lines { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .right-stack, .premix-results-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 980px) {
  body { overflow: auto; }
  .zyran-app { grid-template-columns: 1fr; }
  .sidebar { position: fixed; inset: 0 auto 0 0; width: min(310px, 86vw); transform: translateX(-105%); transition: transform .2s ease; }
  .sidebar.open { transform: translateX(0); }
  .app-area { height: auto; min-height: 100vh; }
  .mobile-menu { display: inline-grid; }
  .topbar { grid-template-columns: auto 1fr; align-items: center; }
  .topbar h1 { text-align: start; }
  .top-actions { grid-column: 1 / -1; justify-self: start; flex-wrap: wrap; }
  .view { overflow: visible; padding: 22px 16px; }
}
@media (max-width: 720px) {
  .dashboard-kpis, .modules-grid, .kpi-row, .simple-grid, .right-stack, .compact-form-lines, .premix-results-grid { grid-template-columns: 1fr; }
  .stat-card { min-height: auto; }
  .page-head { align-items: flex-start; flex-direction: column; }
  .actions-grid { grid-template-columns: 1fr; }
  .brand-sub { white-space: normal; }
}
@media print {
  .sidebar, .topbar, .toast, .modal, .page-head .secondary-btn, .actions-grid, .tip-card { display: none !important; }
  body { overflow: auto; background: #fff; }
  .zyran-app, .app-area { display: block; height: auto; }
  .view { padding: 0; overflow: visible; }
  .card, .stat-card, .module-card { box-shadow: none; break-inside: avoid; }
}

/* Référentiel nutritionnel */
.formula-nutrients-card { margin-top: 18px; }
.formula-nutrients-card .card-title-row { align-items: flex-start; }
.balance-table-wrap.full { border-radius: 18px; }
.formula-output-table { min-width: 1180px; font-size: 12px; }
.formula-output-table th:nth-child(9), .formula-output-table td:nth-child(9) { min-width: 260px; }
.snapshot-list { display: grid; gap: 9px; }
.snapshot-row { display: flex; justify-content: space-between; gap: 12px; align-items: center; border: 1px solid var(--line); background: #f8fbff; border-radius: 12px; padding: 9px 10px; }
.snapshot-row span { color: #526b8e; font-weight: 900; }
.snapshot-row b { color: var(--blue); font-size: 13px; text-align: right; }
.status-pill.neutral { background: #eef2f7; color: #475569; }
.contrib-chip { display: inline-flex; gap: 5px; align-items: center; margin: 2px 4px 2px 0; padding: 4px 7px; border-radius: 999px; background: #eff6ff; color: #28456f; border: 1px solid #dbeafe; white-space: nowrap; }
.contrib-chip b { color: var(--blue); }
.balance-neutral td { background: #fff; }
body.dark .snapshot-row, body.dark .contrib-chip { background: #17243a; border-color: rgba(148,163,184,.22); }
body.dark .status-pill.neutral { background: #263247; color: #cbd5e1; }

body.sidebar-collapsed .topbar .mobile-menu{display:inline-grid;}


/* Bloc formulation historique stabilisé */
.formulation-view .page-head { margin-bottom: 12px; }
.formulation-view .kpi-row { margin-bottom: 12px; }
.compact-top-row { margin-bottom: 12px; }
.compact-template-strip { margin-bottom: 12px; padding: 14px 16px; display: grid; grid-template-columns: minmax(0, 1fr) minmax(240px, 340px) auto; gap: 12px; align-items: center; }
.formulation-dual-grid { display: grid; grid-template-columns: minmax(560px, 1.36fr) minmax(430px, .86fr); gap: 14px; align-items: start; }
.formula-edit-panel, .side-by-side-nutrients { min-width: 0; align-self: start; }
.formula-edit-panel { padding: 14px; }
.side-by-side-nutrients { padding: 14px; margin-top: 0 !important; }
.side-by-side-nutrients .card-title-row { margin-bottom: 10px; }
.side-by-side-nutrients .card-title-row p { display: none; }
.side-by-side-nutrients h3 { font-size: 15px; }
.formulation-view .edit-table { min-width: 620px; font-size: 12px; }
.formulation-view .edit-table th,
.formulation-view .edit-table td { padding: 7px 8px; }
.formulation-view .select-input,
.formulation-view .table-input { min-width: 0; padding: 7px 8px; height: 32px; font-size: 12px; }
.formulation-view .input-wrap span { right: 8px; }
.formulation-view .secondary-btn { padding: 8px 10px; }
.formulation-view .balance-table-wrap.full { border-radius: 10px; max-height: 620px; overflow: auto; }
.formulation-view .formula-output-table,
.formulation-view .compact-report-table { min-width: 480px !important; font-size: 11px; }
.formulation-view .formula-output-table th,
.formulation-view .formula-output-table td { padding: 7px 8px; text-align: center; }
.formulation-view .formula-output-table td:first-child,
.formulation-view .formula-output-table th:first-child { text-align: left; min-width: 130px; }
.formulation-view .formula-output-table td:first-child b { font-size: 12px; }
.formulation-view .formula-output-table td:first-child span { font-size: 10px; margin-top: 1px; }
.formulation-view .status-pill { padding: 3px 7px; font-size: 10px; }
.formulation-alerts-strip { margin-top: 12px; padding: 14px 16px; }
.formulation-alerts-strip .alert-box { display: inline-flex; margin: 4px 6px 4px 0; }
body.sidebar-collapsed .zyran-app { grid-template-columns: 1fr; }
body.sidebar-collapsed .mobile-menu { display: inline-grid; }

@media (max-width: 1180px) {
  .formulation-dual-grid { grid-template-columns: 1fr; }
  .side-by-side-nutrients .balance-table-wrap.full { max-height: none; }
  .compact-template-strip { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .formulation-view .edit-table { min-width: 560px; }
  .formulation-view .formula-output-table,
  .formulation-view .compact-report-table { min-width: 520px !important; }
}

/* Bloc formulation historique stabilisé */
body.sidebar-collapsed .zyran-app{grid-template-columns:1fr!important;}
body.sidebar-collapsed .sidebar{position:fixed!important;left:0!important;top:0!important;width:min(310px,86vw)!important;transform:translateX(-105%)!important;transition:transform .18s ease!important;z-index:100!important;}
body.sidebar-collapsed .sidebar.open{transform:translateX(0)!important;}
body.sidebar-collapsed .app-area{grid-column:1/-1!important;}
body.sidebar-collapsed .view{padding-left:22px!important;padding-right:22px!important;}
body.sidebar-collapsed .mobile-menu{display:inline-grid!important;}
.formulation-dual-grid .formula-edit-panel{min-width:0;}
.formulation-dual-grid .side-by-side-nutrients{min-width:0;}


/* Bloc formulation historique stabilisé */
.expert-bottom-grid { display:grid; grid-template-columns: minmax(0,1fr) minmax(340px,.8fr); gap:14px; margin-top:12px; align-items:start; }
.audit-grid { display:grid; grid-template-columns: repeat(6, minmax(0,1fr)); gap:8px; margin-top:10px; }
.audit-metric { border:1px solid var(--line); background:#f8fbff; border-radius:14px; padding:10px 9px; display:grid; gap:4px; min-height:62px; }
.audit-metric span { color:#64748b; font-size:11px; font-weight:800; }
.audit-metric b { color:#0f172a; font-size:15px; }
.audit-metric.ok { background:#effaf3; border-color:#bbf7d0; }
.audit-metric.warn { background:#fff8ed; border-color:#fed7aa; }
.audit-metric.danger { background:#fff4f4; border-color:#fecaca; }
.audit-metric.neutral { background:#f8fafc; }
.optimization-summary { margin-top:12px; border-top:1px solid var(--line); padding-top:12px; }
.optimization-summary h4 { margin:0 0 8px; font-size:14px; }
.optimization-summary details { margin-top:8px; }
.optimization-summary summary { cursor:pointer; color:var(--blue); font-weight:850; }
.optimization-summary li { margin:4px 0; color:#334155; }
.fixed-cell { width:42px; text-align:center !important; }
.fixed-cell input { width:16px; height:16px; accent-color:var(--blue); }
.cost-cell { text-align:right !important; color:#0f172a; font-weight:850; white-space:nowrap; }
.formulation-view .edit-table { min-width: 720px; }
.formulation-view .edit-table th:nth-child(1), .formulation-view .edit-table td:nth-child(1) { width:44px; }
.formulation-view .edit-table th:nth-child(5), .formulation-view .edit-table td:nth-child(5) { width:94px; }
@media (max-width: 1180px) { .expert-bottom-grid { grid-template-columns:1fr; } .audit-grid { grid-template-columns: repeat(3, minmax(0,1fr)); } }
@media (max-width: 720px) { .audit-grid { grid-template-columns: repeat(2, minmax(0,1fr)); } }
body.dark .audit-metric { background:#101a2b; border-color:rgba(148,163,184,.18); }
body.dark .audit-metric b, body.dark .optimization-summary li { color:#e2e8f0; }

/* Espace expert formulation : rail gauche + double tableau */
body.sidebar-collapsed .zyran-app{
  grid-template-columns: 74px minmax(0,1fr) !important;
}
body.sidebar-collapsed .sidebar{
  position: sticky !important;
  left: 0 !important;
  top: 0 !important;
  width: 74px !important;
  min-width: 74px !important;
  height: 100vh !important;
  transform: none !important;
  z-index: 80 !important;
  overflow-x: hidden !important;
  transition: width .18s ease, box-shadow .18s ease !important;
}
body.sidebar-collapsed .sidebar.open{
  position: fixed !important;
  width: min(310px,86vw) !important;
  min-width: min(310px,86vw) !important;
  transform: none !important;
  box-shadow: var(--shadow-lg) !important;
}
body.sidebar-collapsed .app-area{
  grid-column: auto !important;
}
body.sidebar-collapsed .sidebar-brand{
  justify-content: center !important;
  padding: 12px 8px !important;
}
body.sidebar-collapsed .sidebar .brand-mark{ width:34px; height:34px; }
body.sidebar-collapsed .sidebar .brand-copy,
body.sidebar-collapsed .sidebar .nav-section-title,
body.sidebar-collapsed .sidebar .nav-label,
body.sidebar-collapsed .sidebar .badge-mini{
  display: none !important;
}
body.sidebar-collapsed .sidebar.open .brand-copy,
body.sidebar-collapsed .sidebar.open .nav-section-title,
body.sidebar-collapsed .sidebar.open .nav-label,
body.sidebar-collapsed .sidebar.open .badge-mini{
  display: initial !important;
}
body.sidebar-collapsed .sidebar.open .nav-section-title{ display:block!important; }
body.sidebar-collapsed .side-nav{ padding: 16px 8px !important; }
body.sidebar-collapsed .nav-item{
  justify-content: center !important;
  grid-template-columns: 1fr !important;
  min-height: 48px !important;
  padding: 12px 8px !important;
}
body.sidebar-collapsed .sidebar.open .nav-item{
  justify-content: start !important;
  grid-template-columns: 24px 1fr auto !important;
  padding: 12px 14px !important;
}
body.sidebar-collapsed .nav-ico{ margin:auto; }
body.sidebar-collapsed .sidebar.open .nav-ico{ margin:0; }
body.sidebar-collapsed .view{
  padding: 22px 28px 34px !important;
}
body.sidebar-collapsed .mobile-menu{ display:inline-grid!important; }

.phase1-workspace{ max-width: 100%; }
.phase1-titlebar{
  display:flex; align-items:center; justify-content:space-between; gap:16px; margin-bottom:16px;
}
.phase1-titlebar h2{ font-size:26px; letter-spacing:-.03em; margin:0; color:#0b2b62; }
.phase1-titlebar p{ margin:4px 0 0; color:var(--muted); font-weight:650; }
.phase1-title-actions{ display:flex; gap:10px; flex-wrap:wrap; }
.phase1-kpis{ grid-template-columns: repeat(4, minmax(0,1fr)); margin-bottom:16px; }
.phase1-control-strip{
  display:grid; grid-template-columns: minmax(280px, 1fr) auto minmax(380px, .9fr); gap:14px; align-items:end; margin-bottom:16px; padding:16px 18px;
}
.phase1-control-main label{ display:block; font-size:11px; font-weight:900; color:#6b7f9d; text-transform:uppercase; letter-spacing:.06em; margin-bottom:7px; }
.phase1-control-meta{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.phase1-control-meta span{ display:grid; gap:3px; min-width:96px; padding:9px 12px; border:1px solid var(--line); border-radius:14px; background:#f8fbff; font-size:12px; color:#0f2c5a; }
.phase1-control-meta b{ color:#6b7f9d; font-size:10px; text-transform:uppercase; letter-spacing:.06em; }
.phase1-template{ display:grid; grid-template-columns:minmax(0,1fr) auto; gap:10px; }
.phase1-dual-grid{
  grid-template-columns: minmax(680px, 1.18fr) minmax(520px, .82fr) !important;
  gap: 16px !important;
  align-items: start;
}
.formula-edit-panel,.formula-nutrients-card{ min-width:0; }
.phase1-formula-wrap{ overflow:auto; border:1px solid var(--line); border-radius:16px; }
.phase1-formula-table{ min-width: 820px !important; font-size:12px !important; }
.phase1-formula-table th{ background:#f4f8ff; color:#344764; text-transform:uppercase; letter-spacing:.055em; font-size:10px; white-space:nowrap; }
.phase1-formula-table th,.phase1-formula-table td{ padding:8px 9px!important; vertical-align:middle; }
.phase1-formula-table .ingredient-select{ min-width: 172px; }
.phase1-formula-table .compact-price{ width:110px; }
.phase1-formula-table .compact-percent{ min-width:116px; }
.phase1-formula-table .compact-bound{ width:78px; }
.phase1-formula-table .cost-cell{ font-weight:900; color:#0b3f91; text-align:right; white-space:nowrap; }
.phase1-total-line{ display:grid!important; grid-template-columns:1fr auto auto; gap:18px; align-items:center; padding:10px 14px!important; background:#f8fbff; }
.phase1-total-line strong{ color:#0b55c9; font-size:16px; }
.side-by-side-nutrients .card-title-row{ align-items:start; margin-bottom:10px; }
.side-by-side-nutrients .card-title-row h3{ font-size:17px; }
.side-by-side-nutrients .small-note{ font-size:12px; }
.side-by-side-nutrients .balance-table-wrap.full{ max-height: 612px !important; border-radius:16px; }
.side-by-side-nutrients .balance-table{ min-width: 610px !important; font-size:12px; }
.side-by-side-nutrients .balance-table th,
.side-by-side-nutrients .balance-table td{ padding:9px 10px; }
.side-by-side-nutrients .balance-table td:first-child b{ font-size:12px; }
.status-pill{ min-width:86px; justify-content:center; }
.phase1-bottom-grid{ grid-template-columns: minmax(0,1fr) minmax(460px,.9fr) !important; gap:16px !important; margin-top:16px; }
.phase1-actions-card .actions-grid{ grid-template-columns: repeat(4, minmax(0,1fr)); }
.phase1-actions-grid .action-btn{ min-height:102px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:4px; }
.phase1-actions-grid .action-btn b{ font-size:13px; }
.phase1-actions-grid .action-btn span{ color:var(--muted); font-size:11px; line-height:1.25; }
.phase1-audit{ margin-top:16px; }
.panel-actions{ display:flex; gap:8px; flex-wrap:wrap; }
.formulation-view .top-formulation-row,
.formulation-view .template-strip.compact-template-strip{ display:none!important; }

@media (max-width: 1360px){
  .phase1-dual-grid{ grid-template-columns: minmax(600px,1fr) minmax(460px,.82fr)!important; }
  .phase1-control-strip{ grid-template-columns: 1fr; align-items:stretch; }
  .phase1-template{ grid-template-columns:1fr auto; }
}
@media (max-width: 1120px){
  body.sidebar-collapsed .zyran-app{ grid-template-columns: 1fr!important; }
  body.sidebar-collapsed .sidebar{ position:fixed!important; transform:translateX(-105%)!important; width:min(310px,86vw)!important; }
  body.sidebar-collapsed .sidebar.open{ transform:translateX(0)!important; }
  .phase1-dual-grid,.phase1-bottom-grid{ grid-template-columns:1fr!important; }
  .phase1-kpis{ grid-template-columns:repeat(2,minmax(0,1fr)); }
  .phase1-actions-card .actions-grid{ grid-template-columns:repeat(2,minmax(0,1fr)); }
}
@media (max-width: 720px){
  .phase1-titlebar{ flex-direction:column; align-items:flex-start; }
  .phase1-kpis,.phase1-actions-card .actions-grid{ grid-template-columns:1fr; }
  .phase1-template{ grid-template-columns:1fr; }
  body.sidebar-collapsed .view{ padding:16px!important; }
}


/* UX stabilisée */
body.sidebar-collapsed .zyran-app{
  grid-template-columns: 68px minmax(0,1fr) !important;
}
body.sidebar-collapsed .sidebar{
  position: sticky !important;
  top:0 !important;
  left:0 !important;
  width:68px !important;
  min-width:68px !important;
  max-width:68px !important;
  transform:none !important;
  overflow-x:hidden !important;
  z-index:90 !important;
}
body.sidebar-collapsed .sidebar.open{
  position:fixed !important;
  width:min(312px,88vw) !important;
  min-width:min(312px,88vw) !important;
  max-width:min(312px,88vw) !important;
  transform:none !important;
  box-shadow: 18px 0 54px rgba(15,23,42,.18) !important;
}
body.sidebar-collapsed .app-area{ grid-column:auto !important; min-width:0 !important; }
body.sidebar-collapsed .mobile-menu{ display:inline-grid !important; }
body.sidebar-collapsed .sidebar:not(.open) .sidebar-brand .icon-btn.ghost{ display:none !important; }
body.sidebar-collapsed .sidebar:not(.open) .sidebar-brand{ justify-content:center !important; padding:12px 6px !important; }
body.sidebar-collapsed .sidebar:not(.open) .brand-copy,
body.sidebar-collapsed .sidebar:not(.open) .nav-section-title,
body.sidebar-collapsed .sidebar:not(.open) .nav-label,
body.sidebar-collapsed .sidebar:not(.open) .badge-mini{ display:none !important; }
body.sidebar-collapsed .sidebar:not(.open) .side-nav{ padding:12px 6px !important; }
body.sidebar-collapsed .sidebar:not(.open) .nav-item{ justify-content:center !important; padding:12px 6px !important; min-height:48px !important; gap:0 !important; }
body.sidebar-collapsed .sidebar:not(.open) .nav-ico{ margin:auto !important; width:auto !important; }
body.sidebar-collapsed .sidebar.open .sidebar-brand{ justify-content:flex-start !important; padding:14px 18px !important; }
body.sidebar-collapsed .sidebar.open .brand-copy,
body.sidebar-collapsed .sidebar.open .nav-label,
body.sidebar-collapsed .sidebar.open .badge-mini{ display:block !important; }
body.sidebar-collapsed .sidebar.open .nav-section-title{ display:block !important; }
body.sidebar-collapsed .view{ padding:22px 26px 34px !important; }
body.sidebar-collapsed .topbar{ grid-template-columns:auto 1fr auto !important; }
body.sidebar-collapsed .topbar h1{ text-align:left !important; }

.phase2-actions-toolbar{ margin:0 0 16px; padding:16px 18px; }
.phase2-actions-toolbar .card-title-row.compact{ display:flex; align-items:flex-end; justify-content:space-between; gap:12px; margin-bottom:12px; }
.phase2-actions-toolbar h3{ margin:0; }
.phase2-actions-toolbar .small-note{ margin:0; color:#64748b; }
.phase2-actions-toolbar .actions-grid{ grid-template-columns: repeat(4,minmax(0,1fr)) !important; }
.phase2-actions-toolbar .action-btn{ min-height:76px !important; }
.phase2-actions-toolbar .action-btn br{ display:none; }
.phase2-actions-toolbar .action-btn b{ display:block; margin-top:3px; }
.phase2-actions-toolbar .action-btn span{ font-size:11px; color:#64748b; }
.phase1-bottom-grid.diagnostic-only-grid{ grid-template-columns:minmax(0,1fr) 360px !important; }
.formulation-price-note p{ margin:0; color:#475569; line-height:1.5; }
.formulation-price-note b{ color:var(--blue); }
.phase1-formula-table .price-input{ width:118px !important; text-align:right; font-variant-numeric:tabular-nums; }
.phase1-formula-table .cost-cell{ font-variant-numeric:tabular-nums; min-width:96px; }
.phase1-formula-table th:nth-child(2), .phase1-formula-table td:nth-child(2){ min-width:128px; }
.phase1-formula-table th:nth-child(7), .phase1-formula-table td:nth-child(7){ min-width:118px; }

.phase2-premix-workspace{ max-width:100%; }
.phase2-premix-workspace .premix-head{ align-items:center; margin-bottom:14px; }
.premix-topbar{ display:grid; grid-template-columns: minmax(220px,.9fr) minmax(260px,1fr) 160px minmax(280px,1fr); gap:12px; align-items:end; padding:16px 18px; margin-bottom:14px; }
.premix-summary-strip{ display:grid; grid-template-columns: repeat(5,minmax(0,1fr)); gap:12px; padding:14px 18px; margin-bottom:14px; }
.premix-summary-strip div{ border-right:1px solid var(--line); padding-right:12px; display:grid; gap:4px; }
.premix-summary-strip div:last-child{ border-right:0; }
.premix-summary-strip span{ color:#64748b; font-size:12px; font-weight:800; }
.premix-summary-strip b{ color:#0b3f91; font-size:16px; }
.ok-text{ color:var(--green)!important; }
.phase2-premix-grid{ display:grid !important; grid-template-columns: 250px minmax(560px,1fr) 320px !important; gap:16px !important; align-items:start; }
.phase2-premix-summary{ min-width:0; }
.phase2-premix-main{ min-width:0; }
.phase2-premix-main .data-table{ min-width:720px; }
.phase2-premix-results{ min-width:0; }
.phase2-premix-results h3{ margin-bottom:14px; }
.phase2-premix-results .textarea-field{ min-height:116px; }
.phase2-premix-actions{ margin-top:16px; }
.phase2-premix-actions .actions-grid{ grid-template-columns: repeat(3,minmax(0,1fr)) !important; }
.phase2-premix-actions .action-btn{ min-height:82px; }
.premix-view .table-wrap{ overflow:auto; }
.premix-view .table-input{ min-height:38px; }

@media (max-width: 1380px){
  .phase2-premix-grid{ grid-template-columns: 230px minmax(520px,1fr) 300px !important; }
  .premix-topbar{ grid-template-columns: repeat(2,minmax(0,1fr)); }
}
@media (max-width: 1180px){
  .phase2-actions-toolbar .actions-grid{ grid-template-columns:repeat(2,minmax(0,1fr)) !important; }
  .phase1-bottom-grid.diagnostic-only-grid{ grid-template-columns:1fr !important; }
  .phase2-premix-grid{ grid-template-columns:1fr !important; }
  .premix-summary-strip{ grid-template-columns: repeat(2,minmax(0,1fr)); }
}
@media (max-width: 760px){
  body.sidebar-collapsed .zyran-app{ grid-template-columns:1fr !important; }
  body.sidebar-collapsed .sidebar{ position:fixed !important; transform:translateX(-105%) !important; width:min(312px,88vw) !important; max-width:min(312px,88vw) !important; }
  body.sidebar-collapsed .sidebar.open{ transform:none !important; }
  .phase2-actions-toolbar .actions-grid,
  .phase2-premix-actions .actions-grid,
  .premix-topbar,
  .premix-summary-strip{ grid-template-columns:1fr !important; }
}

/* Prix & Besoins */
.price-workspace .page-head, .needs-workspace .page-head { margin-bottom: 18px; }
.price-kpi-grid { display:grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; margin-bottom: 16px; }
.mini-kpi { padding: 18px 20px; }
.mini-kpi span { display:block; color: var(--muted); font-weight: 800; font-size: 12px; text-transform: uppercase; letter-spacing: .04em; }
.mini-kpi b { display:block; margin-top: 6px; color: var(--blue); font-size: 22px; line-height:1.15; }
.price-table-card { overflow:hidden; }
.price-matrix { min-width: 1120px; }
.price-matrix th { white-space: nowrap; }
.price-matrix td { vertical-align: middle; }
.price-input { min-width: 120px; font-weight: 850; }
.price-group-row td { font-weight: 950; text-transform: uppercase; letter-spacing: .06em; font-size: 12px; padding: 10px 14px !important; border-top: 2px solid var(--line); }
.price-group-row small { text-transform: none; letter-spacing: 0; margin-left: 10px; color: var(--muted); font-weight: 750; }
.group-dot { display:inline-block; width:10px; height:10px; border-radius:999px; margin-right:8px; background: var(--blue); }
.price-group-organic td { background: #f0fdf4 !important; color: #166534; }
.price-group-cmv td { background: #eef2ff !important; color: #3730a3; }
.price-group-mineral td { background: #fff7ed !important; color: #9a3412; }
.price-group-amino td { background: #fdf2f8 !important; color: #9d174d; }
.price-row-organic td { background: rgba(240,253,244,.45); }
.price-row-cmv td { background: rgba(238,242,255,.55); }
.price-row-mineral td { background: rgba(255,247,237,.50); }
.price-row-amino td { background: rgba(253,242,248,.50); }
.group-badge { display:inline-flex; align-items:center; padding:4px 10px; border-radius:999px; font-size:11px; font-weight:950; white-space:nowrap; }
.group-organic { background:#dcfce7; color:#166534; }
.group-cmv { background:#e0e7ff; color:#3730a3; }
.group-mineral { background:#ffedd5; color:#9a3412; }
.group-amino { background:#fce7f3; color:#9d174d; }
.group-other { background:#e2e8f0; color:#475569; }
.info-strip { display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-top:16px; padding:16px 18px; }
.needs-current-card { margin-bottom: 16px; }
.needs-formula-select { max-width: 460px; }
.ref-library-head { margin-bottom: 16px; }
.ref-species-block { margin-bottom: 18px; }
.ref-species-block > h3 { margin: 0 0 10px; color: #0b244c; display:flex; align-items:center; gap:10px; }
.ref-species-block > h3 span { font-size: 12px; color: var(--blue); background:#eaf2ff; padding:4px 10px; border-radius:999px; }
.ref-grid { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.ref-card { background:#fff; border:1px solid var(--line); border-radius:18px; box-shadow: var(--shadow-soft); overflow:hidden; }
.ref-card-head { display:flex; justify-content:space-between; gap:12px; align-items:flex-start; padding:14px 16px; border-bottom:1px solid var(--line); background: linear-gradient(180deg,#ffffff,#f8fbff); }
.ref-card-head b { display:block; color:#0b244c; }
.ref-card-head span { display:block; color:var(--blue); font-weight:850; margin-top:2px; }
.ref-card-head small { display:block; color:var(--muted); margin-top:2px; }
.table-wrap.mini { max-height: 320px; overflow:auto; }
.table-wrap.mini table { min-width: 520px; font-size: 12px; }
.table-wrap.mini td:first-child span { display:block; color:var(--muted); font-size:11px; }
@media (max-width: 1240px) {
  .price-kpi-grid, .ref-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 720px) {
  .price-kpi-grid, .ref-grid { grid-template-columns: 1fr; }
  .needs-formula-select { max-width: 100%; }
}

/* === ZYRAN bloc historique : affichage, sidebar unique, anti-overflow === */
html, body { overflow-x: hidden !important; }
:root { --rail: 66px; }
.zyran-app, .app-area, .view, .card, .table-wrap { min-width: 0 !important; }
body.sidebar-collapsed .zyran-app {
  display: grid !important;
  grid-template-columns: var(--rail) minmax(0, 1fr) !important;
  min-width: 0 !important;
}
body.sidebar-collapsed .sidebar {
  position: sticky !important;
  top: 0 !important;
  left: 0 !important;
  width: var(--rail) !important;
  max-width: var(--rail) !important;
  min-width: var(--rail) !important;
  height: 100vh !important;
  transform: none !important;
  z-index: 20 !important;
  overflow-x: hidden !important;
  background: rgba(255,255,255,.96) !important;
}
body.sidebar-collapsed .sidebar.open {
  position: fixed !important;
  width: min(292px, 86vw) !important;
  max-width: min(292px, 86vw) !important;
  min-width: min(292px, 86vw) !important;
  transform: none !important;
  z-index: 120 !important;
  box-shadow: 24px 0 60px rgba(15,23,42,.18) !important;
}
body.sidebar-collapsed .sidebar:not(.open) .brand-copy,
body.sidebar-collapsed .sidebar:not(.open) .nav-section-title,
body.sidebar-collapsed .sidebar:not(.open) .nav-label,
body.sidebar-collapsed .sidebar:not(.open) .badge-mini { display: none !important; }
body.sidebar-collapsed .sidebar:not(.open) .sidebar-brand { height: var(--topbar) !important; justify-content: center !important; padding: 10px 6px !important; gap: 0 !important; }
body.sidebar-collapsed .sidebar:not(.open) .sidebar-brand .icon-btn.ghost { display: none !important; }
body.sidebar-collapsed .sidebar:not(.open) .brand-mark { width: 36px !important; height: 36px !important; }
body.sidebar-collapsed .sidebar:not(.open) .side-nav { padding: 12px 6px !important; }
body.sidebar-collapsed .sidebar:not(.open) .nav-item { justify-content: center !important; min-height: 48px !important; padding: 12px 6px !important; gap: 0 !important; }
body.sidebar-collapsed .sidebar:not(.open) .nav-ico { margin: auto !important; }
body.sidebar-collapsed .sidebar.open .brand-copy,
body.sidebar-collapsed .sidebar.open .nav-label,
body.sidebar-collapsed .sidebar.open .badge-mini,
body.sidebar-collapsed .sidebar.open .nav-section-title { display: block !important; }
body.sidebar-collapsed .sidebar.open .sidebar-brand { justify-content: flex-start !important; padding: 14px 18px !important; gap: 12px !important; }
body.sidebar-collapsed .sidebar.open .sidebar-brand .icon-btn.ghost { display: inline-grid !important; }
body.sidebar-collapsed .app-area { grid-column: auto !important; width: 100% !important; min-width: 0 !important; }
body.sidebar-collapsed .topbar { grid-template-columns: auto minmax(0, 1fr) auto !important; }
body.sidebar-collapsed .topbar .mobile-menu { display: inline-grid !important; }
body.sidebar-collapsed .topbar h1 { text-align: left !important; min-width: 0 !important; }
body.sidebar-collapsed .view { padding: 18px 20px 34px !important; min-width: 0 !important; }
.phase1-dual-grid { display: grid !important; grid-template-columns: minmax(0, 1.14fr) minmax(390px, .86fr) !important; gap: 16px !important; align-items: start !important; min-width: 0 !important; }
.phase1-dual-grid > .card { min-width: 0 !important; overflow: hidden !important; }
.phase1-formula-wrap, .balance-table-wrap { overflow: auto !important; max-width: 100% !important; }
.phase1-formula-table { min-width: 720px !important; font-size: 11.5px !important; }
.phase1-formula-table th, .phase1-formula-table td { padding: 7px 8px !important; }
.phase1-formula-table .ingredient-select { min-width: 145px !important; }
.phase1-formula-table .price-input { width: 100px !important; }
.phase1-formula-table .compact-percent { min-width: 94px !important; }
.phase1-formula-table .compact-bound { width: 70px !important; }
.formula-output-table, .compact-report-table, .balance-table { min-width: 560px !important; font-size: 11.5px !important; }
.phase2-actions-toolbar { margin: 0 0 14px !important; }
.phase2-actions-toolbar .actions-grid { grid-template-columns: repeat(4, minmax(0,1fr)) !important; }
.phase2-actions-toolbar .action-btn { min-height: 66px !important; padding: 10px !important; }
.phase1-bottom-grid.diagnostic-only-grid { grid-template-columns: minmax(0,1fr) 340px !important; }
.price-workspace .page-head { margin-top: 0 !important; }
.price-matrix { min-width: 960px !important; }
.price-table-card .table-wrap { overflow:auto !important; }
.premix-view .page-head { margin-top: 0 !important; }
.phase2-premix-grid { grid-template-columns: 230px minmax(0,1fr) 300px !important; gap: 14px !important; }
.phase2-premix-grid > .card { min-width: 0 !important; }
.phase2-premix-main .data-table { min-width: 650px !important; }
.premix-view .table-input[data-field="unit"] { min-width: 118px !important; }
.segmented [data-value="AR"] { display:none !important; }
@media (max-width: 1180px){
  .phase1-dual-grid, .phase1-bottom-grid.diagnostic-only-grid, .phase2-premix-grid { grid-template-columns: 1fr !important; }
}
@media (max-width: 760px){
  body.sidebar-collapsed .zyran-app { grid-template-columns: 1fr !important; }
  body.sidebar-collapsed .sidebar:not(.open) { transform: translateX(-105%) !important; position: fixed !important; }
  body.sidebar-collapsed .view { padding: 14px !important; }
  .phase2-actions-toolbar .actions-grid { grid-template-columns: repeat(2, minmax(0,1fr)) !important; }
}


/* === ZYRAN : Module Espèces & Stades === */
.species-workspace .page-head { margin-bottom: 18px; }
.species-kpi-grid { display:grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap:14px; margin-bottom:16px; }
.species-control-card { margin-bottom:16px; }
.species-grid { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:16px; margin-bottom:18px; }
.species-card { overflow:hidden; border-top:4px solid #1e40af; }
.species-card.species-avian { border-top-color:#1e40af; }
.species-card.species-ruminant { border-top-color:#059669; }
.species-card.species-aqua { border-top-color:#06b6d4; }
.species-card.species-other { border-top-color:#7c3aed; }
.species-card-head { display:flex; justify-content:space-between; gap:12px; align-items:flex-start; margin-bottom:12px; }
.species-card-head h3 { margin:0; color:#0b244c; }
.species-card-head p { margin:4px 0 0; color:var(--muted); font-weight:650; }
.species-chip { display:inline-flex; padding:6px 10px; border-radius:999px; background:#eaf2ff; color:var(--blue); font-size:12px; font-weight:950; white-space:nowrap; }
.species-strains { display:flex; align-items:center; gap:8px; flex-wrap:wrap; padding:10px 12px; background:#f8fbff; border:1px solid var(--line); border-radius:14px; margin-bottom:12px; color:#334155; }
.species-strains span { display:inline-flex; padding:4px 9px; border-radius:999px; background:#fff; border:1px solid var(--line); color:#0b3f91; font-size:12px; font-weight:800; }
.species-stage-table { min-width:620px; }
.species-reference-table { min-width:900px; }
.species-reference-table td:nth-child(5) { color:var(--muted); font-size:12px; }
@media (max-width: 1240px) { .species-kpi-grid, .species-grid { grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width: 760px) { .species-kpi-grid, .species-grid { grid-template-columns: 1fr; } }


/* Layout stabilisé */
html, body {
  width: 100% !important;
  max-width: 100vw !important;
  overflow-x: hidden !important;
}
body {
  overflow: hidden !important;
}
.zyran-app {
  width: 100% !important;
  max-width: 100vw !important;
  height: 100vh !important;
  overflow: hidden !important;
}
.app-area {
  width: auto !important;
  max-width: 100% !important;
  min-width: 0 !important;
  overflow: hidden !important;
}
.view {
  width: auto !important;
  max-width: 100% !important;
  min-width: 0 !important;
  overflow-x: hidden !important;
  overflow-y: auto !important;
}
.view-inner,
.formulation-view,
.premix-view,
.price-workspace,
.species-workspace,
.needs-workspace {
  max-width: 100% !important;
  min-width: 0 !important;
}
.table-wrap,
.phase1-formula-wrap,
.balance-table-wrap,
.price-table-card .table-wrap {
  max-width: 100% !important;
  min-width: 0 !important;
  overflow: auto !important;
}
body:not(.sidebar-collapsed) .zyran-app {
  grid-template-columns: var(--sidebar) minmax(0, 1fr) !important;
}
body:not(.sidebar-collapsed) .sidebar,
body:not(.sidebar-collapsed) .sidebar.open {
  position: sticky !important;
  top: 0 !important;
  left: 0 !important;
  width: var(--sidebar) !important;
  max-width: var(--sidebar) !important;
  min-width: var(--sidebar) !important;
  height: 100vh !important;
  transform: none !important;
  z-index: 30 !important;
  overflow-x: hidden !important;
}
body:not(.sidebar-collapsed) .mobile-menu {
  display: none !important;
}
body.sidebar-collapsed .zyran-app {
  grid-template-columns: var(--rail) minmax(0, 1fr) !important;
}
body.sidebar-collapsed .app-area {
  grid-column: auto !important;
  width: auto !important;
  max-width: 100% !important;
  min-width: 0 !important;
}
body.sidebar-collapsed .sidebar {
  position: sticky !important;
  top: 0 !important;
  left: 0 !important;
  width: var(--rail) !important;
  max-width: var(--rail) !important;
  min-width: var(--rail) !important;
  height: 100vh !important;
  transform: none !important;
  z-index: 35 !important;
  overflow-x: hidden !important;
}
body.sidebar-collapsed .sidebar.open {
  position: fixed !important;
  inset: 0 auto 0 0 !important;
  width: min(292px, 86vw) !important;
  max-width: min(292px, 86vw) !important;
  min-width: min(292px, 86vw) !important;
  transform: none !important;
  z-index: 120 !important;
  box-shadow: 24px 0 60px rgba(15,23,42,.18) !important;
}
body.sidebar-collapsed .sidebar:not(.open) .brand-copy,
body.sidebar-collapsed .sidebar:not(.open) .nav-section-title,
body.sidebar-collapsed .sidebar:not(.open) .nav-label,
body.sidebar-collapsed .sidebar:not(.open) .badge-mini {
  display: none !important;
}
body.sidebar-collapsed .sidebar:not(.open) .sidebar-brand {
  justify-content: center !important;
  padding: 10px 6px !important;
  gap: 0 !important;
}
body.sidebar-collapsed .sidebar:not(.open) .sidebar-brand .icon-btn.ghost {
  display: none !important;
}
body.sidebar-collapsed .sidebar:not(.open) .side-nav {
  padding: 12px 6px !important;
}
body.sidebar-collapsed .sidebar:not(.open) .nav-item {
  grid-template-columns: 1fr !important;
  justify-content: center !important;
  padding: 12px 6px !important;
  gap: 0 !important;
}
body.sidebar-collapsed .sidebar:not(.open) .nav-ico {
  margin: auto !important;
}
body.sidebar-collapsed .sidebar.open .brand-copy,
body.sidebar-collapsed .sidebar.open .nav-section-title,
body.sidebar-collapsed .sidebar.open .nav-label,
body.sidebar-collapsed .sidebar.open .badge-mini {
  display: block !important;
}
body.sidebar-collapsed .sidebar.open .nav-item {
  grid-template-columns: 24px 1fr auto !important;
  justify-content: start !important;
  padding: 12px 14px !important;
}
body.sidebar-collapsed .sidebar.open .nav-ico {
  margin: 0 !important;
}
body.sidebar-collapsed .topbar {
  grid-template-columns: auto minmax(0, 1fr) auto !important;
}
body.sidebar-collapsed .topbar .mobile-menu {
  display: inline-grid !important;
}
.phase1-dual-grid,
.phase2-premix-grid,
.phase1-bottom-grid.diagnostic-only-grid {
  max-width: 100% !important;
  min-width: 0 !important;
}
@media (max-width: 980px) {
  body {
    overflow: auto !important;
  }
  .zyran-app,
  body:not(.sidebar-collapsed) .zyran-app,
  body.sidebar-collapsed .zyran-app {
    grid-template-columns: 1fr !important;
    height: auto !important;
    min-height: 100vh !important;
    overflow-x: hidden !important;
    overflow-y: visible !important;
  }
  .app-area {
    min-height: 100vh !important;
    height: auto !important;
  }
  .view {
    overflow: visible !important;
    padding: 16px !important;
  }
  .sidebar,
  body:not(.sidebar-collapsed) .sidebar,
  body.sidebar-collapsed .sidebar,
  body.sidebar-collapsed .sidebar:not(.open) {
    position: fixed !important;
    inset: 0 auto 0 0 !important;
    width: min(310px, 86vw) !important;
    max-width: min(310px, 86vw) !important;
    min-width: min(310px, 86vw) !important;
    transform: translateX(-105%) !important;
    z-index: 120 !important;
  }
  .sidebar.open,
  body:not(.sidebar-collapsed) .sidebar.open,
  body.sidebar-collapsed .sidebar.open {
    transform: translateX(0) !important;
  }
  .sidebar.open .brand-copy,
  .sidebar.open .nav-section-title,
  .sidebar.open .nav-label,
  .sidebar.open .badge-mini {
    display: block !important;
  }
  .sidebar.open .nav-item {
    grid-template-columns: 24px 1fr auto !important;
    justify-content: start !important;
  }
  .mobile-menu,
  body:not(.sidebar-collapsed) .mobile-menu,
  body.sidebar-collapsed .topbar .mobile-menu {
    display: inline-grid !important;
  }
  .topbar {
    grid-template-columns: auto minmax(0, 1fr) !important;
  }
}


/* Layout stabilisé */
body.sidebar-collapsed {
  overflow: hidden !important;
}
@media (min-width: 761px) {
  html, body {
    width: 100% !important;
    max-width: 100vw !important;
    overflow: hidden !important;
  }
  .zyran-app,
  body.sidebar-collapsed .zyran-app,
  body:not(.sidebar-collapsed) .zyran-app {
    display: grid !important;
    grid-template-columns: var(--sidebar) minmax(0, 1fr) !important;
    width: 100% !important;
    max-width: 100vw !important;
    height: 100vh !important;
    min-height: 100vh !important;
    overflow: hidden !important;
  }
  .sidebar,
  .sidebar.open,
  body.sidebar-collapsed .sidebar,
  body.sidebar-collapsed .sidebar.open,
  body.sidebar-collapsed .sidebar:not(.open),
  body:not(.sidebar-collapsed) .sidebar,
  body:not(.sidebar-collapsed) .sidebar.open {
    position: sticky !important;
    inset: auto !important;
    top: 0 !important;
    left: 0 !important;
    transform: none !important;
    width: var(--sidebar) !important;
    max-width: var(--sidebar) !important;
    min-width: var(--sidebar) !important;
    height: 100vh !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    z-index: 30 !important;
    background: rgba(255, 255, 255, .96) !important;
    box-shadow: 12px 0 36px rgba(15, 23, 42, .045) !important;
  }
  .app-area,
  body.sidebar-collapsed .app-area,
  body:not(.sidebar-collapsed) .app-area {
    grid-column: auto !important;
    width: auto !important;
    max-width: 100% !important;
    min-width: 0 !important;
    height: 100vh !important;
    min-height: 0 !important;
    display: grid !important;
    grid-template-rows: var(--topbar) minmax(0, 1fr) !important;
    overflow: hidden !important;
  }
  .view,
  body.sidebar-collapsed .view,
  body:not(.sidebar-collapsed) .view {
    width: auto !important;
    max-width: 100% !important;
    min-width: 0 !important;
    height: auto !important;
    min-height: 0 !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    padding-left: 30px !important;
    padding-right: 30px !important;
  }
  .mobile-menu,
  body.sidebar-collapsed .mobile-menu,
  body.sidebar-collapsed .topbar .mobile-menu,
  body:not(.sidebar-collapsed) .mobile-menu {
    display: none !important;
  }
  .sidebar .brand-copy,
  .sidebar .nav-section-title,
  .sidebar .nav-label,
  body.sidebar-collapsed .sidebar .brand-copy,
  body.sidebar-collapsed .sidebar .nav-section-title,
  body.sidebar-collapsed .sidebar .nav-label,
  body.sidebar-collapsed .sidebar.open .brand-copy,
  body.sidebar-collapsed .sidebar.open .nav-section-title,
  body.sidebar-collapsed .sidebar.open .nav-label {
    display: block !important;
  }
  .sidebar .badge-mini,
  body.sidebar-collapsed .sidebar .badge-mini,
  body.sidebar-collapsed .sidebar.open .badge-mini {
    display: inline-flex !important;
  }
  .sidebar .sidebar-brand,
  body.sidebar-collapsed .sidebar .sidebar-brand,
  body.sidebar-collapsed .sidebar.open .sidebar-brand {
    justify-content: flex-start !important;
    padding: 14px 18px !important;
    gap: 12px !important;
  }
  .sidebar .sidebar-brand .icon-btn.ghost,
  body.sidebar-collapsed .sidebar .sidebar-brand .icon-btn.ghost {
    display: inline-grid !important;
  }
  .sidebar .side-nav,
  body.sidebar-collapsed .sidebar .side-nav {
    padding: 14px !important;
  }
  .sidebar .nav-item,
  body.sidebar-collapsed .sidebar .nav-item,
  body.sidebar-collapsed .sidebar.open .nav-item {
    display: flex !important;
    grid-template-columns: none !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 12px !important;
    padding: 12px 12px !important;
  }
  .sidebar .nav-ico,
  body.sidebar-collapsed .sidebar .nav-ico,
  body.sidebar-collapsed .sidebar.open .nav-ico {
    margin: 0 !important;
    width: 24px !important;
    text-align: center !important;
  }
  .topbar,
  body.sidebar-collapsed .topbar {
    grid-template-columns: minmax(0, 1fr) auto !important;
  }
}
@media (max-width: 760px) {
  body,
  body.sidebar-collapsed {
    overflow: auto !important;
  }
  .zyran-app,
  body.sidebar-collapsed .zyran-app,
  body:not(.sidebar-collapsed) .zyran-app {
    grid-template-columns: 1fr !important;
    height: auto !important;
    min-height: 100vh !important;
    overflow-x: hidden !important;
    overflow-y: visible !important;
  }
  .sidebar,
  .sidebar:not(.open),
  body.sidebar-collapsed .sidebar,
  body.sidebar-collapsed .sidebar:not(.open),
  body:not(.sidebar-collapsed) .sidebar {
    position: fixed !important;
    inset: 0 auto 0 0 !important;
    width: min(310px, 88vw) !important;
    max-width: min(310px, 88vw) !important;
    min-width: min(310px, 88vw) !important;
    height: 100vh !important;
    transform: translateX(-105%) !important;
    z-index: 120 !important;
    overflow-y: auto !important;
  }
  .sidebar.open,
  body.sidebar-collapsed .sidebar.open,
  body:not(.sidebar-collapsed) .sidebar.open {
    transform: translateX(0) !important;
  }
  .mobile-menu,
  body.sidebar-collapsed .topbar .mobile-menu,
  body:not(.sidebar-collapsed) .mobile-menu {
    display: inline-grid !important;
  }
  .app-area,
  body.sidebar-collapsed .app-area {
    grid-column: auto !important;
    min-height: 100vh !important;
    height: auto !important;
  }
  .view,
  body.sidebar-collapsed .view {
    overflow: visible !important;
    padding: 16px !important;
  }
}


/* Référentiel nutritionnel */
.needs-context-card { margin-bottom: 16px; }
.needs-context-grid { display:grid; grid-template-columns: repeat(6, minmax(130px, 1fr)); gap:10px; }
.needs-context-grid > div { border:1px solid var(--line); border-radius:14px; padding:10px 12px; background:#f8fbff; }
.needs-context-grid span { display:block; font-size:11px; text-transform:uppercase; letter-spacing:.06em; color:var(--muted); font-weight:850; margin-bottom:4px; }
.needs-context-grid b { color:#0b244c; font-weight:900; }
.needs-source-line, .needs-missing-line { margin-top:10px; padding:10px 12px; border-radius:14px; border:1px solid var(--line); background:#fff; color:#334155; }
.needs-missing-line.ok { background:#ecfdf5; border-color:#bbf7d0; }
.needs-missing-line.warn { background:#fff7ed; border-color:#fed7aa; }
.need-status { display:inline-flex; align-items:center; justify-content:center; gap:4px; padding:4px 9px; border-radius:999px; font-size:12px; font-weight:900; white-space:nowrap; }
.need-status.ok { background:#dcfce7; color:#166534; }
.need-status.warn { background:#fef3c7; color:#92400e; }
.need-status.bad { background:#fee2e2; color:#991b1b; }
.need-required-dot { display:inline-flex; margin-left:6px; padding:2px 6px; border-radius:999px; font-size:10px; font-weight:850; color:#1d4ed8; background:#eff6ff; border:1px solid #bfdbfe; }
.need-row-missing td { background:#fff7ed; }
.species-ref-block, .species-test-block { display:grid; grid-template-columns: 170px minmax(0, 1fr); gap:8px; align-items:start; padding:10px 12px; border:1px solid var(--line); border-radius:14px; margin-bottom:10px; background:#f8fbff; color:#334155; }
.species-test-block { background:#ffffff; }
.species-ref-block b, .species-test-block b { color:#0b244c; }
.species-ref-block div, .species-test-block div { display:flex; flex-wrap:wrap; gap:8px; }
.species-ref-block span, .species-test-block span { display:inline-flex; padding:4px 9px; border-radius:999px; background:#fff; border:1px solid var(--line); color:#0b3f91; font-size:12px; font-weight:800; }
.species-test-block span { color:#475569; background:#f8fafc; }
.species-ref-block em, .species-test-block em { color:var(--muted); font-style:normal; font-weight:700; }

@media (max-width: 1100px) {
  .needs-context-grid { grid-template-columns: repeat(3, minmax(130px, 1fr)); }
}
@media (max-width: 760px) {
  .needs-context-grid { grid-template-columns: 1fr; }
  .species-ref-block, .species-test-block { grid-template-columns: 1fr; }
}


/* Espèces et stades */
.species-cards-pro .species-control-card { border-left: 4px solid var(--blue); }
.species-pro-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; margin-bottom: 18px; }
.species-cards-pro .species-card { display: flex; flex-direction: column; gap: 14px; overflow: visible; }
.species-card-body { display: grid; gap: 14px; }
.species-subsection { border: 1px solid var(--line); border-radius: 18px; background: #fbfdff; overflow: hidden; }
.species-subsection.primary { background: linear-gradient(180deg, #fbfdff, #f6faff); }
.species-subsection.test { background: #ffffff; }
.species-subhead { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 12px 14px; border-bottom: 1px solid var(--line); color: #0b244c; font-weight: 950; }
.species-subhead b { display: inline-flex; min-width: 28px; justify-content: center; padding: 4px 9px; border-radius: 999px; background: #eaf2ff; color: var(--blue); font-size: 12px; }
.strain-stack { display: grid; gap: 10px; padding: 12px; }
.strain-panel { border: 1px solid #cfe0f5; border-radius: 16px; background: #ffffff; overflow: hidden; }
.strain-head { display: flex; justify-content: space-between; align-items: center; gap: 10px; padding: 11px 12px; background: #f1f6ff; border-bottom: 1px solid #d9e8fb; }
.strain-head b { color: #0b244c; }
.strain-head span { color: var(--blue); font-size: 12px; font-weight: 900; background: #fff; border: 1px solid #cfe0f5; border-radius: 999px; padding: 4px 9px; }
.stage-card-list { display: grid; gap: 8px; padding: 10px; }
.stage-ref-card { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 12px; align-items: center; padding: 12px; border: 1px solid #edf2f7; border-radius: 14px; background: #ffffff; }
.stage-ref-main b { display: block; color: #0f172a; }
.stage-ref-main small { display: block; color: var(--muted); margin-top: 2px; }
.stage-ref-main .small-note { display: block; margin-top: 6px; color: #475569; font-weight: 750; }
.stage-ref-actions { display: flex; flex-direction: column; align-items: flex-end; gap: 8px; }
.species-empty-ref { padding: 14px; border: 1px dashed #cbd5e1; border-radius: 14px; background: #f8fafc; color: #475569; }
.species-empty-ref b { display: block; color: #0b244c; margin-bottom: 4px; }
.test-formula-list { display: grid; gap: 8px; padding: 12px; }
.test-formula-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 10px 12px; border-radius: 14px; background: #f8fafc; border: 1px solid #e2e8f0; }
.test-formula-row b { display: block; color: #334155; }
.test-formula-row small { display: block; color: var(--muted); margin-top: 2px; }
.species-test-empty { padding: 12px; color: var(--muted); font-weight: 750; }
.ghost-small { background: #ffffff; color: var(--blue); border-color: #bfd5ff; }
.species-reference-table-card { display: none !important; }
@media (max-width: 1240px) {
  .species-pro-grid { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .stage-ref-card { grid-template-columns: 1fr; }
  .stage-ref-actions { align-items: flex-start; }
  .test-formula-row { align-items: flex-start; flex-direction: column; }
}


/* Référentiel nutritionnel */
.needs-cards-workspace .page-head { margin-bottom: 18px; }
.needs-focus-grid { display:grid; grid-template-columns: minmax(0, 1.35fr) minmax(320px, .65fr); gap:16px; margin-bottom:16px; }
.needs-active-card, .needs-action-card { min-width:0; }
.needs-active-head { display:flex; align-items:flex-start; justify-content:space-between; gap:14px; margin-bottom:14px; }
.needs-active-head span { display:block; color:var(--muted); font-size:12px; text-transform:uppercase; letter-spacing:.06em; font-weight:900; }
.needs-active-head h3 { margin:4px 0 2px; color:#0b244c; font-size:22px; }
.needs-active-head p { margin:0; color:#475569; font-weight:750; }
.needs-meta-grid { display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap:10px; }
.needs-meta-grid > div { border:1px solid var(--line); border-radius:14px; padding:10px 12px; background:#f8fbff; min-width:0; }
.needs-meta-grid span { display:block; color:var(--muted); font-size:11px; text-transform:uppercase; letter-spacing:.06em; font-weight:850; margin-bottom:4px; }
.needs-meta-grid b { display:block; color:#0b244c; font-weight:900; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.needs-action-card h3 { margin:0 0 8px; color:#0b244c; }
.needs-action-card .field { width:100%; margin:12px 0; }
.needs-family-section { margin-bottom:16px; }
.section-heading { display:flex; align-items:flex-end; justify-content:space-between; gap:12px; margin-bottom:10px; }
.section-heading h3 { margin:0; color:#0b244c; }
.needs-family-grid { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:14px; }
.needs-family-card { border:1px solid var(--line); border-radius:18px; background:#fff; box-shadow:var(--shadow-soft); overflow:hidden; }
.needs-family-head { display:flex; align-items:center; justify-content:space-between; gap:10px; padding:12px 14px; border-bottom:1px solid var(--line); background:linear-gradient(180deg,#ffffff,#f8fbff); }
.needs-family-head div { display:flex; align-items:center; gap:8px; min-width:0; }
.needs-family-head span { width:30px; height:30px; display:inline-grid; place-items:center; border-radius:999px; background:#eaf2ff; }
.needs-family-head b { color:#0b244c; font-weight:950; }
.needs-family-head small { color:var(--muted); font-weight:850; white-space:nowrap; }
.need-chip-list { display:grid; gap:8px; padding:12px; }
.need-chip { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:10px 12px; border-radius:14px; border:1px solid var(--line); background:#f8fafc; }
.need-chip span { min-width:0; }
.need-chip b { display:block; color:#0f172a; }
.need-chip small { display:block; color:var(--muted); font-size:11px; margin-top:1px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:230px; }
.need-chip em { font-style:normal; font-weight:900; color:#334155; white-space:nowrap; }
.need-chip.ok { background:#f0fdf4; border-color:#bbf7d0; }
.need-chip.ok em { color:#166534; }
.need-chip.missing { background:#fff7ed; border-color:#fed7aa; }
.need-chip.missing em { color:#9a3412; }
.need-chip.empty { opacity:.75; }
.needs-edit-details { padding:0; overflow:hidden; margin-bottom:16px; }
.needs-edit-details > summary { cursor:pointer; list-style:none; display:flex; align-items:center; justify-content:space-between; gap:12px; padding:16px 18px; color:#0b244c; font-weight:950; background:linear-gradient(180deg,#ffffff,#f8fbff); }
.needs-edit-details > summary::-webkit-details-marker { display:none; }
.needs-edit-details > summary small { color:var(--muted); font-weight:750; }
.needs-edit-details[open] > summary { border-bottom:1px solid var(--line); }
.compact-library-head { margin-bottom:12px; }
.needs-ref-species-card { border:1px solid var(--line); border-radius:20px; background:#fff; box-shadow:var(--shadow-soft); overflow:hidden; margin-bottom:16px; }
.needs-ref-species-head { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; padding:16px 18px; border-bottom:1px solid var(--line); background:#f8fbff; }
.needs-ref-species-head h3 { margin:0; color:#0b244c; }
.needs-ref-species-head p { margin:4px 0 0; color:var(--muted); font-weight:750; }
.needs-ref-species-head span { display:inline-flex; padding:5px 10px; border-radius:999px; background:#eaf2ff; color:var(--blue); font-weight:950; font-size:12px; white-space:nowrap; }
.ref-grid.compact { padding:14px; grid-template-columns: repeat(2, minmax(0,1fr)); }
.compact-ref-card { box-shadow:none; border-color:#dbeafe; }
.compact-ref-card .ref-card-head { align-items:center; }
.ref-nutrient-details { border-top:1px solid var(--line); background:#fbfdff; }
.ref-nutrient-details > summary { cursor:pointer; padding:11px 14px; color:var(--blue); font-weight:900; list-style:none; }
.ref-nutrient-details > summary::-webkit-details-marker { display:none; }
.ref-family-grid { padding:12px; grid-template-columns:1fr; }
.ref-family-grid .needs-family-card { box-shadow:none; }
.ref-family-grid .needs-family-head { padding:10px 12px; }
.ref-family-grid .need-chip-list { grid-template-columns: repeat(2, minmax(0,1fr)); }
.ref-family-grid .need-chip { padding:8px 10px; }
.ref-family-grid .need-chip small { max-width:160px; }

@media (max-width: 1180px) {
  .needs-focus-grid { grid-template-columns:1fr; }
  .needs-family-grid, .ref-grid.compact { grid-template-columns:1fr; }
}
@media (max-width: 760px) {
  .needs-meta-grid { grid-template-columns:1fr; }
  .needs-active-head, .needs-edit-details > summary, .needs-ref-species-head { flex-direction:column; align-items:flex-start; }
  .need-chip { align-items:flex-start; flex-direction:column; }
  .need-chip em { white-space:normal; }
  .ref-family-grid .need-chip-list { grid-template-columns:1fr; }
}


/* Espèces et stades */
.species-icon-workspace .page-head { margin-bottom: 14px; }
.species-lite-summary { margin-bottom: 16px; }
.species-summary-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}
.species-summary-card h3 { margin: 0 0 4px; color: #0b244c; }
.species-summary-pills {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}
.species-summary-pills span {
  display: inline-flex;
  padding: 7px 10px;
  border-radius: 999px;
  background: #eef6ff;
  border: 1px solid #dbeafe;
  color: #1d4ed8;
  font-size: 12px;
  font-weight: 950;
}
.species-icon-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  align-items: start;
}
.species-icon-card {
  padding: 0;
  overflow: hidden;
  border-top: 0;
}
.species-icon-card > summary {
  list-style: none;
}
.species-icon-card > summary::-webkit-details-marker {
  display: none;
}
.species-icon-summary {
  min-height: 148px;
  cursor: pointer;
  display: grid;
  grid-template-rows: auto 1fr auto;
  place-items: center;
  gap: 10px;
  padding: 18px 14px;
  text-align: center;
  background: linear-gradient(180deg, #ffffff, #f7fbff);
  border: 1px solid transparent;
}
.species-icon-summary:hover {
  background: linear-gradient(180deg, #ffffff, #eef6ff);
}
.species-image-wrap {
  width: 72px;
  height: 72px;
  border-radius: 22px;
  display: inline-grid;
  place-items: center;
  background: #eef6ff;
  border: 1px solid #dbeafe;
  box-shadow: 0 10px 24px rgba(15, 23, 42, .08);
}
.species-image-wrap img {
  width: 56px;
  height: 56px;
  object-fit: contain;
  display: block;
}
.species-tile-text b {
  display: block;
  color: #0b244c;
  font-size: 16px;
  font-weight: 950;
}
.species-tile-text small {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-weight: 750;
  line-height: 1.35;
}
.species-open-indicator {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 72px;
  padding: 7px 12px;
  border-radius: 999px;
  background: #ffffff;
  border: 1px solid #bfdbfe;
  color: var(--blue);
  font-size: 12px;
  font-weight: 950;
}
.species-icon-card[open] {
  grid-column: span 3;
}
.species-icon-card[open] .species-icon-summary {
  min-height: auto;
  grid-template-columns: auto 1fr auto;
  grid-template-rows: auto;
  text-align: left;
  place-items: center start;
  border-bottom: 1px solid var(--line);
}
.species-icon-card[open] .species-image-wrap {
  width: 58px;
  height: 58px;
  border-radius: 18px;
}
.species-icon-card[open] .species-image-wrap img {
  width: 46px;
  height: 46px;
}
.species-icon-card[open] .species-open-indicator {
  background: #eaf2ff;
}
.species-icon-card[open] .species-open-indicator::before {
  content: "Détail ";
}
.species-detail-panel {
  display: grid;
  gap: 14px;
  padding: 14px;
  background: #ffffff;
}
.species-test-details {
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #fbfdff;
  overflow: hidden;
}
.species-test-details > summary {
  cursor: pointer;
  padding: 12px 14px;
  color: #334155;
  font-weight: 950;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.species-test-details > summary::-webkit-details-marker {
  display: none;
}
.species-test-details > summary b {
  display: inline-flex;
  padding: 4px 9px;
  border-radius: 999px;
  background: #f1f5f9;
  color: #475569;
  font-size: 12px;
}
.species-test-details .test-formula-list,
.species-test-details .species-test-empty {
  border-top: 1px solid var(--line);
}
.species-icon-card.species-avian .species-image-wrap { background: #eef6ff; }
.species-icon-card.species-ruminant .species-image-wrap { background: #ecfdf5; border-color: #bbf7d0; }
.species-icon-card.species-aqua .species-image-wrap { background: #ecfeff; border-color: #a5f3fc; }
.species-icon-card.species-other .species-image-wrap { background: #f5f3ff; border-color: #ddd6fe; }

@media (max-width: 1180px) {
  .species-icon-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .species-icon-card[open] { grid-column: span 2; }
}
@media (max-width: 760px) {
  .species-summary-card { align-items: flex-start; flex-direction: column; }
  .species-summary-pills { justify-content: flex-start; }
  .species-icon-grid { grid-template-columns: 1fr; }
  .species-icon-card[open] { grid-column: span 1; }
  .species-icon-card[open] .species-icon-summary {
    grid-template-columns: auto 1fr;
  }
  .species-icon-card[open] .species-open-indicator {
    grid-column: 1 / -1;
  }
}


/* Formules modèles */
.model-formulas { background: #ffffff; }
.species-subhead-actions { display: inline-flex; align-items: center; gap: 8px; }
.model-formula-list { display: grid; gap: 10px; padding: 12px; }
.model-formula-row {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto minmax(280px, auto);
  align-items: center;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #f8fbff;
}
.model-formula-main b { display: block; color: #0b244c; font-weight: 950; }
.model-formula-main small { display: block; margin-top: 4px; color: var(--muted); font-weight: 750; }
.model-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 5px 9px;
  border-radius: 999px;
  background: #eef6ff;
  border: 1px solid #bfdbfe;
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}
.model-formula-actions { display: flex; justify-content: flex-end; flex-wrap: wrap; gap: 8px; }
.species-model-empty {
  margin: 12px;
  padding: 14px;
  border: 1px dashed #bfdbfe;
  border-radius: 16px;
  background: #f8fbff;
  color: var(--muted);
  font-weight: 750;
}
.species-model-empty.compact { margin: 0; }
.species-model-modal { width: min(1040px, 96vw); }
.model-form-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 14px;
}
.model-total-strip {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #f8fbff;
  margin-bottom: 14px;
}
.model-total-strip span { color: var(--muted); font-weight: 850; text-transform: uppercase; font-size: 12px; letter-spacing: .05em; }
.model-total-strip b { font-size: 20px; }
.model-total-strip small { color: var(--muted); font-weight: 750; }
.ok-text { color: var(--green); }
.warn-text { color: var(--orange); }
.model-edit-table { max-height: 360px; }
.modal-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}
.danger-soft {
  background: var(--red-soft);
  color: var(--red);
  border-color: #fecdd3;
}
@media (max-width: 980px) {
  .model-formula-row { grid-template-columns: 1fr; align-items: stretch; }
  .model-formula-actions { justify-content: flex-start; }
  .model-form-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px) {
  .model-form-grid { grid-template-columns: 1fr; }
  .model-total-strip { align-items: flex-start; flex-direction: column; }
}

.species-subhint { color: var(--muted); font-size: 12px; font-weight: 750; margin-left: 8px; }


/* Module Pet Food */
.petfood-workspace .page-head p { max-width: 860px; }
.petfood-intro {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}
.petfood-intro h3 { margin: 0 0 6px; }
.pet-animal-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(260px, 1fr));
  gap: 16px;
}
.pet-animal-card {
  overflow: hidden;
  padding: 0;
}
.pet-animal-summary {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 16px;
  padding: 18px;
  list-style: none;
  cursor: pointer;
}
.pet-animal-summary::-webkit-details-marker { display: none; }
.pet-image {
  width: 92px;
  height: 92px;
  border-radius: 24px;
  background: #f8fbff;
}
.pet-image img { width: 78px; height: 78px; object-fit: contain; }
.pet-animal-summary em {
  display: block;
  margin-top: 6px;
  color: var(--blue);
  font-style: normal;
  font-weight: 900;
  font-size: 12px;
}
.pet-animal-card[open] {
  grid-column: span 2;
}
.pet-animal-card[open] .pet-animal-summary {
  border-bottom: 1px solid var(--line);
  background: linear-gradient(135deg, #ffffff, #f8fbff);
}
.pet-animal-detail {
  display: grid;
  grid-template-columns: minmax(280px, .95fr) minmax(320px, 1.05fr);
  gap: 16px;
  padding: 16px;
}
.pet-subsection {
  border: 1px solid var(--line);
  border-radius: 18px;
  background: #ffffff;
  overflow: hidden;
}
.pet-stage-grid {
  display: grid;
  gap: 10px;
  padding: 12px;
}
.pet-stage-card {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #f8fbff;
}
.pet-stage-main b { display: block; color: #0b244c; font-weight: 950; }
.pet-stage-main small { display: block; margin-top: 4px; color: var(--muted); font-weight: 750; }
.pet-stage-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 8px;
}
@media (max-width: 980px) {
  .pet-animal-grid { grid-template-columns: 1fr; }
  .pet-animal-card[open] { grid-column: span 1; }
  .pet-animal-detail { grid-template-columns: 1fr; }
  .pet-stage-card { grid-template-columns: 1fr; }
  .pet-stage-actions { justify-content: flex-start; }
}
@media (max-width: 640px) {
  .petfood-intro { align-items: flex-start; flex-direction: column; }
  .pet-animal-summary { grid-template-columns: auto 1fr; }
  .pet-animal-summary .species-open-indicator { grid-column: 1 / -1; }
}


/* Output Quality Gate */
.quality-gate-card { border-width: 1px; }
.quality-gate-card.danger { border-color: #fecaca; background: linear-gradient(135deg, #fff, #fff5f5); }
.quality-gate-card.warn { border-color: #fed7aa; background: linear-gradient(135deg, #fff, #fff8ed); }
.quality-gate-card.ok { border-color: #bbf7d0; background: linear-gradient(135deg, #fff, #f0fdf4); }
.quality-gate-head { display:flex; justify-content:space-between; gap:18px; align-items:flex-start; }
.quality-gate-head span { color: var(--muted); font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: .05em; }
.quality-gate-head h3 { margin: 4px 0; font-size: 22px; }
.quality-badge { display:inline-flex; align-items:center; border-radius:999px; padding:8px 12px; font-size:12px; font-weight:900; white-space:nowrap; }
.quality-badge.danger { background:#fee2e2; color:#b91c1c; }
.quality-badge.warn { background:#ffedd5; color:#c2410c; }
.quality-badge.ok { background:#dcfce7; color:#15803d; }
.quality-reasons { margin: 10px 0 0; padding-left: 18px; color: var(--muted); }
@media (max-width: 760px) { .quality-gate-head { flex-direction:column; } .quality-badge { white-space:normal; } }


/* Output Quality Gate */
.client-dashboard-grid,
.settings-icon-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(180px, 1fr));
  gap: 16px;
  margin-bottom: 16px;
}
.icon-module-card,
.settings-tile {
  min-height: 150px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.module-icon.big {
  width: 58px;
  height: 58px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 18px;
  background: linear-gradient(135deg, #eff6ff, #f8fbff);
  color: var(--blue);
  font-size: 28px;
  font-weight: 950;
  box-shadow: inset 0 0 0 1px var(--line);
}
.client-main-grid {
  display: grid;
  grid-template-columns: minmax(320px, .92fr) minmax(380px, 1.08fr);
  gap: 16px;
  align-items: start;
}
.section-head,
.client-card-title,
.bon-title {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
  margin-bottom: 12px;
}
.client-list,
.bon-list {
  display: grid;
  gap: 12px;
}
.client-card,
.bon-card {
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 14px;
  background: #fff;
}
.bon-card.danger { border-color: #fecaca; background: linear-gradient(135deg, #fff, #fff5f5); }
.bon-card.warn { border-color: #fed7aa; background: linear-gradient(135deg, #fff, #fff8ed); }
.bon-card.ok { border-color: #bbf7d0; background: linear-gradient(135deg, #fff, #f0fdf4); }
.mini-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(160px, 1fr));
  gap: 12px;
}
.mini-form-grid label,
.client-card label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-weight: 800;
  font-size: 12px;
}
.inline-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}
.warn-btn {
  border-color: #fed7aa !important;
  background: #fff8ed !important;
  color: #c2410c !important;
}
.danger-btn {
  border-color: #fecaca !important;
  background: #fff5f5 !important;
  color: #b91c1c !important;
}
.quality-actions {
  display: grid;
  gap: 8px;
  justify-items: end;
}
.toggle-line {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: #f8fbff;
  margin-bottom: 12px;
}
.switch {
  position: relative;
  display: inline-flex;
  width: 58px;
  height: 32px;
  flex: 0 0 auto;
}
.switch input { display: none; }
.switch span {
  position: absolute;
  inset: 0;
  border-radius: 999px;
  background: #cbd5e1;
  cursor: pointer;
  transition: .18s ease;
}
.switch span:before {
  content: '';
  position: absolute;
  width: 26px;
  height: 26px;
  left: 3px;
  top: 3px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 6px 14px rgba(15,23,42,.18);
  transition: .18s ease;
}
.switch input:checked + span { background: #1e40af; }
.switch input:checked + span:before { transform: translateX(26px); }
@media (max-width: 1000px) {
  .client-dashboard-grid,
  .settings-icon-grid { grid-template-columns: repeat(2, minmax(160px, 1fr)); }
  .client-main-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .client-dashboard-grid,
  .settings-icon-grid,
  .mini-form-grid { grid-template-columns: 1fr; }
  .quality-actions { justify-items: start; }
}


/* Output Quality Gate */
.mixer-workspace { display: grid; gap: 16px; }
.mixer-hero {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: stretch;
}
.mixer-capacity-box {
  min-width: 210px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: linear-gradient(135deg, #eff6ff, #f8fbff);
  padding: 14px;
  display: grid;
  align-content: center;
  text-align: right;
}
.mixer-capacity-box span,
.mixer-summary-grid span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.mixer-capacity-box b {
  color: var(--blue);
  font-size: 28px;
}
.mixer-capacity-card { display: grid; gap: 14px; }
.capacity-selector {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.capacity-btn {
  border: 1px solid var(--line);
  background: #fff;
  color: var(--text);
  border-radius: 14px;
  padding: 10px 14px;
  font-weight: 950;
  cursor: pointer;
}
.capacity-btn.active {
  border-color: var(--blue);
  background: #eff6ff;
  color: var(--blue);
}
.mixer-custom-capacity {
  display: grid;
  gap: 6px;
  max-width: 260px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}
.mixer-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(130px, 1fr));
  gap: 12px;
  margin: 14px 0;
}
.mixer-summary-grid > div {
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #f8fbff;
  padding: 12px;
}
.mixer-summary-grid b {
  display: block;
  color: var(--blue);
  font-size: 18px;
  margin-top: 4px;
}
@media (max-width: 860px) {
  .mixer-hero { flex-direction: column; }
  .mixer-capacity-box { text-align: left; }
  .mixer-summary-grid { grid-template-columns: repeat(2, minmax(130px, 1fr)); }
}
@media (max-width: 560px) {
  .mixer-summary-grid { grid-template-columns: 1fr; }
}


/* Output Quality Gate */
.price-icon-workspace .price-lite-head,
.needs-icon-workspace .needs-action-tile {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}
.price-group-icon-grid,
.needs-family-icon-grid,
.needs-species-icon-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
  margin-top: 14px;
}
.price-group-tile,
.needs-family-tile,
.needs-species-tile,
.needs-active-tile {
  overflow: hidden;
}
.price-group-summary,
.needs-family-summary,
.needs-active-summary {
  list-style: none;
  display: grid;
  grid-template-columns: 58px 1fr auto;
  align-items: center;
  gap: 14px;
  cursor: pointer;
}
.price-group-summary::-webkit-details-marker,
.needs-family-summary::-webkit-details-marker,
.needs-active-summary::-webkit-details-marker,
.needs-species-summary::-webkit-details-marker {
  display: none;
}
.price-group-icon,
.needs-tile-icon {
  width: 54px;
  height: 54px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  background: #eff6ff;
  border: 1px solid #cfe0ff;
  font-size: 26px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.7);
}
.price-group-main small,
.needs-family-summary small,
.needs-active-summary small {
  display: block;
  color: var(--muted);
  margin-top: 4px;
  font-weight: 800;
}
.price-group-status {
  border-radius: 999px;
  padding: 7px 10px;
  font-size: 11px;
  font-weight: 950;
  white-space: nowrap;
}
.price-group-status.ok {
  background: #dcfce7;
  color: #047857;
}
.price-group-status.watch {
  background: #fff7ed;
  color: #c2410c;
}
.price-group-detail,
.needs-active-detail,
.needs-species-detail {
  margin-top: 16px;
  border-top: 1px solid var(--line);
  padding-top: 14px;
}
.price-group-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(120px, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}
.price-group-metrics > div {
  background: #f8fbff;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 10px;
}
.price-group-metrics span {
  display: block;
  font-size: 11px;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 950;
}
.price-group-metrics b {
  display: block;
  margin-top: 4px;
  color: var(--blue);
}
.price-subgroup-block {
  border: 1px solid var(--line);
  border-radius: 16px;
  overflow: hidden;
  margin-top: 12px;
  background: #fff;
}
.price-subgroup-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 11px 12px;
  background: #f1f7ff;
  border-bottom: 1px solid var(--line);
}
.compact-price-table td small {
  display: block;
  margin-top: 3px;
  color: var(--muted);
}
.needs-hero-grid {
  display: grid;
  grid-template-columns: minmax(320px, 1.3fr) minmax(260px, .7fr);
  gap: 14px;
  margin-bottom: 16px;
}
.needs-action-tile {
  display: flex;
  align-items: center;
  gap: 14px;
}
.needs-action-tile .field {
  margin-top: 8px;
}
.needs-tile-section {
  margin-top: 18px;
}
.needs-family-tile .need-chip-list {
  margin-top: 14px;
}
.compact-edit-details {
  margin-top: 16px;
}
.needs-species-summary {
  grid-template-columns: 64px 1fr auto;
}
.needs-strain-panel {
  margin-top: 12px;
}
@media (max-width: 900px) {
  .needs-hero-grid,
  .price-group-metrics {
    grid-template-columns: 1fr;
  }
  .price-icon-workspace .price-lite-head {
    align-items: flex-start;
    flex-direction: column;
  }
}
@media (max-width: 640px) {
  .price-group-summary,
  .needs-family-summary,
  .needs-active-summary,
  .needs-species-summary {
    grid-template-columns: 48px 1fr;
  }
  .price-group-status,
  .species-open-indicator {
    grid-column: 2;
    justify-self: start;
  }
  .price-group-icon,
  .needs-tile-icon {
    width: 48px;
    height: 48px;
    border-radius: 15px;
    font-size: 22px;
  }
}


/* Output Quality Gate */
.guide-workspace { display: grid; gap: 20px; }
.guide-hero { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 18px; align-items: stretch; padding: 22px; }
.guide-hero h3 { font-size: 28px; letter-spacing: -.05em; margin: 10px 0 8px; color: #0f2a5f; }
.guide-hero p { color: #526782; line-height: 1.55; margin: 0; max-width: 920px; }
.guide-principle { border: 1px solid #cfe0ff; border-radius: 18px; background: linear-gradient(135deg, #eff6ff, #ffffff); padding: 18px; display: grid; gap: 8px; }
.guide-principle b { color: var(--blue); font-size: 15px; }
.guide-principle span { font-weight: 950; color: #14233f; }
.guide-principle small { color: #64748b; line-height: 1.4; }
.guide-section { display: grid; gap: 14px; }
.guide-section-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 18px; }
.guide-section-head h3 { margin: 0; color: #12244a; font-size: 20px; letter-spacing: -.03em; }
.guide-section-head p { margin: 0; color: #64748b; max-width: 680px; line-height: 1.45; font-size: 13px; }
.guide-icon-grid { display: grid; grid-template-columns: repeat(3, minmax(260px, 1fr)); gap: 14px; }
.guide-module-card { border: 1px solid #d7e4f5; border-radius: 20px; background: #fff; box-shadow: 0 14px 34px rgba(15,23,42,.06); overflow: hidden; }
.guide-module-card[open] { border-color: #9fc2ff; box-shadow: 0 20px 48px rgba(30,64,175,.10); }
.guide-module-card summary { list-style: none; cursor: pointer; display: grid; grid-template-columns: 56px 1fr auto; align-items: center; gap: 14px; padding: 18px; }
.guide-module-card summary::-webkit-details-marker { display: none; }
.guide-module-icon { width: 54px; height: 54px; border-radius: 18px; background: linear-gradient(135deg, #dbeafe, #eff6ff); color: var(--blue); display: grid; place-items: center; font-size: 24px; font-weight: 950; border: 1px solid #bfdbfe; }
.guide-module-card summary b { color: #10285a; font-size: 15px; letter-spacing: -.02em; display: block; }
.guide-module-card summary small { color: #64748b; line-height: 1.35; display: block; margin-top: 5px; }
.guide-module-card summary em { color: var(--blue); font-size: 12px; font-style: normal; font-weight: 950; background: #eff6ff; border: 1px solid #bfdbfe; border-radius: 999px; padding: 7px 10px; white-space: nowrap; }
.guide-module-card[open] summary em { background: var(--blue); color: #fff; border-color: var(--blue); }
.guide-module-body { border-top: 1px solid #e2e8f0; padding: 16px 18px 18px; display: grid; gap: 12px; background: #fbfdff; }
.guide-mini-block { border: 1px solid #e3ebf7; border-radius: 16px; background: #fff; padding: 13px 14px; }
.guide-mini-block b { color: #10285a; display: block; margin-bottom: 8px; }
.guide-mini-block ol { margin: 0; padding-left: 18px; color: #3f5573; line-height: 1.55; font-size: 13px; }
.guide-mini-block li + li { margin-top: 4px; }
.guide-link-row { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.guide-link-row span { border: 1px solid #dbe5f1; border-radius: 999px; padding: 7px 10px; font-size: 12px; color: #425672; background: #fff; font-weight: 800; }
.guide-workflow-grid { display: grid; grid-template-columns: repeat(2, minmax(280px, 1fr)); gap: 14px; }
.guide-workflow-card { border: 1px solid #d7e4f5; border-radius: 20px; background: #fff; padding: 16px; box-shadow: 0 12px 32px rgba(15,23,42,.055); }
.guide-workflow-title { display: flex; align-items: center; gap: 10px; color: #10285a; font-size: 15px; margin-bottom: 12px; }
.guide-workflow-title span { width: 42px; height: 42px; display: grid; place-items: center; border-radius: 14px; background: #eff6ff; border: 1px solid #bfdbfe; }
.guide-flow { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.guide-flow span { border-radius: 999px; background: #f8fafc; border: 1px solid #dbe5f1; padding: 7px 10px; font-size: 12px; color: #374b68; font-weight: 850; }
.guide-flow i { color: #94a3b8; font-style: normal; font-weight: 950; }
.guide-quality-card { display: flex; align-items: center; justify-content: space-between; gap: 18px; padding: 20px; border-color: #bfdbfe; background: linear-gradient(135deg, #ffffff, #eff6ff); }
.guide-quality-card h3 { margin: 0 0 6px; color: #10285a; }
.guide-quality-card p { margin: 0; color: #536985; line-height: 1.5; }
.guide-quality-actions { display: flex; gap: 10px; flex-wrap: wrap; justify-content: flex-end; min-width: 280px; }
@media (max-width: 1180px) {
  .guide-icon-grid { grid-template-columns: repeat(2, minmax(240px, 1fr)); }
  .guide-hero { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .guide-icon-grid, .guide-workflow-grid { grid-template-columns: 1fr; }
  .guide-section-head, .guide-quality-card { display: grid; }
  .guide-quality-actions { min-width: 0; justify-content: start; }
  .guide-module-card summary { grid-template-columns: 48px 1fr; }
  .guide-module-card summary em { grid-column: 1 / -1; justify-self: start; }
}


/* Bloc historique stabilisé */
.pet-breed-section { background: linear-gradient(135deg, #ffffff, #f8fbff); }
.pet-size-strip { display: grid; grid-template-columns: repeat(auto-fit, minmax(130px, 1fr)); gap: 8px; margin: 10px 0 12px; }
.pet-size-strip span { border: 1px solid #dbe5f1; border-radius: 14px; background: #fff; padding: 9px 10px; display: grid; gap: 3px; }
.pet-size-strip b { color: #10285a; font-size: 12px; }
.pet-size-strip small { color: #6b7f99; font-size: 11px; }
.pet-breed-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 10px; }
.pet-breed-chip { border: 1px solid #d7e4f5; border-radius: 16px; padding: 11px; background: #fff; box-shadow: 0 8px 22px rgba(15,23,42,.045); display: grid; gap: 4px; }
.pet-breed-chip b { color: #10285a; font-size: 13px; }
.pet-breed-chip small { color: #536985; font-size: 11px; line-height: 1.35; }
.pet-breed-chip em { justify-self: start; border-radius: 999px; padding: 4px 8px; background: #fff7ed; border: 1px solid #fed7aa; color: #9a3412; font-size: 10px; font-style: normal; font-weight: 850; }
.species-pig .species-image-wrap,
.species-equine .species-image-wrap,
.species-aqua .species-image-wrap { background: #f8fafc; }


/* Assistant formulation */
.quality-inline-controls{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
  margin:12px 0 8px;
  padding:10px;
  border:1px solid rgba(148,163,184,.35);
  border-radius:14px;
  background:rgba(248,250,252,.82);
}
body.dark .quality-inline-controls{background:rgba(15,23,42,.55)}
.quality-inline-controls label{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:13px;
  color:var(--muted);
}
.quality-inline-controls .compact-field{
  width:auto;
  min-width:86px;
  padding:7px 9px;
}
.quality-check-inline input{accent-color:var(--primary)}


/* Référentiel nutritionnel */
.formulation-reference-context { border: 1px solid rgba(30, 64, 175, .18); background: linear-gradient(135deg, rgba(219,234,254,.88), rgba(255,255,255,.96)); }
.reference-context-grid { display: grid; grid-template-columns: repeat(6, minmax(130px, 1fr)); gap: 10px; margin-top: 14px; }
.reference-context-grid div { background: rgba(255,255,255,.82); border: 1px solid var(--line); border-radius: 16px; padding: 12px; }
.reference-context-grid span { display: block; color: var(--muted); font-size: 12px; margin-bottom: 4px; }
.reference-context-grid b { color: var(--text); font-size: 13px; }
.reference-context-note { margin-top: 12px; padding: 12px 14px; border-radius: 14px; background: rgba(255,255,255,.70); color: var(--muted); line-height: 1.45; }

.formulation-ref-modal { width: min(1080px, 96vw); }
.ref-picker-steps { display: grid; grid-template-columns: repeat(3, minmax(180px, 1fr)); gap: 12px; margin-bottom: 14px; }
.ref-picker-steps .field { padding: 12px; }
.ref-picker-steps select { width: 100%; border: 1px solid var(--line); border-radius: 12px; padding: 10px 12px; background: #fff; color: var(--text); }
.ref-picker-summary { display: grid; grid-template-columns: repeat(4, minmax(140px, 1fr)); gap: 10px; margin-bottom: 14px; }
.ref-picker-summary div { border: 1px solid var(--line); border-radius: 14px; padding: 12px; background: var(--bg); }
.ref-picker-summary span { display: block; color: var(--muted); font-size: 12px; margin-bottom: 4px; }
.ref-picker-summary b { font-size: 13px; }
.ref-associated-table { margin-top: 14px; }
.needs-association-table td:first-child span { display: block; color: var(--muted); font-size: 12px; margin-top: 2px; }
.needs-association-table th:nth-child(3), .needs-association-table td:nth-child(3) { white-space: nowrap; }

body.dark .formulation-reference-context { background: linear-gradient(135deg, rgba(30,64,175,.20), rgba(17,28,47,.96)); }
body.dark .reference-context-grid div, body.dark .reference-context-note { background: rgba(17,28,47,.88); }
body.dark .ref-picker-steps select { background: #111c2f; color: var(--text); }

@media (max-width: 980px) {
  .reference-context-grid { grid-template-columns: repeat(2, minmax(140px, 1fr)); }
  .ref-picker-steps, .ref-picker-summary { grid-template-columns: 1fr; }
}

/* Tables nutritionnelles adaptatives */
.needs-row-missing td{background:#fff7ed;color:#9a3412}.needs-row-missing b{color:#9a3412}.reference-context-note+.alert-box{margin-top:12px}.formulation-ref-modal .alert-box.warning{margin:12px 0}.ref-picker-summary div:first-child{border-color:#bfdbfe;background:#eff6ff}


/* UX stabilisée */
.formulation-view .phase1-titlebar {
  gap: 12px;
  padding: 14px 16px;
}
.formulation-view .phase1-titlebar h2 {
  margin-bottom: 2px;
}
.formulation-view .phase1-title-actions {
  gap: 8px;
  flex-wrap: wrap;
}
.formulation-view .phase1-kpis {
  margin-top: 10px;
}
.formulation-view .quality-gate-card {
  padding: 14px 16px;
}
.quality-reasons-fold {
  margin-top: 10px;
  border-top: 1px solid var(--line);
  padding-top: 8px;
}
.quality-reasons-fold summary {
  cursor: pointer;
  color: var(--muted);
  font-weight: 800;
}
.quality-reasons-fold .quality-reasons {
  margin-top: 8px;
}
.formulation-reference-context .reference-context-grid {
  grid-template-columns: repeat(auto-fit, minmax(165px, 1fr));
}
.phase2-actions-toolbar .card-title-row.compact {
  margin-bottom: 8px;
}
.phase2-actions-toolbar {
  padding: 12px 14px;
}

/* ZYRAN V6.1.1 — Ajout local des matières premières */
.material-create-card { border-color: #bfdbfe; }
.material-create-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.material-create-field { display: grid; gap: 6px; }
.material-create-field span {
  color: #455a78;
  font-size: 12px;
  font-weight: 850;
}
.material-create-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 14px;
  flex-wrap: wrap;
}
.material-delete-btn { padding: 8px 10px; }
@media (max-width: 900px) {
  .material-create-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px) {
  .material-create-grid { grid-template-columns: 1fr; }
}



/* ZYRAN V6.2.8 — accueil suite logicielle */
.suite-view { display: flex; flex-direction: column; gap: 22px; }
.suite-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 310px;
  gap: 20px;
  align-items: stretch;
  background: linear-gradient(135deg, #0f172a 0%, #1e40af 58%, #06b6d4 100%);
  color: white;
  border-radius: 28px;
  padding: 34px;
  box-shadow: var(--shadow);
  overflow: hidden;
  position: relative;
}
.suite-hero::after {
  content: "";
  position: absolute;
  inset: auto -60px -90px auto;
  width: 280px;
  height: 280px;
  background: rgba(255,255,255,.11);
  border-radius: 50%;
}
.suite-kicker {
  color: rgba(255,255,255,.72);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.suite-hero h2 {
  margin: 10px 0 10px;
  font-size: clamp(34px, 5vw, 58px);
  line-height: .96;
}
.suite-hero p { max-width: 760px; margin: 0 0 10px; color: rgba(255,255,255,.86); font-size: 17px; }
.suite-lead { font-weight: 650; }
.suite-hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 20px; }
.suite-note {
  display: flex;
  flex-direction: column;
  gap: 10px;
  background: rgba(255,255,255,.13);
  border: 1px solid rgba(255,255,255,.22);
  border-radius: 22px;
  padding: 20px;
  backdrop-filter: blur(10px);
  z-index: 1;
}
.suite-note b { font-size: 18px; }
.suite-note span { color: rgba(255,255,255,.84); }
.suite-kpis { margin-top: -4px; }
.suite-editions-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}
.suite-card {
  border: 1px solid var(--line);
  background: var(--panel);
  color: var(--text);
  border-radius: 24px;
  padding: 20px;
  text-align: left;
  min-height: 255px;
  box-shadow: var(--shadow-soft);
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.suite-card.active:hover { transform: translateY(-3px); box-shadow: var(--shadow); border-color: rgba(37,99,235,.42); }
.suite-card.disabled { opacity: .72; cursor: default; background: linear-gradient(180deg, #fff, #f8fbff); }
.suite-card-head { display: flex; justify-content: space-between; gap: 12px; align-items: flex-start; }
.suite-card-title { font-size: 19px; font-weight: 900; letter-spacing: -.02em; }
.suite-card-sub { color: var(--muted); font-size: 13px; font-weight: 750; margin-top: 3px; }
.suite-card p { color: var(--muted); margin: 0; line-height: 1.5; }
.suite-species-label {
  color: var(--soft-text);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 900;
  margin-top: auto;
}
.suite-species-list { display: flex; flex-wrap: wrap; gap: 7px; }
.suite-species-list span {
  background: var(--blue-soft);
  color: var(--blue);
  border: 1px solid #dbeafe;
  border-radius: 999px;
  padding: 6px 9px;
  font-size: 12px;
  font-weight: 800;
}
.suite-card-action {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 4px;
  font-weight: 900;
  color: var(--blue);
}
.suite-card.disabled .suite-card-action { color: var(--muted); }
.suite-rule { margin-top: 0; }
.compact-modules { grid-template-columns: repeat(5, minmax(0, 1fr)); }

@media (max-width: 1180px) {
  .suite-editions-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .compact-modules { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .suite-hero { grid-template-columns: 1fr; }
}
@media (max-width: 680px) {
  .suite-hero { padding: 24px; border-radius: 22px; }
  .suite-editions-grid, .compact-modules { grid-template-columns: 1fr; }
  .suite-card { min-height: 0; }
}


/* V6.2.8 — Suite d'accueil inspirée PhytoPrecision : registre scientifique, cartes numérotées */
.phyto-suite {
  --phyto-ink: #111827;
  --phyto-muted: #5f6f85;
  --phyto-line: rgba(17, 24, 39, .10);
  --phyto-cream: #fbfaf5;
  --phyto-sage: #789879;
  --phyto-lime: #d7f36c;
  --phyto-panel: rgba(255,255,255,.86);
}

.phyto-suite .phyto-hero {
  grid-template-columns: minmax(0, 1.25fr) 360px;
  background:
    radial-gradient(circle at 82% 18%, rgba(215, 243, 108, .34) 0, rgba(215, 243, 108, 0) 27%),
    radial-gradient(circle at 8% 0%, rgba(120, 152, 121, .22) 0, rgba(120, 152, 121, 0) 30%),
    linear-gradient(135deg, #fbfaf5 0%, #eef4e9 48%, #dfeadc 100%);
  color: var(--phyto-ink);
  border: 1px solid var(--phyto-line);
  box-shadow: 0 28px 80px rgba(17, 24, 39, .10);
}

.phyto-suite .phyto-hero::before {
  content: "";
  position: absolute;
  inset: 28px 28px auto auto;
  width: 122px;
  height: 122px;
  border-radius: 999px;
  border: 1px solid rgba(17, 24, 39, .13);
  background:
    linear-gradient(90deg, transparent 49%, rgba(17,24,39,.12) 50%, transparent 51%),
    linear-gradient(0deg, transparent 49%, rgba(17,24,39,.12) 50%, transparent 51%);
  opacity: .72;
}

.phyto-suite .phyto-hero::after {
  inset: auto -90px -110px auto;
  width: 360px;
  height: 360px;
  background: rgba(255,255,255,.42);
  border: 1px solid rgba(17, 24, 39, .06);
}

.phyto-suite .suite-kicker,
.phyto-suite .suite-section-code,
.phyto-suite .phyto-note-code {
  color: #526556;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 12px;
  font-weight: 850;
  letter-spacing: .13em;
  text-transform: uppercase;
}

.phyto-suite .suite-hero h2 {
  color: var(--phyto-ink);
  max-width: 740px;
  letter-spacing: -.065em;
  font-size: clamp(42px, 6vw, 76px);
}

.phyto-suite .suite-hero p {
  color: var(--phyto-muted);
}

.phyto-suite .suite-lead {
  max-width: 830px;
  color: #243827;
  font-weight: 760;
}

.phyto-suite .suite-hero-actions .primary-btn {
  background: #111827;
  color: #fff;
  box-shadow: 0 22px 44px rgba(17, 24, 39, .22);
}

.phyto-suite .suite-hero-actions .secondary-btn {
  border-color: rgba(17,24,39,.16);
  color: #142018;
  background: rgba(255,255,255,.72);
}

.phyto-suite .phyto-note {
  background: rgba(255,255,255,.58);
  color: var(--phyto-ink);
  border: 1px solid rgba(17, 24, 39, .12);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.7);
}

.phyto-suite .phyto-note span {
  color: var(--phyto-muted);
}

.phyto-lab-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: 16px 0 22px;
}

.phyto-lab-strip span {
  border: 1px solid rgba(17, 24, 39, .10);
  background: rgba(255,255,255,.72);
  border-radius: 999px;
  padding: 12px 14px;
  color: #29382d;
  font-size: 12px;
  font-weight: 900;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.suite-section-head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 24px;
  margin: 10px 0 16px;
}

.suite-section-head .section-title {
  margin: 4px 0 0;
  color: #15231b;
  font-size: 28px;
}

.suite-section-head p {
  max-width: 540px;
  margin: 0;
  color: var(--phyto-muted);
  line-height: 1.55;
  font-weight: 650;
}

.phyto-suite .suite-editions-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.phyto-suite .suite-card {
  position: relative;
  overflow: hidden;
  min-height: 286px;
  border-radius: 28px;
  border: 1px solid rgba(17,24,39,.10);
  background:
    linear-gradient(180deg, rgba(255,255,255,.93), rgba(249,250,245,.92));
  box-shadow: 0 22px 60px rgba(17, 24, 39, .080);
}

.phyto-suite .suite-card::after {
  content: "";
  position: absolute;
  right: -34px;
  bottom: -34px;
  width: 112px;
  height: 112px;
  border-radius: 999px;
  background: rgba(215, 243, 108, .34);
}

.phyto-suite .suite-card.active {
  border-color: rgba(17,24,39,.24);
  background:
    radial-gradient(circle at 86% 18%, rgba(215,243,108,.42), rgba(215,243,108,0) 34%),
    linear-gradient(180deg, #ffffff, #f4f7ec);
}

.phyto-suite .suite-card.disabled {
  opacity: 1;
  cursor: default;
}

.suite-card-index {
  position: absolute;
  right: 18px;
  top: 15px;
  color: rgba(17, 24, 39, .10);
  font-size: 56px;
  font-weight: 950;
  line-height: 1;
  letter-spacing: -.08em;
}

.suite-card-code {
  position: relative;
  z-index: 1;
  color: #6d7c69;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 11px;
  font-weight: 850;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.phyto-suite .suite-card-title {
  position: relative;
  z-index: 1;
  color: #101820;
  font-size: 22px;
  letter-spacing: -.045em;
}

.phyto-suite .suite-card-sub {
  position: relative;
  z-index: 1;
  color: #5f725d;
}

.phyto-suite .suite-card p {
  position: relative;
  z-index: 1;
  color: #5b6878;
}

.phyto-suite .suite-species-label,
.phyto-suite .suite-species-list,
.phyto-suite .suite-card-action,
.phyto-suite .suite-card-head {
  position: relative;
  z-index: 1;
}

.phyto-suite .suite-species-list span {
  background: rgba(239, 246, 232, .92);
  color: #2d482f;
  border-color: rgba(120, 152, 121, .24);
}

.phyto-suite .suite-card-action {
  color: #111827;
}

.phyto-suite .badge-mini.pro {
  background: #111827;
  color: #fff;
}

.phyto-suite .badge-mini.soon {
  background: rgba(17, 24, 39, .06);
  color: #5d6878;
}

@media (max-width: 1180px) {
  .phyto-suite .phyto-hero { grid-template-columns: 1fr; }
  .phyto-suite .suite-editions-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .phyto-lab-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .suite-section-head { align-items: start; flex-direction: column; }
}

@media (max-width: 680px) {
  .phyto-suite .suite-hero h2 { font-size: 42px; }
  .phyto-suite .suite-editions-grid,
  .phyto-lab-strip { grid-template-columns: 1fr; }
}


/* V6.2.8 — correction menu principal ZYRAN Suite visible */
.suite-menu-home {
  max-width: 1280px;
  margin: 0 auto;
  padding-top: 22px;
  padding-bottom: 56px;
}

.suite-menu-hero {
  min-height: 320px;
  align-items: stretch;
  background:
    radial-gradient(circle at 12% 10%, rgba(37, 99, 235, .18), transparent 34%),
    linear-gradient(135deg, #071b3f 0%, #123f88 48%, #eff6ff 49%, #ffffff 100%);
  border: 1px solid rgba(30, 64, 175, .18);
  box-shadow: 0 26px 58px rgba(15, 23, 42, .16);
}

.suite-menu-hero h2 {
  font-size: clamp(38px, 5vw, 72px);
  letter-spacing: -.055em;
  line-height: .93;
  margin-bottom: 18px;
}

.suite-menu-hero .phyto-hero-copy {
  color: #fff;
  max-width: 760px;
}

.suite-menu-hero .phyto-hero-copy p,
.suite-menu-hero .suite-lead,
.suite-menu-hero .suite-kicker {
  color: rgba(255, 255, 255, .88);
}

.suite-menu-hero .suite-kicker {
  font-weight: 900;
  letter-spacing: .18em;
}

.suite-menu-hero .secondary-btn {
  background: rgba(255,255,255,.10);
  color: #fff;
  border-color: rgba(255,255,255,.28);
}

.suite-menu-hero .phyto-note {
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(255,255,255,.50);
}

.suite-product-strip {
  margin: 20px 0 26px;
  background: #fff;
}

.suite-section-head {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  align-items: end;
  margin: 8px 0 18px;
}

.suite-section-head h3 {
  margin: 2px 0 0;
  font-size: 30px;
  letter-spacing: -.03em;
}

.suite-section-head p {
  max-width: 520px;
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}

.suite-kicker.small {
  color: var(--blue);
  font-size: 11px;
  letter-spacing: .18em;
}

.suite-main-menu {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.suite-main-menu .suite-card {
  min-height: 300px;
  text-align: left;
}

.suite-main-menu .suite-card.active {
  grid-column: span 2;
  background:
    linear-gradient(135deg, #0f2a5d 0%, #1d4ed8 62%, #dbeafe 100%);
  color: #fff;
  border-color: rgba(29, 78, 216, .65);
}

.suite-main-menu .suite-card.active .suite-card-sub,
.suite-main-menu .suite-card.active p,
.suite-main-menu .suite-card.active .suite-species-label,
.suite-main-menu .suite-card.active .suite-species-list span,
.suite-main-menu .suite-card.active .suite-card-code,
.suite-main-menu .suite-card.active .suite-card-index {
  color: rgba(255,255,255,.86);
}

.suite-main-menu .suite-card.active .suite-species-list span,
.suite-main-menu .suite-card.active .badge-mini {
  background: rgba(255,255,255,.15);
  border-color: rgba(255,255,255,.25);
}

.suite-main-menu .suite-card.disabled {
  background: #ffffff;
}

.suite-main-menu .suite-card.disabled:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-soft);
}

@media (max-width: 1180px) {
  .suite-main-menu { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .suite-main-menu .suite-card.active { grid-column: span 2; }
}

@media (max-width: 720px) {
  .suite-section-head { display: block; }
  .suite-section-head p { margin-top: 8px; }
  .suite-main-menu { grid-template-columns: 1fr; }
  .suite-main-menu .suite-card.active { grid-column: span 1; }
  .suite-menu-hero { background: linear-gradient(135deg, #071b3f 0%, #123f88 100%); }
}



/* V6.2.8 — vraie page d'accueil ZYRAN Suite, sans chrome applicatif */
body.suite-landing-mode {
  overflow: auto;
  background:
    radial-gradient(circle at 12% 8%, rgba(215, 243, 108, .28), transparent 26%),
    radial-gradient(circle at 88% 0%, rgba(37, 99, 235, .12), transparent 28%),
    linear-gradient(180deg, #fbfaf5 0%, #f4f8ee 42%, #eef5f8 100%);
}

body.suite-landing-mode .zyran-app {
  display: block;
  min-height: 100vh;
}

body.suite-landing-mode .sidebar,
body.suite-landing-mode .topbar {
  display: none;
}

body.suite-landing-mode .app-area {
  min-height: 100vh;
}

body.suite-landing-mode .view {
  height: auto;
  min-height: 100vh;
  overflow: visible;
  padding: 0;
}

.suite-landing {
  min-height: 100vh;
  color: #111827;
}

.suite-landing-top {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  padding: 22px clamp(18px, 5vw, 70px);
  background: rgba(251, 250, 245, .82);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(17, 24, 39, .08);
}

.suite-brand-lockup {
  display: flex;
  align-items: center;
  gap: 14px;
}

.suite-brand-mark {
  width: 48px;
  height: 48px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  background: #111827;
  color: #d7f36c;
  font-weight: 950;
  letter-spacing: -.04em;
  box-shadow: 0 16px 36px rgba(17, 24, 39, .18);
}

.suite-brand-name {
  font-size: 22px;
  line-height: 1;
  font-weight: 950;
  letter-spacing: -.04em;
}

.suite-brand-sub {
  margin-top: 5px;
  color: #64748b;
  font-size: 11px;
  font-weight: 850;
  letter-spacing: .11em;
}

.suite-landing-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.suite-landing-main {
  width: min(1480px, calc(100% - 40px));
  margin: 0 auto;
  padding: 34px 0 72px;
}

.suite-landing-hero {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) 360px;
  gap: 28px;
  align-items: stretch;
  padding: clamp(34px, 5vw, 72px);
  min-height: 430px;
  border-radius: 38px;
  border: 1px solid rgba(17, 24, 39, .10);
  background:
    radial-gradient(circle at 90% 12%, rgba(215, 243, 108, .46), transparent 24%),
    radial-gradient(circle at 4% 0%, rgba(120, 152, 121, .18), transparent 32%),
    linear-gradient(135deg, #ffffff 0%, #f7f7ee 46%, #e7f0e2 100%);
  box-shadow: 0 34px 90px rgba(17, 24, 39, .10);
}

.suite-landing-hero::before {
  content: "";
  position: absolute;
  right: 34px;
  top: 34px;
  width: 132px;
  height: 132px;
  border-radius: 999px;
  border: 1px solid rgba(17, 24, 39, .12);
  background:
    linear-gradient(90deg, transparent 49%, rgba(17,24,39,.10) 50%, transparent 51%),
    linear-gradient(0deg, transparent 49%, rgba(17,24,39,.10) 50%, transparent 51%);
  opacity: .55;
}

.suite-landing-hero .suite-hero-copy {
  position: relative;
  z-index: 1;
  max-width: 840px;
}

.suite-landing-hero h2 {
  margin: 12px 0 18px;
  max-width: 760px;
  font-size: clamp(48px, 7vw, 92px);
  line-height: .88;
  letter-spacing: -.075em;
  color: #111827;
}

.suite-landing-hero p {
  margin: 0 0 12px;
  color: #5f6f85;
  font-size: clamp(16px, 1.5vw, 20px);
  line-height: 1.55;
}

.suite-landing-hero .suite-lead {
  color: #243827;
  font-weight: 760;
}

.suite-hero-panel {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  justify-content: end;
  gap: 12px;
  min-height: 270px;
  padding: 24px;
  border-radius: 28px;
  background: rgba(255,255,255,.62);
  border: 1px solid rgba(17, 24, 39, .10);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.72);
}

.suite-hero-panel b {
  font-size: 25px;
  line-height: 1.06;
  letter-spacing: -.04em;
}

.suite-hero-panel span {
  color: #5f6f85;
  line-height: 1.45;
  font-weight: 650;
}

.suite-mini-note {
  display: inline-flex;
  align-items: center;
  max-width: 380px;
  color: #5f6f85;
  font-size: 13px;
  font-weight: 750;
}

.suite-lab-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin: 26px 0;
}

.suite-lab-strip span {
  padding: 13px 14px;
  border-radius: 999px;
  border: 1px solid rgba(17, 24, 39, .10);
  background: rgba(255,255,255,.72);
  color: #29382d;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .10em;
  text-align: center;
  text-transform: uppercase;
}

body.suite-landing-mode .suite-section-head {
  margin: 30px 0 18px;
}

body.suite-landing-mode .suite-main-menu {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

body.suite-landing-mode .suite-main-menu .suite-card {
  min-height: 315px;
  border-radius: 30px;
}

body.suite-landing-mode .suite-main-menu .suite-card.active {
  grid-column: span 2;
  background:
    radial-gradient(circle at 86% 16%, rgba(215,243,108,.50), transparent 28%),
    linear-gradient(180deg, #111827 0%, #1f2937 100%);
  color: #fff;
  border-color: rgba(17, 24, 39, .34);
}

body.suite-landing-mode .suite-main-menu .suite-card.active .suite-card-title,
body.suite-landing-mode .suite-main-menu .suite-card.active .suite-card-sub,
body.suite-landing-mode .suite-main-menu .suite-card.active p,
body.suite-landing-mode .suite-main-menu .suite-card.active .suite-species-label,
body.suite-landing-mode .suite-main-menu .suite-card.active .suite-card-code,
body.suite-landing-mode .suite-main-menu .suite-card.active .suite-card-action {
  color: rgba(255,255,255,.90);
}

body.suite-landing-mode .suite-main-menu .suite-card.active .suite-species-list span {
  color: #fff;
  background: rgba(255,255,255,.13);
  border-color: rgba(255,255,255,.24);
}

.suite-integral-note {
  margin-top: 26px;
  display: flex;
  gap: 10px;
  align-items: center;
  padding: 18px 22px;
  border-radius: 22px;
  background: rgba(255,255,255,.76);
  border: 1px solid rgba(17, 24, 39, .09);
  color: #4b5563;
  box-shadow: 0 16px 34px rgba(17,24,39,.055);
}

.suite-integral-note b {
  color: #111827;
}

@media (max-width: 1160px) {
  .suite-landing-hero {
    grid-template-columns: 1fr;
  }
  body.suite-landing-mode .suite-main-menu {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  body.suite-landing-mode .suite-main-menu .suite-card.active {
    grid-column: span 2;
  }
  .suite-lab-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .suite-landing-top {
    position: static;
    flex-direction: column;
    align-items: stretch;
  }
  .suite-landing-actions {
    justify-content: stretch;
  }
  .suite-landing-actions button {
    flex: 1;
  }
  .suite-brand-sub {
    white-space: normal;
  }
  .suite-landing-main {
    width: min(100% - 24px, 1480px);
    padding-top: 18px;
  }
  .suite-landing-hero {
    padding: 26px;
    border-radius: 28px;
  }
  .suite-landing-hero h2 {
    font-size: 46px;
  }
  body.suite-landing-mode .suite-main-menu,
  .suite-lab-strip {
    grid-template-columns: 1fr;
  }
  body.suite-landing-mode .suite-main-menu .suite-card.active {
    grid-column: span 1;
  }
  .suite-integral-note {
    align-items: flex-start;
    flex-direction: column;
  }
}


/* V6.2.8 — accueil public ZYRAN Suite autonome, hors shell applicatif */
body.suite-public-page {
  margin: 0;
  min-height: 100vh;
  overflow: auto;
  color: #111827;
  background:
    radial-gradient(circle at 8% 4%, rgba(217, 249, 157, .55), transparent 26%),
    radial-gradient(circle at 88% 0%, rgba(37, 99, 235, .16), transparent 30%),
    linear-gradient(180deg, #fbfaf5 0%, #f6faee 42%, #edf6f8 100%);
}

.suite-public-page a { color: inherit; text-decoration: none; }

.suite-public-shell {
  width: min(100% - 44px, 1540px);
  margin: 0 auto;
  padding: 24px 0 38px;
}

.suite-public-header {
  min-height: 78px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 14px 0 28px;
}

.suite-public-brand {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
}

.suite-public-logo {
  width: 52px;
  height: 52px;
  display: inline-grid;
  place-items: center;
  border-radius: 18px;
  overflow: hidden;
  background: #101827;
  color: #d9f99d;
  box-shadow: 0 18px 34px rgba(17, 24, 39, .16);
  position: relative;
}

.suite-public-logo img {
  width: 36px;
  height: 36px;
  object-fit: contain;
  position: absolute;
}

.suite-public-logo b {
  font-size: 17px;
  letter-spacing: -.04em;
}

.suite-public-brand strong {
  display: block;
  font-size: 22px;
  font-weight: 1000;
  letter-spacing: -.04em;
}

.suite-public-brand small {
  display: block;
  margin-top: 2px;
  color: #536271;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .12em;
}

.suite-public-nav {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

.suite-public-nav a {
  padding: 11px 15px;
  border: 1px solid rgba(17, 24, 39, .10);
  border-radius: 999px;
  background: rgba(255, 255, 255, .58);
  color: #334155;
  font-size: 13px;
  font-weight: 900;
}

.suite-public-nav .suite-public-nav-primary {
  background: #111827;
  color: #fff;
  border-color: #111827;
}

.suite-public-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.42fr) minmax(320px, .58fr);
  gap: 22px;
  align-items: stretch;
}

.suite-public-hero-copy,
.suite-public-panel {
  border: 1px solid rgba(17, 24, 39, .10);
  border-radius: 38px;
  box-shadow: 0 28px 70px rgba(17, 24, 39, .10);
}

.suite-public-hero-copy {
  min-height: 430px;
  padding: clamp(32px, 5vw, 72px);
  background:
    radial-gradient(circle at 86% 18%, rgba(217, 249, 157, .44), transparent 28%),
    linear-gradient(135deg, #101827 0%, #1f2937 58%, #193f7f 100%);
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  overflow: hidden;
}

.suite-public-hero-copy::after {
  content: "";
  position: absolute;
  right: -110px;
  bottom: -130px;
  width: 360px;
  height: 360px;
  border-radius: 999px;
  background: rgba(217, 249, 157, .36);
}

.suite-public-kicker {
  display: inline-flex;
  width: fit-content;
  padding: 9px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  color: rgba(255,255,255,.86);
  font-size: 11px;
  font-weight: 1000;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.suite-public-section-title .suite-public-kicker {
  background: #e8f3d2;
  color: #3f6212;
}

.suite-public-hero h1 {
  max-width: 980px;
  margin: 24px 0 18px;
  font-size: clamp(46px, 7vw, 96px);
  line-height: .88;
  font-weight: 1000;
  letter-spacing: -.075em;
}

.suite-public-hero p {
  max-width: 760px;
  margin: 0;
  color: rgba(255,255,255,.80);
  font-size: 18px;
  line-height: 1.7;
}

.suite-public-actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 30px;
  position: relative;
  z-index: 1;
}

.suite-public-primary,
.suite-public-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 14px 20px;
  border-radius: 999px;
  font-weight: 1000;
}

.suite-public-primary {
  background: #d9f99d;
  color: #162013;
}

.suite-public-secondary {
  border: 1px solid rgba(255,255,255,.22);
  color: #fff;
  background: rgba(255,255,255,.08);
}

.suite-public-panel {
  padding: 34px;
  background: rgba(255, 255, 255, .72);
  backdrop-filter: blur(16px);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 22px;
}

.suite-public-panel span {
  color: #2563eb;
  font-size: 12px;
  font-weight: 1000;
  letter-spacing: .16em;
}

.suite-public-panel b {
  display: block;
  color: #111827;
  font-size: 36px;
  line-height: 1.02;
  letter-spacing: -.055em;
}

.suite-public-panel p {
  margin: 0;
  color: #596579;
  line-height: 1.72;
}

.suite-public-panel-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.suite-public-panel-grid small,
.suite-public-strip span {
  padding: 12px 14px;
  border-radius: 16px;
  background: #f7faed;
  border: 1px solid rgba(63, 98, 18, .12);
  color: #334155;
  font-size: 12px;
  font-weight: 950;
}

.suite-public-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin: 22px 0 32px;
}

.suite-public-strip span {
  background: rgba(255,255,255,.74);
  text-align: center;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.suite-public-section-title {
  display: grid;
  grid-template-columns: minmax(0, .8fr) minmax(280px, .45fr);
  gap: 20px;
  align-items: end;
  margin: 18px 0 18px;
}

.suite-public-section-title h2 {
  margin: 14px 0 0;
  font-size: clamp(34px, 5vw, 66px);
  line-height: .95;
  font-weight: 1000;
  letter-spacing: -.065em;
}

.suite-public-section-title p {
  margin: 0;
  color: #64748b;
  line-height: 1.72;
}

.suite-public-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.suite-public-card {
  min-height: 328px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(17,24,39,.10);
  border-radius: 32px;
  padding: 24px;
  background: rgba(255,255,255,.78);
  box-shadow: 0 20px 48px rgba(17,24,39,.075);
}

.suite-public-card::after {
  content: "";
  position: absolute;
  right: -56px;
  bottom: -66px;
  width: 150px;
  height: 150px;
  border-radius: 999px;
  background: rgba(217,249,157,.76);
}

.suite-public-card.is-active {
  grid-column: span 2;
  background:
    radial-gradient(circle at 90% 18%, rgba(217,249,157,.48), transparent 28%),
    linear-gradient(180deg, #111827 0%, #1f2937 100%);
  color: #fff;
}

.suite-public-index {
  position: absolute;
  right: 20px;
  top: 18px;
  color: rgba(15,23,42,.10);
  font-size: 52px;
  font-weight: 1000;
  letter-spacing: -.08em;
}

.suite-public-card.is-active .suite-public-index { color: rgba(255,255,255,.20); }

.suite-public-status {
  width: fit-content;
  padding: 7px 10px;
  border-radius: 999px;
  background: #eef7d5;
  color: #3f6212;
  font-size: 11px;
  font-weight: 1000;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.suite-public-card.is-active .suite-public-status {
  background: #d9f99d;
  color: #18230f;
}

.suite-public-code {
  margin-top: 10px;
  color: #64748b;
  font-size: 11px;
  font-weight: 1000;
  letter-spacing: .16em;
}

.suite-public-card.is-active .suite-public-code { color: rgba(255,255,255,.62); }

.suite-public-card strong {
  display: block;
  max-width: 88%;
  color: #111827;
  font-size: 26px;
  line-height: 1.02;
  font-weight: 1000;
  letter-spacing: -.055em;
}

.suite-public-card.is-active strong { color: #fff; }

.suite-public-card em {
  color: #334155;
  font-style: normal;
  font-weight: 900;
  font-size: 13px;
}

.suite-public-card.is-active em { color: rgba(255,255,255,.86); }

.suite-public-card p {
  margin: 0;
  color: #667085;
  line-height: 1.62;
  font-size: 14px;
}

.suite-public-card.is-active p { color: rgba(255,255,255,.75); }

.suite-public-species {
  margin-top: auto;
  color: #38503a;
  font-size: 12px;
  font-weight: 950;
  line-height: 1.62;
}

.suite-public-card.is-active .suite-public-species { color: #d9f99d; }

.suite-public-cta {
  display: inline-flex;
  width: fit-content;
  position: relative;
  z-index: 1;
  padding-top: 8px;
  color: #111827;
  font-weight: 1000;
  font-size: 14px;
}

.suite-public-card.is-active .suite-public-cta { color: #fff; }

.suite-public-footer {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-top: 28px;
  padding: 20px 0;
  color: #64748b;
  font-size: 13px;
  font-weight: 800;
}

@media (max-width: 1180px) {
  .suite-public-hero,
  .suite-public-section-title {
    grid-template-columns: 1fr;
  }
  .suite-public-grid,
  .suite-public-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .suite-public-card.is-active {
    grid-column: span 2;
  }
}

@media (max-width: 720px) {
  .suite-public-shell {
    width: min(100% - 24px, 1540px);
  }
  .suite-public-header,
  .suite-public-footer {
    align-items: flex-start;
    flex-direction: column;
  }
  .suite-public-nav {
    justify-content: flex-start;
  }
  .suite-public-hero-copy {
    min-height: auto;
    padding: 30px;
    border-radius: 28px;
  }
  .suite-public-hero h1 {
    font-size: 46px;
  }
  .suite-public-grid,
  .suite-public-strip,
  .suite-public-panel-grid {
    grid-template-columns: 1fr;
  }
  .suite-public-card.is-active {
    grid-column: span 1;
  }
}


/* ZYRAN V6.2.8 — Accueil public compact : menu des applications, séparé du dashboard interne */
body.zyran-suite-home {
  margin: 0;
  min-height: 100vh;
  overflow-x: hidden;
  background:
    radial-gradient(circle at 0 0, rgba(221, 255, 134, .55), transparent 34rem),
    radial-gradient(circle at 100% 100%, rgba(37, 99, 235, .10), transparent 36rem),
    #f7faef;
  color: #101828;
}

.suite-menu-shell {
  width: min(1180px, calc(100% - 32px));
  margin: 0 auto;
  padding: 18px 0 22px;
}

.suite-menu-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}

.suite-menu-brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: inherit;
}

.suite-menu-logo {
  width: 48px;
  height: 48px;
  border-radius: 15px;
  display: grid;
  place-items: center;
  background: #0f172a;
  color: #dfff68;
  overflow: hidden;
  box-shadow: 0 16px 34px rgba(15, 23, 42, .16);
  position: relative;
}

.suite-menu-logo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.suite-menu-logo b {
  position: absolute;
  font-size: 12px;
  letter-spacing: .08em;
}

.suite-menu-brand strong {
  display: block;
  font-size: 22px;
  letter-spacing: -.04em;
}

.suite-menu-brand small {
  display: block;
  color: #667085;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .18em;
}

.suite-menu-tag {
  border: 1px solid rgba(15, 23, 42, .10);
  background: rgba(255, 255, 255, .72);
  border-radius: 999px;
  padding: 10px 14px;
  color: #475467;
  font-size: 12px;
  font-weight: 900;
  box-shadow: 0 14px 30px rgba(15, 23, 42, .06);
}

.suite-menu-intro {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: end;
  border: 1px solid rgba(15, 23, 42, .10);
  background: rgba(255,255,255,.82);
  border-radius: 30px;
  padding: 24px;
  box-shadow: 0 22px 60px rgba(15, 23, 42, .08);
  margin-bottom: 12px;
}

.suite-menu-kicker {
  display: block;
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .22em;
  color: #2563eb;
  margin-bottom: 8px;
}

.suite-menu-intro h1 {
  margin: 0;
  font-size: clamp(34px, 5vw, 66px);
  line-height: .88;
  letter-spacing: -.07em;
}

.suite-menu-intro p {
  margin: 12px 0 0;
  max-width: 740px;
  color: #475467;
  line-height: 1.65;
  font-weight: 650;
}

.suite-menu-open {
  min-width: 230px;
  display: inline-flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  padding: 15px 18px;
  border-radius: 999px;
  background: #0f172a;
  color: #dfff68;
  text-decoration: none;
  font-weight: 950;
  box-shadow: 0 20px 44px rgba(15, 23, 42, .18);
}

.suite-menu-open span {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: rgba(223,255,104,.18);
}

.suite-menu-rules {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin: 12px 0;
}

.suite-menu-rules span {
  border: 1px solid rgba(15, 23, 42, .10);
  background: rgba(255,255,255,.76);
  border-radius: 999px;
  padding: 9px 12px;
  text-align: center;
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: #253048;
}

.suite-app-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-top: 12px;
}

.suite-app-card {
  min-height: 168px;
  border: 1px solid rgba(15, 23, 42, .10);
  border-radius: 24px;
  padding: 18px;
  background: rgba(255,255,255,.88);
  box-shadow: 0 18px 50px rgba(15, 23, 42, .08);
  position: relative;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.suite-app-card::after {
  content: "";
  position: absolute;
  right: -34px;
  bottom: -34px;
  width: 92px;
  height: 92px;
  border-radius: 999px;
  background: #e9ffc6;
  opacity: .9;
}

.suite-app-card.is-active {
  background: linear-gradient(135deg, #10233f, #1d4ed8);
  color: #fff;
  border-color: rgba(255,255,255,.24);
}

.suite-app-card.is-active::after {
  background: #dfff68;
  opacity: .62;
}

.suite-app-card.is-disabled {
  opacity: .96;
}

.suite-app-number {
  position: absolute;
  top: 12px;
  right: 16px;
  font-size: 34px;
  line-height: 1;
  font-weight: 950;
  letter-spacing: -.08em;
  color: rgba(15, 23, 42, .14);
}

.suite-app-card.is-active .suite-app-number {
  color: rgba(255,255,255,.28);
}

.suite-app-status {
  align-self: flex-start;
  border-radius: 999px;
  padding: 5px 9px;
  background: #eef7dd;
  color: #355314;
  font-size: 10px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .12em;
}

.suite-app-card.is-active .suite-app-status {
  background: #dfff68;
  color: #0f172a;
}

.suite-app-card strong {
  font-size: 21px;
  line-height: 1.05;
  letter-spacing: -.05em;
  max-width: 78%;
}

.suite-app-card em {
  font-style: normal;
  color: #667085;
  font-weight: 850;
  font-size: 12px;
}

.suite-app-card.is-active em {
  color: rgba(255,255,255,.82);
}

.suite-app-card p {
  margin: 0;
  color: #475467;
  line-height: 1.4;
  font-size: 12px;
  font-weight: 650;
}

.suite-app-card.is-active p {
  color: rgba(255,255,255,.88);
}

.suite-app-card small {
  margin-top: auto;
  color: #344054;
  font-weight: 850;
  font-size: 11px;
  line-height: 1.35;
  position: relative;
  z-index: 1;
}

.suite-app-card.is-active small {
  color: rgba(255,255,255,.88);
}

.suite-app-action {
  color: #1d4ed8;
  font-size: 12px;
  position: relative;
  z-index: 1;
}

.suite-app-card.is-active .suite-app-action {
  color: #dfff68;
}

.suite-menu-footer {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: #667085;
  font-size: 12px;
  font-weight: 800;
  margin-top: 16px;
  padding-bottom: 10px;
}

@media (max-width: 980px) {
  .suite-menu-intro {
    grid-template-columns: 1fr;
  }
  .suite-menu-rules {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .suite-app-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 620px) {
  .suite-menu-shell {
    width: min(100% - 20px, 560px);
    padding-top: 10px;
  }
  .suite-menu-header,
  .suite-menu-footer {
    align-items: flex-start;
    flex-direction: column;
  }
  .suite-menu-tag {
    border-radius: 16px;
  }
  .suite-menu-rules,
  .suite-app-grid {
    grid-template-columns: 1fr;
  }
  .suite-menu-intro {
    padding: 18px;
    border-radius: 22px;
  }
}


/* ZYRAN V6.2.8 — Icônes officielles optimisées pour le menu Suite */
.suite-menu-logo {
  width: 74px;
  height: 54px;
  border-radius: 14px;
  background: rgba(255, 255, 255, .80);
  color: inherit;
  padding: 6px;
  box-shadow: 0 14px 30px rgba(15, 23, 42, .08);
}

.suite-menu-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.suite-app-card {
  min-height: 222px;
  padding: 18px;
  padding-right: 112px;
  isolation: isolate;
}

.suite-app-card::after {
  right: -44px;
  bottom: -44px;
  width: 118px;
  height: 118px;
  opacity: .72;
}

.suite-app-card[data-edition="integral"]::after { background: #dfff68; }
.suite-app-card[data-edition="aqua"]::after { background: #c9fff7; }
.suite-app-card[data-edition="petfood"]::after { background: #ffe0a3; }
.suite-app-card[data-edition="ruminants"]::after { background: #ffd1a7; }
.suite-app-card[data-edition="equides-camelides-lapin"]::after { background: #d7ecff; }
.suite-app-card[data-edition="volaille"]::after { background: #ffd1d1; }
.suite-app-card[data-edition="blank"]::after { background: #eedcff; }
.suite-app-card[data-edition="data-packs"]::after { background: #fff0ad; }

.suite-app-media {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 82px;
  height: 82px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,.72);
  box-shadow: 0 12px 28px rgba(15, 23, 42, .14);
  overflow: hidden;
  z-index: 2;
}

.suite-app-media img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.suite-app-card.is-active .suite-app-media {
  width: 92px;
  height: 92px;
  background: rgba(255,255,255,.16);
  box-shadow: 0 18px 36px rgba(0, 0, 0, .22);
}

.suite-app-number {
  right: 20px;
  top: 100px;
  font-size: 22px;
  z-index: 1;
}

.suite-app-status,
.suite-app-card strong,
.suite-app-card em,
.suite-app-card p,
.suite-app-card small,
.suite-app-action {
  position: relative;
  z-index: 3;
}

.suite-app-card strong {
  max-width: 100%;
}

.suite-app-card p {
  max-width: 98%;
}

@media (max-width: 980px) {
  .suite-app-card {
    min-height: 214px;
  }
}

@media (max-width: 620px) {
  .suite-menu-logo {
    width: 68px;
    height: 50px;
  }
  .suite-app-card {
    min-height: 214px;
    padding-right: 104px;
  }
  .suite-app-media {
    width: 76px;
    height: 76px;
  }
  .suite-app-card.is-active .suite-app-media {
    width: 84px;
    height: 84px;
  }
}


/* ZYRAN V6.2.8 — Correctifs interface Suite : scroll, logo complet, icônes remplacées */
body.zyran-suite-home {
  height: auto;
  min-height: 100vh;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

body.zyran-suite-home .suite-menu-shell {
  padding-bottom: 44px;
}

.suite-menu-logo {
  width: 112px;
  height: 84px;
  border-radius: 0;
  background: transparent;
  padding: 0;
  box-shadow: none;
  overflow: visible;
  flex: 0 0 auto;
}

.suite-menu-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.suite-menu-brand {
  align-items: center;
}

.suite-app-media {
  background: rgba(255, 255, 255, .82);
}

.suite-app-media img {
  object-fit: contain;
}

@media (max-width: 620px) {
  .suite-menu-logo {
    width: 92px;
    height: 70px;
  }
  .suite-menu-brand strong {
    font-size: 20px;
  }
}

/* ZYRAN V6.2.8 — Correctif final scroll public : neutralise les règles historiques overflow:hidden!important */
html.zyran-suite-page {
  height: auto !important;
  min-height: 100% !important;
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: hidden !important;
  overflow-y: scroll !important;
  scroll-behavior: smooth;
}

html.zyran-suite-page body.zyran-suite-home,
body.zyran-suite-home {
  height: auto !important;
  min-height: 100vh !important;
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: hidden !important;
  overflow-y: visible !important;
  position: static !important;
}

html.zyran-suite-page .suite-menu-shell {
  min-height: auto !important;
  height: auto !important;
  overflow: visible !important;
  padding-bottom: 72px !important;
}

html.zyran-suite-page .suite-app-grid,
html.zyran-suite-page .suite-app-card {
  overflow: visible;
}

html.zyran-suite-page .suite-app-media img {
  object-fit: contain;
}

/* V6.3.1 app logo Inoiatech */
.sidebar .brand-mark {
  width: 52px;
  height: 44px;
  border-radius: 14px;
  background: #ffffff;
  padding: 3px;
  overflow: visible;
}
.sidebar .brand-mark img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
body.sidebar-collapsed .sidebar .brand-mark {
  width: 38px;
  height: 36px;
}



/* ZYRAN V6.3.3 — License Gate */
body.license-pending .zyran-app,
body.license-locked .zyran-app {
  display: grid;
}
.license-gate {
  min-height: 100vh;
  padding: 34px 18px;
  display: grid;
  place-items: center;
  background:
    radial-gradient(circle at 20% 0%, rgba(37, 99, 235, .18), transparent 34%),
    radial-gradient(circle at 80% 15%, rgba(5, 150, 105, .16), transparent 30%),
    #f3f7fc;
  color: #0f172a;
  overflow-y: auto;
}
.license-card {
  width: min(560px, 100%);
  background: rgba(255, 255, 255, .94);
  border: 1px solid #dbe5f1;
  border-radius: 24px;
  padding: 26px;
  box-shadow: 0 22px 60px rgba(15, 23, 42, .12);
}
.license-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 18px;
}
.license-brand img {
  width: 52px;
  height: 52px;
  object-fit: contain;
  border-radius: 14px;
  background: #fff;
  border: 1px solid #e2e8f0;
}
.license-brand strong {
  display: block;
  color: #1e40af;
  font-size: 18px;
  letter-spacing: .02em;
}
.license-brand span {
  display: block;
  color: #64748b;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.license-card h1 {
  margin: 0 0 8px;
  font-size: clamp(26px, 4vw, 38px);
  line-height: 1.05;
}
.license-card p {
  color: #64748b;
  line-height: 1.55;
  margin: 0 0 20px;
}
.license-card form {
  display: grid;
  gap: 14px;
}
.license-card label {
  display: grid;
  gap: 7px;
  color: #334155;
  font-size: 13px;
  font-weight: 850;
}
.license-card input {
  width: 100%;
  border: 1px solid #cbd5e1;
  border-radius: 14px;
  background: #fff;
  padding: 13px 14px;
  color: #0f172a;
  outline: none;
}
.license-card input:focus {
  border-color: #2563eb;
  box-shadow: 0 0 0 4px rgba(37, 99, 235, .12);
}
.license-card button {
  border: 0;
  border-radius: 15px;
  background: linear-gradient(135deg, #1e40af, #2563eb);
  color: #fff;
  padding: 13px 16px;
  font-weight: 950;
  box-shadow: 0 14px 28px rgba(37, 99, 235, .22);
}
.license-message {
  margin-top: 14px;
  border: 1px solid #dbe5f1;
  border-radius: 15px;
  background: #f8fafc;
  padding: 12px 14px;
  color: #475569;
  font-weight: 750;
}
.license-message.ok { background: #ecfdf5; border-color: #bbf7d0; color: #047857; }
.license-message.warn { background: #fff7ed; border-color: #fed7aa; color: #c2410c; }
.license-message.danger { background: #fff1f2; border-color: #fecdd3; color: #be123c; }
.license-message.info { background: #eff6ff; border-color: #bfdbfe; color: #1d4ed8; }
.license-help {
  display: grid;
  gap: 4px;
  margin-top: 14px;
  color: #64748b;
  font-size: 12px;
}
.license-reset {
  margin-top: 14px;
  background: #eef4ff !important;
  color: #1e40af !important;
  box-shadow: none !important;
}
.license-grace-banner {
  position: fixed;
  left: 50%;
  bottom: 18px;
  transform: translateX(-50%);
  z-index: 9999;
  width: min(720px, calc(100% - 28px));
  border: 1px solid #fed7aa;
  border-radius: 16px;
  background: #fff7ed;
  color: #9a3412;
  box-shadow: 0 16px 38px rgba(15, 23, 42, .14);
  padding: 12px 16px;
  font-size: 13px;
  font-weight: 850;
  text-align: center;
}



/* ZYRAN V7.0.3 — mode aperçu public + accès administrateur/licence.
   L'application reste toujours visible : aucune édition ne doit afficher un écran vide. */
body.license-pending .zyran-app,
body.license-locked .zyran-app {
  display: grid;
}

body.license-preview .top-actions .primary-top {
  opacity: .88;
}

body.license-preview .view input,
body.license-preview .view textarea,
body.license-preview .view select {
  background: #f8fafc;
  cursor: not-allowed;
}

.license-preview-bar {
  position: fixed;
  left: 50%;
  bottom: 16px;
  transform: translateX(-50%);
  z-index: 9997;
  width: min(880px, calc(100% - 28px));
  border: 1px solid rgba(37, 99, 235, .22);
  border-radius: 18px;
  background: rgba(255, 255, 255, .96);
  color: #0f172a;
  box-shadow: 0 18px 44px rgba(15, 23, 42, .16);
  padding: 12px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  backdrop-filter: blur(14px);
}

.license-preview-bar strong {
  display: block;
  color: #1e40af;
  font-size: 13px;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.license-preview-bar span {
  display: block;
  color: #475569;
  font-size: 12px;
  font-weight: 750;
  line-height: 1.35;
}

.license-preview-bar button,
.license-preview-badge {
  border: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, #1e40af, #2563eb);
  color: #fff;
  padding: 10px 13px;
  font-size: 12px;
  font-weight: 950;
  cursor: pointer;
  box-shadow: 0 12px 28px rgba(37, 99, 235, .22);
  white-space: nowrap;
}

.license-preview-badge {
  position: fixed;
  right: 18px;
  top: 72px;
  z-index: 9996;
  padding: 8px 12px;
  background: #eaf2ff;
  color: #1e40af;
  border: 1px solid #bfdbfe;
  box-shadow: 0 10px 22px rgba(15, 23, 42, .12);
}

.license-gate {
  position: fixed;
  inset: 0;
  z-index: 9999;
  min-height: 100vh;
  padding: 34px 18px;
  display: grid;
  place-items: center;
  background:
    radial-gradient(circle at 20% 0%, rgba(37, 99, 235, .18), transparent 34%),
    radial-gradient(circle at 80% 15%, rgba(5, 150, 105, .16), transparent 30%),
    rgba(243, 247, 252, .96);
  color: #0f172a;
  overflow-y: auto;
  backdrop-filter: blur(10px);
}

.license-card {
  position: relative;
  width: min(560px, 100%);
  background: rgba(255, 255, 255, .97);
  border: 1px solid #dbe5f1;
  border-radius: 24px;
  padding: 26px;
  box-shadow: 0 22px 60px rgba(15, 23, 42, .18);
}

.license-close {
  position: absolute;
  right: 14px;
  top: 14px;
  width: 34px;
  height: 34px;
  border: 1px solid #dbe5f1 !important;
  border-radius: 999px !important;
  background: #fff !important;
  color: #0f172a !important;
  box-shadow: none !important;
  font-size: 22px;
  line-height: 1;
}

@media (max-width: 760px) {
  .license-preview-bar {
    align-items: stretch;
    flex-direction: column;
  }
  .license-preview-bar button {
    width: 100%;
  }
  .license-preview-badge {
    right: 12px;
    top: 62px;
  }
}
