/* ════════════════════════════════════════════════════════════════
   DentalStock — design Flux (ex-2.0, promue LA version le 06/06/2026).
   CSS transposé de maquette-stock-flux-reference.html (contrat visuel
   validé). Scoping conservé de la phase strangler (sans risque) :
   - tokens déclarés sur .s2 (jamais :root) — zéro collision agenda/portail
   - toutes les classes préfixées s2- — styles.css ne peut pas fuir ici
   ════════════════════════════════════════════════════════════════ */
.s2{
  --ivory:#FAF6EE; --ivory-soft:#F2EBDB; --ivory-deep:#E9DFC8; --paper:#FFFCF5;
  --rule:#D9CDB2; --rule-soft:#E8DDC4;
  --terracotta:#B85940; --terracotta-deep:#8C3D2A; --terracotta-light:#D88466;
  --terracotta-bg:#F4DFD3; --terracotta-mist:#FBEEE5;
  --sage:#6B7A5A; --sage-deep:#4F5C42; --sage-bg:#E4E8DD;
  --ink:#2A1F18; --ink-soft:#4A3D33; --ink-mute:#8B7B6A; --ink-faint:#B5A89A;
  --danger:#A6321F; --danger-bg:#F7DDD5; --warn:#C68A2E; --warn-bg:#F5E7C9;
  --shadow-sm:0 1px 2px rgba(60,40,25,.05); --shadow-md:0 4px 12px rgba(60,40,25,.08);
  --shadow-lg:0 12px 32px rgba(60,40,25,.12);
  --serif:'Fraunces','Cormorant Garamond',Georgia,serif;
  --sans:'Manrope',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --radius-sm:4px; --radius:8px; --radius-lg:14px;
  font-family:var(--sans); color:var(--ink); font-size:14px;
  background:var(--ivory);
}
.s2 *{box-sizing:border-box}
.s2 .s2-icon{width:15px;height:15px;stroke:currentColor;stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round;vertical-align:-2px;flex-shrink:0;}
.s2 .s2-icon.lg{width:19px;height:19px;}

/* Header éditorial */
.s2 .s2-header{background:var(--ivory-soft);border-bottom:1px solid var(--rule);padding:24px 48px 20px;position:relative;margin:0;}
.s2 .s2-header::after{content:'';position:absolute;left:48px;right:48px;bottom:-1px;height:1px;
  background:linear-gradient(90deg,var(--terracotta) 0 40px,var(--rule) 40px);}
.s2 .s2-version-badge{font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--terracotta);}
.s2 .s2-header h1{font-family:var(--serif);font-size:30px;font-weight:300;font-style:italic;letter-spacing:-.01em;margin:5px 0 0;color:var(--ink);}
.s2 .s2-header h1 .s2-amp{color:var(--terracotta);font-style:normal;}
.s2 .s2-beta{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  background:var(--terracotta);color:var(--paper);border-radius:99px;padding:2px 10px;vertical-align:6px;margin-left:10px;}

/* Onglets + actions barre */
.s2 .s2-tabs{display:flex;gap:8px;background:var(--ivory-soft);border-bottom:1px solid var(--rule);padding:13px 48px;
  flex-wrap:wrap;position:sticky;top:0;z-index:300;align-items:center;margin:0;}
.s2 .s2-tab{background:var(--paper);border:1px solid var(--rule);border-radius:99px;padding:10px 20px;font-family:var(--serif);
  font-size:15px;color:var(--ink-mute);display:inline-flex;align-items:center;gap:9px;cursor:pointer;white-space:nowrap;transition:all .2s;font-style:normal;font-weight:400;}
.s2 .s2-tab:hover{background:var(--ivory-deep);color:var(--ink);border-color:var(--ink-mute);transform:none;}
.s2 .s2-tab.active{background:var(--terracotta);color:var(--paper);border-color:var(--terracotta);
  box-shadow:0 6px 16px rgba(184,89,64,.25);font-style:italic;font-weight:500;}
.s2 .s2-tab-badge{display:inline-block;background:var(--terracotta);color:var(--paper);font-size:11px;font-weight:700;
  padding:2px 8px;border-radius:99px;min-width:21px;text-align:center;font-family:var(--sans);font-style:normal;}
.s2 .s2-tab-badge.off{display:none;}
.s2 .s2-tab.active .s2-tab-badge{background:var(--paper);color:var(--terracotta);}
.s2 .s2-tab-badge.alert{background:var(--danger);}
.s2 .s2-tab.active .s2-tab-badge.alert{background:var(--paper);color:var(--danger);}
/* Pastille STOCK (à commander) — ambre : grammaire validée 06/06,
   « ambre = commander, rouge = agir cliniquement ». Alignée sur la
   bannière interne « à commander » (warn). */
.s2 .s2-tab-badge.stock{background:var(--warn);}
.s2 .s2-tab.active .s2-tab-badge.stock{background:var(--paper);color:var(--warn);}
.s2 .s2-tabs-actions{margin-left:auto;display:flex;gap:8px;align-items:center;flex-wrap:wrap;}
.s2 .s2-tss{display:inline-flex;align-items:center;gap:8px;background:var(--paper);border:1px solid var(--rule);
  border-radius:99px;padding:8px 14px;color:var(--ink-faint);font-size:12px;font-style:italic;cursor:pointer;font-family:var(--sans);}
.s2 .s2-tss kbd{font-family:var(--sans);font-style:normal;font-size:10px;font-weight:700;color:var(--ink-mute);
  border:1px solid var(--rule);border-radius:4px;padding:1px 5px;background:var(--ivory-soft);}
.s2 .s2-tbtn{display:inline-flex;align-items:center;gap:7px;font-family:var(--sans);font-size:12.5px;font-weight:600;
  color:var(--ink-soft);background:var(--paper);border:1px solid var(--rule);border-radius:99px;padding:8px 14px;cursor:pointer;}
.s2 .s2-tbtn:hover{border-color:var(--ink-mute);}
.s2 .s2-dd{position:relative;}
.s2 .s2-dd-menu{display:none;position:absolute;right:0;top:calc(100% + 6px);background:var(--paper);
  border:1px solid var(--rule);border-radius:var(--radius);box-shadow:var(--shadow-md);min-width:240px;z-index:350;padding:5px;}
.s2 .s2-dd-menu.show{display:block;}
.s2 .s2-dd-item{display:flex;align-items:center;gap:9px;width:100%;text-align:left;border:none;background:none;
  font-family:var(--sans);font-size:13px;color:var(--ink-soft);padding:9px 12px;border-radius:var(--radius-sm);cursor:pointer;}
.s2 .s2-dd-item:hover{background:var(--ivory-soft);color:var(--ink);}
.s2 .s2-dd-sep{height:1px;background:var(--rule-soft);margin:5px 8px;}
.s2 .s2-dd-label{font-size:9.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);padding:7px 12px 3px;}

/* Écrans */
.s2 .s2-screen{display:none;}
.s2 .s2-screen.on{display:block;animation:s2fade .22s ease;}
@keyframes s2fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.s2 .s2-content{padding:24px 48px 56px;background:var(--paper);min-height:62vh;}
.s2 .s2-section-title{font-family:var(--serif);font-size:22px;font-weight:300;font-style:italic;color:var(--ink);
  margin:30px 0 18px;padding-bottom:13px;border-bottom:1px solid var(--rule);display:flex;align-items:baseline;gap:14px;position:relative;flex-wrap:wrap;}
.s2 .s2-section-title:first-child{margin-top:0;}
.s2 .s2-section-title::before{content:'';position:absolute;bottom:-1px;left:0;width:40px;height:2px;background:var(--terracotta);}
.s2 .s2-section-actions{margin-left:auto;display:flex;gap:8px;font-family:var(--sans);font-size:13px;font-style:normal;align-items:center;flex-wrap:wrap;}
.s2 .s2-btn{font-family:var(--sans);font-size:13px;font-weight:600;border-radius:var(--radius);padding:9px 17px;
  border:1px solid var(--rule);background:var(--paper);color:var(--ink-soft);cursor:pointer;display:inline-flex;align-items:center;gap:7px;}
.s2 .s2-btn:hover{border-color:var(--ink-mute);background:var(--paper);transform:none;}
.s2 .s2-btn.primary{background:var(--terracotta);border-color:var(--terracotta);color:var(--paper);}
.s2 .s2-btn.primary:hover{background:var(--terracotta-deep);}
.s2 .s2-btn.danger{background:var(--danger);border-color:var(--danger);color:var(--paper);}
.s2 .s2-btn.sm{padding:5px 11px;font-size:11.5px;border-radius:var(--radius-sm);}
.s2 .s2-muted{font-size:12px;color:var(--ink-faint);font-style:italic;margin:8px 0 0;}
.s2 .s2-sim-tag{display:inline-block;font-size:9.5px;font-weight:700;letter-spacing:.08em;border-radius:99px;padding:2px 9px;
  background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger);vertical-align:1px;text-transform:uppercase;}

/* Barres d'outils / filtres */
.s2 .s2-tools{display:flex;gap:9px;align-items:center;margin-bottom:15px;flex-wrap:wrap;}
.s2 .s2-tsearch{display:flex;align-items:center;gap:8px;background:var(--paper);border:1px solid var(--rule);
  border-radius:99px;padding:8px 15px;min-width:230px;}
.s2 .s2-tsearch input{border:none;outline:none;background:transparent;font-family:var(--sans);font-size:12.5px;color:var(--ink);width:100%;padding:0;}
.s2 .s2-tsearch input::placeholder{color:var(--ink-faint);font-style:italic;}
/* width:auto + flex:none EXPLICITES : neutralisent le select{width:100%}
   global de styles.css (V1) qui fuyait dans la vue (bug capture 06/06). */
.s2 .s2-tfilter{font-size:12.5px;font-weight:600;color:var(--ink-soft);background:var(--paper);border:1px solid var(--rule);
  border-radius:99px;padding:8px 13px;cursor:pointer;font-family:var(--sans);
  width:auto;max-width:none;flex:0 0 auto;display:inline-block;margin:0;box-shadow:none;}
.s2 .s2-tools{align-items:center;}
.s2 .s2-tools .s2-tsearch{flex:0 1 280px;}
.s2 .s2-treset{font-size:12px;font-weight:600;color:var(--ink-mute);background:none;border:none;cursor:pointer;
  text-decoration:underline;text-underline-offset:2px;font-family:var(--sans);}
.s2 .s2-seg{display:inline-flex;background:var(--ivory-soft);border:1px solid var(--rule);border-radius:99px;padding:3px;gap:2px;}
.s2 .s2-seg button{border:none;background:transparent;border-radius:99px;font-family:var(--sans);font-size:12.5px;
  font-weight:600;color:var(--ink-mute);padding:8px 17px;cursor:pointer;display:inline-flex;gap:7px;align-items:center;}
.s2 .s2-seg button.on{background:var(--terracotta);color:var(--paper);box-shadow:0 4px 10px rgba(184,89,64,.25);}
.s2 .s2-seg .n{font-size:10.5px;font-weight:700;background:rgba(255,255,255,.25);border-radius:99px;padding:1px 7px;}
.s2 .s2-seg button:not(.on) .n{background:var(--ivory-deep);color:var(--ink-mute);}

/* Bandeau alerte + CTA */
.s2 .s2-alert-banner{display:flex;align-items:center;gap:11px;background:var(--warn-bg);border:1px solid var(--warn);
  border-radius:var(--radius);padding:10px 16px;margin-bottom:16px;cursor:pointer;font-size:13px;color:var(--ink-soft);}
.s2 .s2-alert-banner b{font-family:var(--serif);font-style:italic;font-size:17px;color:var(--warn);}
/* Variante CLINIQUE du bandeau — alerte sans-couronne >6 mois (registre) */
.s2 .s2-alert-banner.clinic{background:var(--danger-bg);border-color:var(--danger);}
.s2 .s2-alert-banner.clinic b{color:var(--danger);}
.s2 .s2-cta-add{display:flex;align-items:center;gap:13px;width:100%;background:var(--paper);border:1px dashed var(--terracotta-light);
  border-radius:var(--radius-lg);padding:14px 20px;cursor:pointer;margin-bottom:18px;font-family:var(--sans);text-align:left;}
.s2 .s2-cta-add:hover{background:var(--terracotta-mist);}
.s2 .s2-cta-add .ci{width:34px;height:34px;border-radius:50%;background:var(--terracotta);color:var(--paper);
  display:inline-flex;align-items:center;justify-content:center;font-size:19px;font-weight:300;flex-shrink:0;}
.s2 .s2-cta-add b{font-family:var(--serif);font-style:italic;font-size:16.5px;font-weight:500;color:var(--ink);display:block;}
.s2 .s2-cta-add small{font-size:11.5px;color:var(--ink-mute);}

/* Pipeline */
.s2 .s2-board{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;align-items:start;}
.s2 .s2-board.two{grid-template-columns:repeat(2,minmax(0,1fr));}
.s2 .s2-col{background:var(--ivory-soft);border:1px solid var(--rule-soft);border-radius:var(--radius-lg);padding:13px;display:flex;flex-direction:column;}
.s2 .s2-col-head{display:flex;align-items:baseline;gap:9px;padding:2px 4px 11px;}
.s2 .s2-col-head h3{font-family:var(--serif);font-size:16.5px;font-weight:400;font-style:italic;color:var(--ink);margin:0;}
.s2 .s2-col-count{font-size:11px;font-weight:700;background:var(--paper);border:1px solid var(--rule);color:var(--ink-mute);border-radius:99px;padding:1px 9px;}
/* Pastille clinique du header de colonne (implants posés sans couronne
   >6 mois) — rouge = agir, halo pulsant, masquée à 0, clic → registre
   filtré « Sans couronne >6 mois » */
.s2 .s2-col-alert{font-size:11px;font-weight:700;background:var(--danger);color:var(--paper);border-radius:99px;padding:1px 9px;cursor:pointer;animation:s2LatePulse 3s ease-in-out infinite;}
.s2 .s2-col-alert.off{display:none;}
@media (prefers-reduced-motion: reduce){.s2 .s2-col-alert{animation:none;}}
.s2 .s2-col-hint{margin-left:auto;font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);}
.s2 .s2-col-body{overflow-y:auto;max-height:530px;padding-right:2px;}
.s2 .s2-col-body::-webkit-scrollbar{width:6px}
.s2 .s2-col-body::-webkit-scrollbar-thumb{background:var(--rule);border-radius:99px}
/* Carte de travail — identité praticien renforcée (bande 6px + tint 18%) */
.s2 .s2-fcard{background:linear-gradient(90deg,color-mix(in srgb,var(--prat,transparent) 18%,var(--paper)) 0%,var(--paper) 62%);
  border:1px solid var(--rule-soft);border-radius:var(--radius);padding:10px 12px 9px 17px;
  margin-bottom:8px;position:relative;cursor:pointer;box-shadow:var(--shadow-sm);}
.s2 .s2-fcard::before{content:'';position:absolute;left:0;top:0;bottom:0;width:6px;border-radius:var(--radius) 0 0 var(--radius);background:var(--prat,var(--rule));}
.s2 .s2-fcard:hover{border-color:var(--ink-faint);box-shadow:var(--shadow-md);}
.s2 .s2-fcard.late{background:linear-gradient(90deg,var(--danger-bg) 0,var(--paper) 70%);border-color:var(--danger);}
@keyframes s2LatePulse{
  0%,100%{box-shadow:0 0 0 1px var(--danger-bg);}
  50%{box-shadow:0 0 0 5px color-mix(in srgb,var(--danger) 14%,transparent);}
}
.s2 .s2-fcard.late{animation:s2LatePulse 3s ease-in-out infinite;}
@media (prefers-reduced-motion: reduce){.s2 .s2-fcard.late{animation:none;}}
.s2 .s2-sortbtn{margin-left:6px;border:1px solid var(--rule);background:var(--paper);border-radius:99px;
  font-family:var(--sans);font-size:10px;font-weight:700;color:var(--ink-mute);padding:3px 10px;cursor:pointer;white-space:nowrap;}
.s2 .s2-sortbtn:hover{border-color:var(--terracotta);color:var(--terracotta);}
.s2 .s2-fcard-top{display:flex;align-items:baseline;gap:8px;}
.s2 .s2-fcard-patient{font-weight:600;font-size:13px;color:var(--ink);}
.s2 .s2-fcard-date{margin-left:auto;font-family:var(--serif);font-style:italic;font-size:11.5px;color:var(--ink-mute);white-space:nowrap;}
.s2 .s2-fcard.late .s2-fcard-date{color:var(--danger);font-weight:600;}
.s2 .s2-fcard-what{font-size:12px;color:var(--ink-soft);margin-top:2px;}
.s2 .s2-fcard-meta{display:flex;gap:6px;margin-top:6px;font-size:10.5px;color:var(--ink-mute);align-items:center;flex-wrap:wrap;}
.s2 .s2-fcard-prat{font-weight:700;color:var(--prat,var(--ink-mute));}
.s2 .s2-fpill{border:1px solid var(--rule);border-radius:99px;padding:1px 8px;background:var(--ivory);white-space:nowrap;}
.s2 .s2-fpill.lab{border-color:var(--warn);color:var(--warn);background:var(--warn-bg);}
.s2 .s2-fpill.ok{border-color:var(--sage);color:var(--sage-deep);background:var(--sage-bg);}
.s2 .s2-fpill.bad{border-color:var(--danger);color:var(--danger);background:var(--danger-bg);}
.s2 .s2-fpill.etape{border-color:var(--terracotta-light);color:var(--terracotta-deep);background:var(--terracotta-mist);}
.s2 .s2-fcard-quick{position:absolute;right:8px;bottom:7px;display:none;gap:4px;}
.s2 .s2-fcard:hover .s2-fcard-quick{display:flex;}
.s2 .s2-fcard-quick button{border:1px solid var(--rule);background:var(--paper);border-radius:var(--radius-sm);
  padding:3px 8px;font-size:10.5px;font-weight:700;color:var(--ink-soft);cursor:pointer;font-family:var(--sans);}
.s2 .s2-fcard-quick button:hover{border-color:var(--terracotta);color:var(--terracotta);}
.s2 .s2-fcard .s2-check{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;color:var(--ink-mute);cursor:pointer;}
.s2 .s2-col-empty{font-size:12px;color:var(--ink-faint);font-style:italic;text-align:center;padding:18px 6px;}

/* Registre / tables */
.s2 .s2-registre-strip{margin-top:18px;display:flex;align-items:center;gap:13px;background:var(--paper);
  border:1px dashed var(--rule);border-radius:var(--radius-lg);padding:14px 19px;color:var(--ink-mute);font-size:13px;}
.s2 .s2-registre-strip b{font-family:var(--serif);font-style:italic;font-size:15.5px;color:var(--ink);font-weight:500;}
.s2 .s2-open-link{margin-left:auto;font-weight:700;font-size:12px;color:var(--terracotta);border:1px solid var(--terracotta);
  border-radius:99px;padding:6px 14px;cursor:pointer;white-space:nowrap;background:var(--paper);font-family:var(--sans);}
.s2 .s2-open-link:hover{background:var(--terracotta-mist);}
.s2 .s2-table-card{border:1px solid var(--rule);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);background:var(--paper);}
.s2 .s2-table-scroll{max-height:460px;overflow-y:auto;}
.s2 table{width:100%;border-collapse:collapse;background:var(--paper);font-size:13px;table-layout:auto;}
.s2 .s2-aug th{position:sticky;top:0;z-index:2;text-align:left;padding:11px 11px;font-size:10px;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute);background:var(--ivory-soft);
  border-bottom:1px solid var(--rule);white-space:nowrap;box-shadow:0 1px 0 var(--rule);}
.s2 .s2-aug th.sortable{cursor:pointer;}
.s2 .s2-aug th.sortable:hover{color:var(--terracotta);}
.s2 .s2-aug th .arr{opacity:.45;font-size:9px;margin-left:3px;}
.s2 .s2-aug th.sort-on{color:var(--terracotta);} .s2 .s2-aug th.sort-on .arr{opacity:1;}
.s2 .s2-aug th.num,.s2 .s2-aug td.num{text-align:right;}
.s2 .s2-aug td{padding:9px 11px;color:var(--ink-soft);vertical-align:middle;border-bottom:1px solid var(--rule-soft);max-width:none;overflow:visible;}
.s2 .s2-aug tbody tr:hover{background:var(--ivory-soft);}
.s2 .s2-aug td.num{font-family:var(--serif);font-style:italic;font-size:13.5px;color:var(--ink);white-space:nowrap;}
.s2 .s2-aug tr.prat{background-image:linear-gradient(90deg,color-mix(in srgb,var(--prat,transparent) 12%,transparent) 0%,transparent 70%);}
.s2 .s2-aug tr.prat td:first-child{position:relative;padding-left:19px;}
.s2 .s2-aug tr.prat td:first-child::before{content:'';position:absolute;left:0;top:3px;bottom:3px;width:5px;border-radius:3px;background:var(--prat,var(--ink-mute));}
.s2 .s2-aug .patient{font-weight:600;color:var(--ink);}
.s2 .s2-aug tr.late td{background:linear-gradient(90deg,var(--danger-bg) 0,transparent 80%);}
.s2 .s2-aug .row-acts{display:flex;gap:4px;justify-content:flex-end;opacity:0;transition:opacity .15s;}
.s2 .s2-aug tbody tr:hover .row-acts{opacity:1;}
.s2 .s2-aug .row-acts button{border:1px solid var(--rule);background:var(--paper);border-radius:var(--radius-sm);
  padding:3px 8px;font-size:10.5px;font-weight:600;color:var(--ink-soft);cursor:pointer;font-family:var(--sans);}
.s2 .s2-aug .row-acts button:hover{border-color:var(--terracotta);color:var(--terracotta);}
.s2 .s2-table-foot{display:flex;align-items:center;gap:13px;padding:11px 15px;background:var(--ivory-soft);
  border-top:1px solid var(--rule);font-size:12px;color:var(--ink-mute);flex-wrap:wrap;}
.s2 .s2-table-foot .pages{margin-left:auto;display:flex;gap:4px;align-items:center;}
.s2 .s2-page-btn{min-width:27px;height:27px;border:1px solid var(--rule);border-radius:var(--radius-sm);background:var(--paper);
  font-size:12px;font-weight:600;color:var(--ink-soft);cursor:pointer;}
.s2 .s2-page-btn.active{background:var(--terracotta);border-color:var(--terracotta);color:var(--paper);}
.s2 .s2-st{font-size:10px;font-weight:700;letter-spacing:.04em;border-radius:99px;padding:2px 9px;white-space:nowrap;}
.s2 .s2-st.ok{background:var(--sage-bg);color:var(--sage-deep);border:1px solid var(--sage);}
.s2 .s2-st.cmd{background:var(--warn-bg);color:var(--warn);border:1px solid var(--warn);}
.s2 .s2-st.rupture,.s2 .s2-st.retard{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger);}
.s2 .s2-st.plan{background:var(--ivory-deep);color:var(--ink-soft);border:1px solid var(--rule);}
.s2 .s2-st.labo{background:var(--warn-bg);color:var(--warn);border:1px solid var(--warn);}
.s2 .s2-st.recue{background:var(--sage-bg);color:var(--sage-deep);border:1px solid var(--sage);}

/* Cartes stock (ajustement 9) */
.s2 .s2-stock-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:13px;margin-bottom:6px;}
.s2 .s2-scard{background:var(--paper);border:1px solid var(--rule-soft);border-radius:var(--radius);padding:13px 15px;box-shadow:var(--shadow-sm);}
.s2 .s2-scard.low{border-color:var(--warn);}
.s2 .s2-scard.out{border-color:var(--danger);background:linear-gradient(90deg,var(--danger-bg) 0,var(--paper) 75%);}
.s2 .s2-scard-ref{font-weight:700;font-size:13.5px;color:var(--ink);}
.s2 .s2-scard-fab{font-size:11px;color:var(--ink-mute);margin-top:1px;}
.s2 .s2-scard-line{display:flex;align-items:baseline;gap:9px;margin-top:9px;}
.s2 .s2-scard-qty{font-family:var(--serif);font-size:30px;font-weight:300;color:var(--ink);line-height:1;}
.s2 .s2-scard.low .s2-scard-qty{color:var(--warn);} .s2 .s2-scard.out .s2-scard-qty{color:var(--danger);}
.s2 .s2-scard-virt{font-size:11px;color:var(--ink-mute);font-style:italic;}
.s2 .s2-scard-line .s2-st{margin-left:auto;}
.s2 .s2-scard-meta{display:flex;gap:9px;flex-wrap:wrap;margin-top:9px;padding-top:8px;border-top:1px solid var(--rule-soft);
  font-size:10.5px;color:var(--ink-mute);align-items:center;}
.s2 .s2-scard-meta b{color:var(--ink-soft);}
.s2 .s2-scard-meta .addstock{margin-left:auto;}

/* Ma journée */
.s2 .s2-mj{margin-bottom:24px;padding:20px 24px;background:linear-gradient(135deg,var(--ivory-soft) 0%,var(--ivory-deep) 100%);
  border:1px solid var(--rule);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);position:relative;overflow:hidden;}
.s2 .s2-mj::before{content:'';position:absolute;top:0;left:0;bottom:0;width:4px;background:var(--terracotta);}
.s2 .s2-mj-eyebrow{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.18em;color:var(--terracotta);margin-bottom:5px;}
.s2 .s2-mj-title{font-family:var(--serif);font-size:24px;font-weight:400;font-style:italic;margin:0 0 4px;color:var(--ink);}
.s2 .s2-mj-legend{font-size:11px;color:var(--ink-mute);font-style:italic;margin:0 0 12px;}
.s2 .s2-mj-list{display:flex;flex-direction:column;gap:7px;}
.s2 .s2-mj-item{display:flex;align-items:center;gap:12px;padding:11px 15px;background:var(--paper);border:1px solid var(--rule-soft);border-radius:var(--radius);cursor:pointer;}
.s2 .s2-mj-item:hover{background:var(--terracotta-mist);border-color:var(--terracotta);}
.s2 .s2-mj-item.urgent{background:var(--danger-bg);border-color:var(--danger);}
.s2 .s2-mj-kind{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute);
  border:1px solid var(--rule);border-radius:99px;padding:3px 9px;background:var(--ivory);min-width:80px;text-align:center;}
.s2 .s2-mj-item.urgent .s2-mj-kind{color:var(--danger);border-color:var(--danger);background:var(--paper);}
.s2 .s2-mj-body{flex:1;min-width:0;}
.s2 .s2-mj-action{font-size:14px;color:var(--ink);}
.s2 .s2-mj-action b{font-weight:600;}
.s2 .s2-mj-meta{font-size:11px;color:var(--ink-mute);margin-top:1px;}
.s2 .s2-mj-hour{font-family:var(--serif);font-style:italic;font-size:13.5px;color:var(--ink-faint);min-width:42px;text-align:center;border-left:1px dashed var(--rule);padding-left:11px;}
.s2 .s2-mj-cta{font-size:10.5px;font-weight:700;color:var(--danger);border:1px solid var(--danger);border-radius:99px;padding:4px 10px;background:var(--paper);white-space:nowrap;}
.s2 .s2-mj-empty{font-family:var(--serif);font-size:17px;font-style:italic;color:var(--ink-mute);padding:6px 0 2px;}

/* Panels / KPI / analyse */
.s2 .s2-cockpit{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(0,1fr);gap:22px;align-items:start;}
.s2 .s2-panel{background:var(--paper);border:1px solid var(--rule);border-radius:var(--radius-lg);padding:18px 20px;box-shadow:var(--shadow-sm);margin-bottom:18px;}
.s2 .s2-panel h4{font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute);margin:0 0 12px;display:flex;gap:7px;align-items:center;}
.s2 .s2-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(175px,1fr));gap:1px;margin-bottom:22px;
  border:1px solid var(--rule);border-radius:var(--radius-lg);overflow:hidden;background:var(--rule-soft);}
.s2 .s2-kpi{padding:19px 21px;background:var(--ivory-soft);position:relative;display:flex;flex-direction:column;gap:7px;}
.s2 .s2-kpi::before{content:'';position:absolute;top:19px;left:0;width:3px;height:26px;background:var(--ink-mute);opacity:.4;}
.s2 .s2-kpi.danger{background:var(--danger-bg);} .s2 .s2-kpi.danger::before{background:var(--danger);opacity:1;}
.s2 .s2-kpi.warning{background:var(--warn-bg);} .s2 .s2-kpi.warning::before{background:var(--warn);opacity:1;}
.s2 .s2-kpi.success{background:var(--sage-bg);} .s2 .s2-kpi.success::before{background:var(--sage);opacity:1;}
.s2 .s2-kpi-label{font-size:10px;font-weight:600;color:var(--ink-mute);text-transform:uppercase;letter-spacing:.14em;}
.s2 .s2-kpi-value{font-family:var(--serif);font-size:33px;font-weight:300;letter-spacing:-.01em;line-height:1;color:var(--ink);}
.s2 .s2-kpi.danger .s2-kpi-value{color:var(--danger);} .s2 .s2-kpi.warning .s2-kpi-value{color:var(--warn);} .s2 .s2-kpi.success .s2-kpi-value{color:var(--sage-deep);}
.s2 .s2-kpi-sub{font-size:11px;color:var(--ink-mute);font-style:italic;}
.s2 .s2-evo{font-size:11px;font-weight:700;}
.s2 .s2-evo.up{color:var(--sage-deep);} .s2 .s2-evo.down{color:var(--danger);}
.s2 .s2-bars{display:flex;align-items:flex-end;gap:10px;height:150px;padding-top:8px;}
.s2 .s2-bar{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;height:100%;justify-content:flex-end;}
.s2 .s2-bar .seg{width:100%;max-width:38px;}
.s2 .s2-bar .seg i{display:block;width:100%;}
.s2 .s2-bar b{font-size:9.5px;font-weight:600;color:var(--ink-mute);text-transform:uppercase;}
.s2 .s2-bar span{font-size:10.5px;font-family:var(--serif);font-style:italic;color:var(--ink-soft);}
.s2 .s2-legend{display:flex;gap:14px;margin-top:10px;flex-wrap:wrap;}
.s2 .s2-legend span{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--ink-mute);}
.s2 .s2-legend i{width:10px;height:10px;border-radius:3px;display:inline-block;}
.s2 .s2-delay-row{display:flex;align-items:center;gap:12px;padding:9px 0;border-top:1px solid var(--rule-soft);}
.s2 .s2-delay-row:first-of-type{border-top:none;}
.s2 .s2-delay-name{font-size:13px;color:var(--ink);min-width:110px;}
.s2 .s2-delay-track{flex:1;height:8px;background:var(--ivory-soft);border-radius:99px;overflow:hidden;}
.s2 .s2-delay-track i{display:block;height:100%;border-radius:99px;background:var(--sage);}
.s2 .s2-delay-row.warn .s2-delay-track i{background:var(--warn);} .s2 .s2-delay-row.bad .s2-delay-track i{background:var(--danger);}
.s2 .s2-delay-val{font-family:var(--serif);font-style:italic;font-size:13.5px;color:var(--ink);min-width:128px;text-align:right;}
.s2 .s2-delay-val small{color:var(--ink-faint);font-size:10.5px;}
.s2 .s2-mini-tables{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;}
.s2 .s2-mini-tables .s2-panel{margin-bottom:0;}
.s2 .s2-mini-tables table td{padding:6px 4px;font-size:12.5px;border-bottom:1px solid var(--rule-soft);color:var(--ink-soft);}
.s2 .s2-mini-tables table td.num{text-align:right;font-family:var(--serif);font-style:italic;color:var(--ink);}
.s2 .s2-mini-tables table tr:last-child td{border-bottom:none;}
.s2 .s2-an-nav{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap;}
.s2 .s2-an-nav a{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute);
  text-decoration:none;border:1px solid var(--rule);border-radius:99px;padding:6px 14px;background:var(--paper);}
.s2 .s2-an-nav a:hover{color:var(--terracotta);border-color:var(--terracotta);}

/* Tickets compta + sliders + guard */
.s2 .s2-ticket{background:var(--ivory-soft);border:1px solid var(--rule);border-radius:var(--radius);padding:15px 19px;margin-bottom:15px;max-width:480px;}
.s2 .s2-ticket .trow{display:flex;justify-content:space-between;gap:14px;font-size:13px;color:var(--ink-soft);padding:4px 0;}
.s2 .s2-ticket .trow .tv{font-family:var(--serif);font-style:italic;font-size:14.5px;color:var(--ink);}
.s2 .s2-ticket .trow.total{border-top:1px solid var(--rule);margin-top:6px;padding-top:9px;font-weight:700;color:var(--ink);}
.s2 .s2-ticket .trow.total .tv{font-size:17px;}
.s2 .s2-ticket .trow.total.pos .tv{color:var(--sage-deep);} .s2 .s2-ticket .trow.total.neg .tv{color:var(--danger);}
.s2 .s2-ticket .tdetail{font-size:11px;color:var(--ink-faint);font-style:italic;margin-top:6px;}
.s2 .s2-slider-row{display:flex;align-items:center;gap:13px;padding:8px 0;border-top:1px solid var(--rule-soft);font-size:13px;color:var(--ink-soft);}
.s2 .s2-slider-row:first-of-type{border-top:none;}
.s2 .s2-slider-row input[type=range]{flex:1;accent-color:var(--terracotta);}
.s2 .s2-slider-row .pct{font-family:var(--serif);font-style:italic;font-size:15px;color:var(--terracotta-deep);min-width:42px;text-align:right;}
.s2 .s2-guard{margin:30px auto;max-width:520px;text-align:center;background:var(--ivory-soft);border:1px solid var(--rule);
  border-radius:var(--radius-lg);padding:38px 30px;}
.s2 .s2-guard h3{font-family:var(--serif);font-size:21px;font-style:italic;font-weight:400;margin:10px 0 6px;color:var(--ink);}
.s2 .s2-guard p{font-size:13px;color:var(--ink-mute);}

/* ════ Modaux S2 ════ */
.s2-overlay{display:none;position:fixed;inset:0;background:rgba(42,31,24,.45);z-index:500;align-items:flex-start;justify-content:center;padding:46px 18px;overflow-y:auto;}
.s2-overlay.show{display:flex;}
.s2-overlay .s2-modal{max-width:660px;width:100%;background:var(--paper);border:1px solid var(--rule);
  border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;animation:s2fade .2s ease;margin-bottom:40px;}
.s2-overlay .s2-modal.wide{max-width:940px;}
.s2-overlay .s2-modal-header{background:var(--ivory-soft);border-bottom:1px solid var(--rule);padding:15px 22px;display:flex;align-items:baseline;gap:10px;}
.s2-overlay .s2-modal-header .hgroup{flex:1;}
.s2-overlay .s2-modal-eyebrow{display:block;font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--terracotta);margin-bottom:2px;}
.s2-overlay .s2-modal-header h3{font-family:var(--serif);font-size:19px;font-weight:400;font-style:italic;margin:0;color:var(--ink);}
.s2-overlay .s2-modal-close{margin-left:auto;color:var(--ink-mute);font-size:21px;cursor:pointer;background:none;border:none;font-family:var(--sans);line-height:1;}
.s2-overlay .s2-modal-body{padding:20px 22px;}
.s2-overlay .s2-modal-actions{background:var(--ivory-soft);border-top:1px solid var(--rule);padding:12px 22px;display:flex;justify-content:flex-end;gap:9px;flex-wrap:wrap;}
.s2-overlay .s2-modal-actions .spacer{margin-right:auto;}
.s2-overlay .s2-fsection{border:1px solid var(--rule-soft);border-radius:var(--radius);margin-bottom:11px;overflow:hidden;}
.s2-overlay .s2-fsection .fs-head{background:var(--ivory-soft);padding:10px 15px;font-size:11.5px;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);display:flex;gap:8px;align-items:center;}
.s2-overlay .s2-fsection .fs-body{padding:14px 15px;}
.s2-overlay .s2-frow{display:flex;gap:12px;margin-bottom:12px;flex-wrap:wrap;}
.s2-overlay .s2-frow:last-child{margin-bottom:0;}
.s2-overlay .s2-fgroup{flex:1;min-width:130px;}
.s2-overlay .s2-fgroup label{display:block;font-size:9.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:5px;}
.s2-overlay .s2-fgroup input,.s2-overlay .s2-fgroup select,.s2-overlay .s2-fgroup textarea{width:100%;font-family:var(--sans);font-size:13px;color:var(--ink);
  background:var(--paper);border:1px solid var(--rule);border-radius:var(--radius);padding:8px 11px;}
.s2-overlay .s2-fgroup textarea{resize:vertical;}
.s2-overlay .s2-fhint{font-size:11px;color:var(--ink-faint);font-style:italic;margin-top:5px;}
.s2-overlay .s2-typeseg{display:flex;background:var(--ivory-soft);border:1px solid var(--rule);border-radius:99px;padding:3px;gap:2px;margin-bottom:16px;}
.s2-overlay .s2-typeseg button{flex:1;border:1px solid transparent;background:transparent;border-radius:99px;font-family:var(--sans);
  font-size:12.5px;font-weight:600;color:var(--ink-mute);padding:8px 6px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:7px;}
.s2-overlay .s2-typeseg button.on{background:var(--terracotta);color:var(--paper);box-shadow:0 4px 10px rgba(184,89,64,.25);}
.s2-overlay .s2-prow{border:1px solid var(--rule-soft);border-radius:var(--radius);padding:12px;margin-bottom:10px;position:relative;background:var(--ivory);}
.s2-overlay .s2-prow .s2-prow-del{position:absolute;top:8px;right:8px;border:1px solid var(--rule);background:var(--paper);
  border-radius:var(--radius-sm);font-size:11px;font-weight:700;color:var(--ink-mute);padding:2px 8px;cursor:pointer;}
.s2-overlay .s2-prow .s2-prow-del:hover{color:var(--danger);border-color:var(--danger);}
.s2-overlay .s2-infobox{background:var(--ivory-soft);border:1px solid var(--rule-soft);border-radius:var(--radius);padding:11px 14px;
  font-size:12.5px;color:var(--ink-soft);margin-bottom:14px;}
.s2-overlay .s2-infobox b{color:var(--ink);}
/* Scopé .s2 (et non .s2-overlay) : ce composant définition-clé/valeur sert AUSSI
   dans le tableau de bord Analyse (bloc SAV, Coûts labo), hors overlay. Les
   overlays portent class="s2-overlay s2" → toujours couverts. */
.s2 .s2-dkv{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule-soft);border:1px solid var(--rule);
  border-radius:var(--radius);overflow:hidden;margin-bottom:14px;}
.s2 .s2-dkv div{background:var(--ivory-soft);padding:10px 13px;}
.s2 .s2-dkv label{display:block;font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute);}
.s2 .s2-dkv span{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--ink);}
.s2 .s2-dkv .bad span{color:var(--danger);}
.s2 details.s2-collaps,.s2-overlay details.s2-collaps{border:1px solid var(--rule-soft);border-radius:var(--radius);margin-top:12px;}
.s2 details.s2-collaps summary,.s2-overlay details.s2-collaps summary{padding:9px 13px;font-size:12px;font-weight:600;color:var(--ink-mute);cursor:pointer;list-style:none;}
.s2 details.s2-collaps summary::before,.s2-overlay details.s2-collaps summary::before{content:'▸ ';font-size:10px;}
.s2 details.s2-collaps[open] summary::before,.s2-overlay details.s2-collaps[open] summary::before{content:'▾ ';}
.s2 details.s2-collaps .cbody,.s2-overlay details.s2-collaps .cbody{padding:4px 13px 11px;font-size:12px;color:var(--ink-soft);line-height:1.7;}
.s2-overlay .s2-tarif-table th,.s2-overlay .s2-tarif-table td{padding:7px 9px;}
.s2-overlay .s2-tarif-table input{width:84px;text-align:right;font-family:var(--sans);font-size:12.5px;border:1px solid var(--rule);border-radius:var(--radius-sm);padding:5px 7px;background:var(--paper);color:var(--ink);}
.s2-overlay .s2-tarif-table tr.grp td{background:var(--ivory);font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);}
.s2-overlay .s2-gerer-tabs{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap;}
.s2-overlay .s2-gerer-tab{border:1px solid var(--rule);background:var(--ivory);border-radius:99px;padding:7px 15px;font-size:12px;font-weight:600;color:var(--ink-mute);cursor:pointer;font-family:var(--sans);}
.s2-overlay .s2-gerer-tab.on{background:var(--terracotta);border-color:var(--terracotta);color:var(--paper);}
.s2-overlay .s2-gerer-item{display:flex;align-items:center;gap:10px;padding:9px 11px;border:1px solid var(--rule-soft);border-radius:var(--radius);margin-bottom:7px;background:var(--paper);}
.s2-overlay .s2-gerer-item b{font-size:13px;color:var(--ink);}
.s2-overlay .s2-gerer-item small{color:var(--ink-mute);font-size:11px;}
.s2-overlay .s2-gerer-item .gacts{margin-left:auto;display:flex;gap:5px;}
.s2-overlay .s2-sr-group{margin-bottom:14px;}
.s2-overlay .s2-sr-group h5{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--terracotta);margin:0 0 6px;display:flex;gap:7px;align-items:center;}
.s2-overlay .s2-hit{display:flex;align-items:baseline;gap:10px;padding:8px 11px;border:1px solid var(--rule-soft);border-radius:var(--radius);margin-bottom:5px;cursor:pointer;background:var(--paper);font-size:13px;}
.s2-overlay .s2-hit:hover{background:var(--terracotta-mist);border-color:var(--terracotta);}
.s2-overlay .s2-hit b{color:var(--ink);}
.s2-overlay .s2-hit .when{margin-left:auto;font-family:var(--serif);font-style:italic;font-size:11.5px;color:var(--ink-mute);white-space:nowrap;}

/* Toasts + FAB S2 */
#s2-toasts{position:fixed;bottom:18px;right:18px;z-index:700;display:flex;flex-direction:column;gap:8px;}
#s2-toasts .s2-toast{background:#2A1F18;color:#FFFCF5;border-radius:8px;padding:11px 16px;font-size:13px;
  box-shadow:0 12px 32px rgba(60,40,25,.12);display:flex;gap:10px;align-items:center;animation:s2fade .2s ease;max-width:380px;font-family:'Manrope',sans-serif;}
#s2-toasts .s2-toast.success{background:#4F5C42;} #s2-toasts .s2-toast.error{background:#A6321F;} #s2-toasts .s2-toast.warning{background:#C68A2E;color:#2A1F18;}
.s2-fab{position:fixed;right:22px;bottom:22px;z-index:250;background:#B85940;color:#FFFCF5;border:none;
  border-radius:99px;padding:13px 20px;font-family:'Manrope',sans-serif;font-size:13.5px;font-weight:700;cursor:pointer;
  box-shadow:0 8px 22px rgba(184,89,64,.4);display:none;align-items:center;gap:8px;}
.s2-fab.show{display:inline-flex;}
