/* Tansa /comparer/ - CSS extrait de l'inline le 2026-05-20 */

/* CLS FIX v2 (apres analyse code ligne 764-766) :
   #cmp-root demarre a ~196px (cmp-loading) puis grandit a 947px (3 produits) a 1888ms
   quand root.innerHTML = ... est execute. Ce shift de ~750px pousse footer-placeholder
   en bas, d ou attribution CLS sur footer-placeholder. On reserve dans cmp-root. */
#cmp-root { min-height: 950px }
@media (max-width: 767px) { #cmp-root { min-height: 1400px } }

/* ── COMPARATEUR v6 — CSS spécifique ──
   Note : .sr-only, .cta-band, .btn-white, .btn-ghost-w, .cta-row, .breadcrumb sont définis
   dans tansa.css. Ce <style> ne contient QUE les classes .cmp-* propres au comparateur. */

/* Anti-flash : masque le contenu jusqu'au premier render */
body.cmp-init-hide #cmp-root,
body.cmp-init-hide .cmp-mobile-refs { visibility:hidden }
[hidden] { display:none !important }

.compare-section{max-width:1200px;margin:0 auto;padding:clamp(24px,3vw,36px) var(--px) 0}
main > .cta-band{margin-top:clamp(40px,6vw,64px)}

/* Hero */
.cmp-hero{margin-bottom:clamp(20px,3vw,28px)}
.cmp-hero .prod-label{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);font-family:var(--bd);margin:0 0 8px}
.cmp-hero h1{font-family:var(--hd);font-size:clamp(22px,2.8vw,30px);font-weight:800;color:var(--navy);line-height:1.15;margin:0 0 8px;letter-spacing:.01em}
.cmp-hero p{font-size:14px;color:var(--muted);line-height:1.7;max-width:680px;margin:0}

/* Statut compact : compteur + verrou gamme + actions partage/print/undo */
.cmp-status{display:flex;align-items:center;flex-wrap:wrap;gap:8px;padding:10px 14px;background:#fff;border:1px solid var(--border);border-radius:var(--r);margin-bottom:clamp(20px,3vw,28px);font-size:13px;color:var(--muted)}
.cmp-status strong{color:var(--navy);font-weight:600}
.cmp-status-count{display:inline-flex;align-items:center;gap:5px}
.cmp-status-count strong{font-family:var(--hd);font-size:14px;letter-spacing:.02em}
.cmp-status-sep{color:#cbcfd4}
.cmp-status-gamme{display:inline-flex;align-items:center;gap:5px;color:var(--muted)}
.cmp-status-gamme svg{color:var(--blue);flex-shrink:0}
.cmp-status-actions{display:inline-flex;gap:6px;margin-left:auto;flex-wrap:wrap}
.cmp-status-btn{display:inline-flex;align-items:center;gap:5px;background:transparent;border:1px solid var(--border);color:var(--blue);font-family:var(--bd);font-size:12.5px;font-weight:500;padding:5px 11px;border-radius:var(--r);cursor:pointer;transition:all .15s;text-decoration:none}
.cmp-status-btn:hover{background:#e8f0fb;border-color:var(--blue)}
.cmp-status-btn svg{flex-shrink:0}
.cmp-status-btn[hidden]{display:none !important}
.cmp-status-btn-primary{background:var(--blue);color:#fff;border-color:var(--blue);font-weight:600}
.cmp-status-btn-primary:hover{background:var(--blue-dk);border-color:var(--blue-dk);color:#fff}
.cmp-status-btn-primary svg{color:#fff}

/* Mini-modal de confirmation HTML (Brave Mobile compatible) */

/* Bandeau "verrou gamme — comparaison mixte" */
.cmp-mix-banner{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#fffbeb;color:var(--amber);border:1px solid #fde68a;border-radius:var(--r);margin-bottom:clamp(20px,3vw,28px);font-size:13px;line-height:1.4}
.cmp-mix-banner svg{flex-shrink:0;margin-top:1px}

/* Empty state (0 produit) */
.cmp-empty{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:clamp(40px,6vw,72px) clamp(20px,3vw,40px);text-align:center;max-width:1200px;margin:0 auto}
.cmp-empty-icon{width:64px;height:64px;border-radius:50%;background:var(--off);color:var(--blue);display:inline-flex;align-items:center;justify-content:center;margin-bottom:18px}
.cmp-empty h2{font-family:var(--hd);font-size:clamp(20px,2.4vw,26px);font-weight:700;color:var(--navy);margin:0 0 8px}
.cmp-empty p{font-size:14px;color:var(--muted);max-width:480px;margin:0 auto 20px;line-height:1.6}
.cmp-empty .btn-cta{display:inline-flex;align-items:center;gap:8px;background:var(--blue);color:#fff;border:none;padding:12px 22px;border-radius:var(--r);font-size:14px;font-family:var(--bd);font-weight:600;text-decoration:none;transition:background .15s}
.cmp-empty .btn-cta:hover{background:var(--blue-dk)}

/* Tableau */
.cmp-table-wrap{background:#fff;border:1px solid var(--border);border-radius:var(--r);max-width:1200px;margin:0 auto;position:relative}

/* Header sticky avec collapse au scroll */
.cmp-table-head{display:grid;border-bottom:1px solid var(--border);background:linear-gradient(180deg,#fafbfc 0%,#fff 100%);position:sticky;top:var(--actual-header-h, 131px);z-index:5;border-top-left-radius:var(--r);border-top-right-radius:var(--r);transition:box-shadow .2s}
.cmp-table-head.scrolled{box-shadow:0 4px 12px rgba(15,39,68,.10)}

.cmp-th{padding:18px 16px 16px;border-left:1px solid var(--border);position:relative;display:flex;flex-direction:column;transition:padding .25s ease}
.cmp-th:first-child{border-left:none;background:var(--off)}
.cmp-th-corner{justify-content:center;text-align:left;padding:18px 16px}
.cmp-corner-label{font-family:var(--hd);font-size:18px;color:var(--navy);font-weight:700;letter-spacing:.02em;margin-bottom:4px;line-height:1.1}
.cmp-corner-hint{font-family:var(--bd);font-size:11.5px;color:var(--muted);line-height:1.35}
.cmp-table-head.scrolled .cmp-th-corner .cmp-corner-label{font-size:13px;margin:0}
.cmp-table-head.scrolled .cmp-th-corner .cmp-corner-hint{display:none}

/* Mode compact desktop scrolled */
.cmp-table-head.scrolled .cmp-th{padding:10px 14px;flex-direction:row;align-items:center;gap:12px}
.cmp-table-head.scrolled .cmp-th-photo{aspect-ratio:1;width:44px;height:44px;margin:0;flex-shrink:0;border-radius:6px}
.cmp-table-head.scrolled .cmp-th-photo img{padding:4px}
.cmp-table-head.scrolled .cmp-th-label,
.cmp-table-head.scrolled .cmp-th-title,
.cmp-table-head.scrolled .cmp-th-actions{display:none}
.cmp-table-head.scrolled .cmp-th-ref{margin:0;font-size:13px;align-self:center}
.cmp-table-head.scrolled .cmp-th-dispo{display:none}
.cmp-table-head.scrolled .cmp-th:first-child{padding:0}

/* Card produit dans le header */
.cmp-th-photo{aspect-ratio:4/3;background:#fff;border:1px solid var(--border);border-radius:8px;margin-bottom:12px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.cmp-th-photo img{width:100%;height:100%;object-fit:contain;padding:14px}

/* Bouton ✕ */
.cmp-th-remove{position:absolute;top:10px;right:10px;background:rgba(255,255,255,.95);border:1px solid var(--border);border-radius:50%;width:28px;height:28px;cursor:pointer;color:var(--muted);display:flex;align-items:center;justify-content:center;transition:all .15s;z-index:3;backdrop-filter:blur(4px)}
.cmp-th-remove:hover{background:#fff;border-color:#d93b2b;color:#d93b2b}
.cmp-th-remove svg{width:13px;height:13px}
.cmp-table-head.scrolled .cmp-th-remove{top:50%;right:10px;transform:translateY(-50%);width:24px;height:24px}
.cmp-table-head.scrolled .cmp-th-remove svg{width:11px;height:11px}
/* Slot "+ Ajouter un produit" : passe aussi en mode compact (sinon il etire toute la sticky bar a 280px) */
.cmp-table-head.scrolled .cmp-th-add{min-height:64px;padding:10px 14px;flex-direction:row;gap:10px;text-align:left}
.cmp-table-head.scrolled .cmp-th-add-icon{width:28px;height:28px;flex-shrink:0}
.cmp-table-head.scrolled .cmp-th-add-icon svg{width:14px;height:14px}
.cmp-table-head.scrolled .cmp-th-add-text{font-size:12px;padding:0;line-height:1.3}
.cmp-th-remove[disabled],
.cmp-th-remove.is-disabled{cursor:not-allowed;opacity:0.4}
.cmp-th-remove.is-disabled:hover{background:rgba(255,255,255,.95);border-color:var(--border);color:var(--muted)}

/* Slot "+ Ajouter un produit" (incomplete state) */
.cmp-th-add{padding:0;border-left:1px solid var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;background:repeating-linear-gradient(45deg,#fafbfc,#fafbfc 8px,#f4f6f9 8px,#f4f6f9 16px);min-height:280px;gap:8px;color:var(--muted);text-align:center;transition:background .15s;text-decoration:none}
.cmp-th-add:hover{background:repeating-linear-gradient(45deg,#f0f4fa,#f0f4fa 8px,#e8eef8 8px,#e8eef8 16px);color:var(--blue)}
.cmp-th-add-icon{width:42px;height:42px;border-radius:50%;background:#fff;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--blue)}
.cmp-th-add-text{font-family:var(--bd);font-size:12.5px;font-weight:500;padding:0 12px;line-height:1.4}

.cmp-th-label{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);font-family:var(--bd);margin:0 0 5px}
.cmp-th-title{font-family:var(--hd);font-size:16px;font-weight:800;color:var(--navy);line-height:1.2;letter-spacing:.01em;margin:0 0 8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:38px}
.cmp-th-ref{font-family:var(--hd);font-size:11.5px;font-weight:600;color:var(--navy);background:#e8f0fb;padding:3px 11px;border-radius:20px;border:1px solid rgba(0,102,204,.15);align-self:flex-start;margin-bottom:10px;letter-spacing:.02em}

.cmp-th-dispo{display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:5px 10px;border-radius:var(--r);font-family:var(--bd);font-weight:500;align-self:flex-start;margin-bottom:14px}
.cmp-th-dispo.ok{background:var(--green-lt);color:var(--green);border:1px solid #a8e6cc}
.cmp-th-dispo.cmd{background:#fffbeb;color:var(--amber);border:1px solid #fde68a}
.cmp-th-dispo .dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}

.cmp-th-actions{display:flex;flex-direction:column;gap:6px;margin-top:auto}
.cmp-th-btn{width:100%;padding:9px 12px;border-radius:var(--r);font-size:12px;font-family:var(--bd);font-weight:500;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;text-decoration:none;transition:border-color .15s;min-height:38px;background:#fff;color:var(--navy);border:1.5px solid var(--border)}
.cmp-th-btn:hover{border-color:var(--navy)}
.cmp-th-btn svg{flex-shrink:0}

/* Sections + rows */
.cmp-section-band{background:var(--off);padding:11px 16px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);font-family:var(--hd);font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.cmp-row{display:grid;border-bottom:1px solid var(--border);transition:background .12s}
.cmp-row:last-child{border-bottom:none}
.cmp-row:hover{background:#fcfcfc}
.cmp-cell{padding:11px 16px;font-size:13px;border-left:1px solid var(--border);display:flex;align-items:center;min-height:42px}
.cmp-cell:first-child{border-left:none;background:var(--off);color:var(--muted);font-weight:500;font-size:12.5px;line-height:1.3;display:flex;align-items:center;hyphens:auto;-webkit-hyphens:auto}
.cmp-cell-val{color:var(--text);font-weight:500;line-height:1.45;word-wrap:break-word;overflow-wrap:break-word;hyphens:auto;-webkit-hyphens:auto;min-width:0}
.cmp-cell-val.empty{color:#cbcfd4;font-style:italic;font-weight:400}

/* Badge "Top" */
.cmp-best{display:inline-flex;align-items:center;gap:3px;background:var(--green-lt);color:var(--green);font-family:var(--bd);font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:20px;border:1px solid #9adfc0;margin-left:8px;letter-spacing:.02em;vertical-align:middle;white-space:nowrap}
.cmp-best svg{width:10px;height:10px}

/* Badges normes */
.cmp-norms{display:flex;flex-wrap:wrap;gap:6px}
.cmp-norm-badge{background:#e8f0fe;color:var(--blue);font-family:var(--bd);font-size:11px;font-weight:600;padding:4px 10px;border-radius:14px;letter-spacing:.02em}

/* CTA bandeau bas — chips refs */
.cmp-cta-refs{display:inline-flex;flex-wrap:wrap;gap:6px;margin:0 0 14px;justify-content:center}
.cmp-cta-refs span{background:rgba(255,255,255,.15);color:#fff;font-family:var(--hd);font-size:11.5px;font-weight:600;padding:4px 11px;border-radius:20px;letter-spacing:.02em;border:1px solid rgba(255,255,255,.25)}

/* Skeleton de chargement */
.cmp-loading{display:flex;align-items:center;justify-content:center;padding:80px 20px;color:var(--muted);font-size:13px;gap:10px}
.cmp-loading::before{content:"";width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:cmp-spin .8s linear infinite}
@keyframes cmp-spin{to{transform:rotate(360deg)}}

/* Toast undo */
.cmp-toast{position:fixed;bottom:20px;left:50%;background:var(--navy);color:#fff;padding:12px 18px;border-radius:var(--r);font-size:13px;box-shadow:0 8px 24px rgba(15,39,68,.20);z-index:1000;align-items:center;gap:14px;pointer-events:none;display:none;opacity:0;transform:translateX(-50%) translateY(20px);transition:opacity .25s, transform .25s}
.cmp-toast.visible{display:flex}
.cmp-toast.show{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}
.cmp-toast-msg{font-family:var(--bd)}
.cmp-toast-btn{background:transparent;border:1px solid rgba(255,255,255,.4);color:#fff;font-family:var(--bd);font-size:12px;font-weight:600;padding:5px 12px;border-radius:6px;cursor:pointer;transition:background .15s}
.cmp-toast-btn:hover{background:rgba(255,255,255,.12)}

/* Hide mobile-only on desktop */
.cmp-mobile-hint,.cmp-mobile-refs{display:none}

/* ── MOBILE ── */
@media (max-width:767px){
  .cmp-status-actions{margin-left:0;width:100%;justify-content:flex-start;padding-top:6px;border-top:1px solid var(--border);margin-top:4px}

  .cmp-table-wrap{
    border:1px solid var(--border);
    border-radius:var(--r);
    position:relative;
    background:#fff;
  }

  /* Sur mobile : on désactive le sticky vertical du head (impossible avec overflow-x du parent),
     on utilise une mini-bande de refs sticky placée AU-DESSUS */
  .cmp-table-head{position:static;top:auto;box-shadow:none}

  /* Mini-bande de références sticky : grille alignée au tableau, scroll-x sync via JS */
  .cmp-mobile-refs{
    display:block;
    position:sticky;
    top:var(--actual-header-h, 102px);
    z-index:20;
    background:#fff;
    border-bottom:1px solid var(--border);
    border-top-left-radius:var(--r);
    border-top-right-radius:var(--r);
    box-shadow:0 2px 8px rgba(15,39,68,.08);
    overflow-x:auto;
    overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  .cmp-mobile-refs::-webkit-scrollbar{display:none}

  .cmp-mobile-refs-grid{
    display:grid;
    gap:0;
    padding:8px 0;
  }
  .cmp-mobile-refs-spacer{background:transparent}
  .cmp-mobile-refs-item{
    display:flex;
    align-items:center;
    gap:6px;
    padding:0 8px;
    margin:0 4px;
    background:var(--off);
    border:1px solid var(--border);
    border-radius:6px;
    min-width:0;
    height:36px;
  }
  .cmp-mobile-refs-thumb{width:24px;height:24px;background:#fff;border-radius:4px;flex-shrink:0;overflow:hidden;display:flex;align-items:center;justify-content:center}
  .cmp-mobile-refs-thumb img{width:100%;height:100%;object-fit:contain;padding:2px}
  .cmp-mobile-refs-text{font-family:var(--hd);font-size:11px;font-weight:700;color:var(--navy);letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1}

  /* Tableau & rows : grille forcée par data-cols + min-width */
  .cmp-table-head,
  .cmp-row{
    display:grid !important;
    border:none;
  }

  /* Cellules card produit : compactes */
  .cmp-th{padding:14px 12px 12px;border-left:1px solid var(--border);min-height:auto}
  .cmp-th:first-child{padding:0;background:var(--off);border-left:none;position:sticky;left:0;z-index:6}
  .cmp-th-photo{margin-bottom:8px}
  .cmp-th-photo img{padding:8px}
  .cmp-th-label{font-size:10px;margin-bottom:3px}
  .cmp-th-title{font-size:13px;-webkit-line-clamp:3;min-height:auto;margin-bottom:6px}
  .cmp-th-ref{font-size:10.5px;padding:2px 9px;margin-bottom:7px}
  .cmp-th-dispo{font-size:10.5px;padding:3px 8px;margin-bottom:10px}
  .cmp-th-btn{font-size:11px;padding:7px 8px;min-height:32px}
  .cmp-th-btn svg{width:10px;height:10px}

  /* Cellules data */
  .cmp-cell{padding:9px 12px;font-size:12px;min-height:38px;line-height:1.35}
  .cmp-cell:first-child{
    position:sticky;
    left:0;
    z-index:2;
    background:var(--off);
    color:var(--muted);
    font-weight:500;
    font-size:11px;
    padding:9px 10px;
    border-right:1px solid var(--border);
    line-height:1.25;
    display:flex;
    align-items:center;
    hyphens:auto;
    -webkit-hyphens:auto;
  }

  /* Section bands : pleine largeur grid, sticky à gauche */
  .cmp-section-band{grid-column:1 / -1;background:var(--off);padding:10px 12px;font-size:10.5px;position:sticky;left:0;z-index:1}

  /* Container scroll horizontal */
  .cmp-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--r);background:linear-gradient(to right,transparent 70%,rgba(15,39,68,.06) 100%) right/40px 100% no-repeat,#fff}

  /* Hint mobile */
  .cmp-mobile-hint{display:block;text-align:center;background:#e8f0fb;color:var(--blue);font-family:var(--bd);font-size:11px;font-weight:500;padding:8px;border-bottom:1px solid var(--border);letter-spacing:.02em;border-top-left-radius:var(--r);border-top-right-radius:var(--r)}

  .cmp-norms{flex-direction:column;align-items:flex-start;gap:3px}
  .cmp-norm-badge{font-size:10px;padding:2px 7px}
  .cmp-best{font-size:9.5px;padding:1px 6px;margin-left:5px}
}

/* ─────────────── @MEDIA PRINT ─────────────── */
@media print {
  /* Page A4 portrait avec marges */
  @page {
    size: A4 portrait;
    margin: 14mm 12mm 16mm 12mm;
    @top-left {
      content: "TANSA | Comparatif produits";
      font-family: 'Inter', sans-serif;
      font-size: 8.5pt;
      color: #6b6560;
    }
    @top-right {
      content: "tansa.fr  |  +33 (0)4 22 53 73 73";
      font-family: 'Inter', sans-serif;
      font-size: 8.5pt;
      color: #6b6560;
    }
    @bottom-center {
      content: "Page " counter(page) " / " counter(pages);
      font-family: 'Inter', sans-serif;
      font-size: 8.5pt;
      color: #6b6560;
    }
  }

  /* Reset general */
  *, *::before, *::after {
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
    color-adjust: exact !important;
    box-shadow: none !important;
  }
  html, body {
    background: #fff !important;
    color: #1a1612 !important;
    font-size: 9pt;
    line-height: 1.35;
    padding: 0;
    margin: 0;
  }

  /* Masquer les elements non-imprimables */
  #nav-placeholder,
  #footer-placeholder,
  #modal-placeholder,
  .breadcrumb,
  .cmp-status-actions,
  .cmp-th-remove,
  .cmp-th-actions,
  .cmp-th-add,
  .cmp-mobile-refs,
  .cmp-mobile-hint,
  .cmp-toast,
  main > .cta-band,
  #cmp-cta,
  .back-to-top {
    display: none !important;
  }

  /* Bandeau imprime en debut : titre + meta */
  .cmp-hero h1 {
    font-size: 16pt !important;
    margin: 0 0 6pt;
    color: #0f2744 !important;
  }
  .cmp-hero p,
  .cmp-hero .prod-label {
    font-size: 9pt;
    margin: 0 0 4pt;
    color: #6b6560 !important;
  }
  .compare-section {
    padding: 0 !important;
    max-width: 100% !important;
  }

  /* Status compact en print : 1 ligne sobre */
  #cmp-status {
    display: flex !important;
    background: transparent !important;
    border: none !important;
    border-top: 1px solid #ccc !important;
    border-bottom: 1px solid #ccc !important;
    padding: 6pt 0 !important;
    margin: 8pt 0 !important;
    font-size: 9pt !important;
  }

  /* Tableau : reset des grilles fluides, on passe en table CSS classique */
  .cmp-table-wrap {
    border: 1px solid #999 !important;
    border-radius: 0 !important;
    background: #fff !important;
    page-break-inside: auto;
  }
  .cmp-table-scroll {
    overflow: visible !important;
    background: none !important;
  }

  /* Header tableau : grille non-fluide pour eviter troncature */
  .cmp-table-head {
    position: static !important;
    background: #fafbfc !important;
    page-break-after: avoid;
    break-after: avoid-page;
    /* IMPORTANT : grille auto-fitted, pas repeat(N, 1fr) */
    grid-template-columns: 22% repeat(var(--cmp-col-count, 3), 1fr) !important;
  }
  .cmp-table-head.scrolled {
    /* annuler le mode compact en print */
    padding: 0 !important;
  }
  .cmp-table-head.scrolled .cmp-th { 
    padding: 8pt !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 0 !important;
  }
  .cmp-table-head.scrolled .cmp-th-photo {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 4/3 !important;
    margin-bottom: 6pt !important;
    border-radius: 0 !important;
  }
  .cmp-table-head.scrolled .cmp-th-label,
  .cmp-table-head.scrolled .cmp-th-title,
  .cmp-table-head.scrolled .cmp-th-dispo {
    display: block !important;
  }
  .cmp-table-head.scrolled .cmp-th-photo img {
    padding: 6pt !important;
  }

  .cmp-th {
    padding: 8pt !important;
    border-left: 1px solid #ddd !important;
  }
  .cmp-th:first-child {
    background: #f4f6f9 !important;
  }
  .cmp-th-photo {
    height: 90pt !important;
    aspect-ratio: auto !important;
    border-color: #ddd !important;
  }
  .cmp-th-photo img {
    padding: 4pt !important;
  }
  .cmp-th-label {
    font-size: 7pt !important;
    color: #0066cc !important;
    margin-bottom: 2pt !important;
  }
  .cmp-th-title {
    font-size: 9.5pt !important;
    color: #0f2744 !important;
    margin: 0 0 4pt !important;
    -webkit-line-clamp: unset !important;
    line-clamp: unset !important;
    min-height: 0 !important;
    overflow: visible !important;
  }
  .cmp-th-ref {
    font-size: 9pt !important;
    background: #e8f0fb !important;
    color: #0f2744 !important;
    margin-bottom: 4pt !important;
  }
  .cmp-th-dispo {
    font-size: 8pt !important;
    margin-bottom: 0 !important;
  }
  .cmp-th-dispo.ok {
    background: #e6f7f0 !important;
    color: #0a7c4e !important;
    border-color: #a8e6cc !important;
  }
  .cmp-th-dispo.cmd {
    background: #fffbeb !important;
    color: #b45000 !important;
    border-color: #fde68a !important;
  }

  /* Sections et lignes : grille identique au header pour alignement */
  .cmp-section-band {
    background: #f4f6f9 !important;
    color: #6b6560 !important;
    padding: 5pt 8pt !important;
    font-size: 8.5pt !important;
    page-break-after: avoid;
    break-after: avoid-page;
  }
  .cmp-row {
    grid-template-columns: 22% repeat(var(--cmp-col-count, 3), 1fr) !important;
    page-break-inside: avoid;
    break-inside: avoid-page;
    border-bottom: 1px solid #eee !important;
  }
  .cmp-row:hover { background: transparent !important }
  .cmp-cell {
    padding: 5pt 8pt !important;
    font-size: 9pt !important;
    border-left: 1px solid #eee !important;
    min-height: 0 !important;
    line-height: 1.3 !important;
    /* IMPORTANT : autoriser le wrap pour ne pas tronquer */
    word-break: break-word;
    overflow-wrap: break-word;
    align-items: flex-start !important;
  }
  .cmp-cell:first-child {
    background: #fafbfc !important;
    color: #6b6560 !important;
    font-size: 8.5pt !important;
    font-weight: 500 !important;
  }
  .cmp-cell-val.empty { color: #aaa !important }
  .cmp-best {
    background: #e6f7f0 !important;
    color: #0a7c4e !important;
    border: 1px solid #9adfc0 !important;
    font-size: 7.5pt !important;
    padding: 1pt 5pt !important;
  }
  .cmp-norm-badge {
    background: #e8f0fe !important;
    color: #0066cc !important;
    font-size: 7.5pt !important;
    padding: 1pt 5pt !important;
  }

  /* HEADER PRINT : logo + titre + date (visible page 1) */
  .cmp-print-header {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    padding: 0 0 8pt !important;
    margin: 0 0 12pt !important;
    border-bottom: 2pt solid #0f2744 !important;
    page-break-after: avoid;
    break-after: avoid-page;
  }
  .cmp-print-logo {
    height: 28pt !important;
    width: auto !important;
  }
  .cmp-print-header-meta {
    text-align: right;
    font-family: 'Inter', sans-serif !important;
  }
  .cmp-print-header-title {
    display: block;
    font-family: 'Barlow Condensed', sans-serif !important;
    font-size: 12pt !important;
    color: #0f2744 !important;
    text-transform: uppercase;
    letter-spacing: .06em;
    font-weight: 700;
  }
  .cmp-print-header-date {
    display: block;
    font-size: 9pt !important;
    color: #6b6560 !important;
    margin-top: 2pt;
  }

  /* HERO simplifie pour le print (masque le hero ecran) */
  .cmp-hero { display: none !important }
  .cmp-print-hero {
    display: block !important;
    margin: 0 0 10pt !important;
  }
  .cmp-print-hero h1 {
    font-family: 'Barlow Condensed', sans-serif !important;
    font-size: 16pt !important;
    color: #0f2744 !important;
    margin: 0 0 4pt !important;
    line-height: 1.15 !important;
    font-weight: 700 !important;
  }
  .cmp-print-hero p {
    margin: 0 !important;
    color: #6b6560 !important;
    font-size: 9pt !important;
    line-height: 1.4 !important;
  }

  /* CTA commercial */
  .cmp-print-cta {
    display: block !important;
    box-sizing: border-box !important;
    width: 100% !important;
    max-width: 1200px !important;
    margin: 14pt auto 8pt !important;
    padding: 9pt 12pt !important;
    border: 1px solid #0f2744 !important;
    border-left: 3pt solid #0066cc !important;
    background: #fafbfc !important;
    font-size: 9pt !important;
    page-break-inside: avoid;
    break-inside: avoid-page;
  }
  .cmp-print-cta h3 {
    font-family: 'Barlow Condensed', sans-serif !important;
    font-size: 11pt !important;
    color: #0f2744 !important;
    margin: 0 0 4pt !important;
    text-transform: uppercase;
    letter-spacing: .04em;
    font-weight: 700;
  }
  .cmp-print-cta p {
    margin: 2pt 0 !important;
    color: #1a1612 !important;
    font-size: 9pt !important;
    line-height: 1.4 !important;
  }
  .cmp-print-cta strong { color: #0f2744 !important }
  .cmp-print-cta-note {
    color: #6b6560 !important;
    font-size: 8.5pt !important;
    font-style: italic;
    margin-top: 4pt !important;
  }
  .cmp-print-cta-url {
    margin-top: 6pt !important;
    padding-top: 5pt !important;
    border-top: 0.5pt solid #d4d8dd !important;
    font-size: 9pt !important;
  }
  .cmp-print-cta-url strong {
    color: #0f2744 !important;
    font-size: 8.5pt !important;
    text-transform: uppercase;
    letter-spacing: .03em;
  }
  .cmp-print-cta-url #cmp-print-share-url {
    display: inline-block;
    margin-top: 2pt;
    font-family: 'Inter', monospace, sans-serif !important;
    font-size: 8.5pt !important;
    color: #0066cc !important;
    word-break: break-all;
    overflow-wrap: anywhere;
    text-decoration: underline;
    text-decoration-thickness: 0.5pt;
    text-underline-offset: 1.5pt;
  }
  .cmp-print-cta-url #cmp-print-share-url svg {
    flex-shrink: 0;
  }

  /* DISCLAIMER en bas : mentions legales */
  .cmp-print-disclaimer {
    display: block !important;
    box-sizing: border-box !important;
    width: 100% !important;
    max-width: 1200px !important;
    margin: 12pt auto 0 !important;
    padding: 8pt 0 0 !important;
    border-top: 0.5pt solid #ccc !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 7.5pt !important;
    color: #6b6560 !important;
    line-height: 1.45 !important;
    page-break-inside: avoid;
    break-inside: avoid-page;
  }
  .cmp-print-disclaimer p {
    margin: 0 0 4pt !important;
    text-align: left;
    hyphens: none !important;
    -webkit-hyphens: none !important;
    word-spacing: normal !important;
  }
  .cmp-print-disclaimer-ref {
    font-size: 7pt !important;
    text-align: center !important;
    color: #888 !important;
    letter-spacing: .03em;
    margin-top: 6pt !important;
    font-family: 'Inter', sans-serif !important;
  }

  /* Hide-from-print */
  .no-print { display: none !important }
}

/* Blocs print : visibles UNIQUEMENT en print (caches par defaut) */
.cmp-print-header,
.cmp-print-hero,
.cmp-print-cta,
.cmp-print-disclaimer { display: none }

/* ===== APPLE MODE ===== */
/* MODE APPLE : sticky a hauteur fixe 80px en permanence.
   Pas de mode etendu/compacte = aucun reflow = aucun clignotement.
   Pattern utilise par Apple, Best Buy, Backmarket, RS Components. */
@media (min-width: 768px) {
  .cmp-table-head {
    min-height: 80px !important;
    max-height: 80px !important;
    overflow: hidden !important;
    transition: none !important;
    box-shadow: 0 2px 8px -2px rgba(15, 39, 68, .15) !important;
    border-bottom: 1px solid var(--border) !important;
  }
  .cmp-table-head .cmp-th,
  .cmp-table-head .cmp-th-corner {
    padding: 12px 14px !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 10px !important;
    min-height: 80px !important;
    max-height: 80px !important;
  }
  .cmp-table-head .cmp-th-photo {
    width: 44px !important;
    height: 44px !important;
    aspect-ratio: 1 !important;
    margin: 0 !important;
    flex-shrink: 0 !important;
    border-radius: 6px !important;
  }
  .cmp-table-head .cmp-th-photo img {
    padding: 3px !important;
  }
  /* Cacher les elements de mode "etendu" : label, title, dispo, actions */
  .cmp-table-head .cmp-th-label,
  .cmp-table-head .cmp-th-title,
  .cmp-table-head .cmp-th-actions,
  .cmp-table-head .cmp-th-dispo {
    display: none !important;
  }
  /* Coin : label seul, hint cachee */
  .cmp-table-head .cmp-corner-label {
    font-size: 14px !important;
    margin: 0 !important;
  }
  .cmp-table-head .cmp-corner-hint {
    display: none !important;
  }
  /* Ref pill bien visible */
  .cmp-table-head .cmp-th-ref {
    font-size: 13px !important;
    margin: 0 !important;
    align-self: center !important;
  }
  /* Bouton X : centre vertical, pas perdu en haut */
  .cmp-table-head .cmp-th-remove {
    top: 50% !important;
    right: 10px !important;
    transform: translateY(-50%) !important;
    width: 24px !important;
    height: 24px !important;
  }
  .cmp-table-head .cmp-th-remove svg {
    width: 11px !important;
    height: 11px !important;
  }
  /* Slot vide compact */
  .cmp-table-head .cmp-th-add {
    min-height: 80px !important;
    max-height: 80px !important;
    padding: 10px 14px !important;
    flex-direction: row !important;
    gap: 10px !important;
    text-align: left !important;
    justify-content: flex-start !important;
  }
  .cmp-table-head .cmp-th-add-icon {
    width: 28px !important;
    height: 28px !important;
    flex-shrink: 0 !important;
  }
  .cmp-table-head .cmp-th-add-text {
    font-size: 12px !important;
    padding: 0 !important;
  }
}

/* ===== REF CLICKABLE ===== */
/* Pastille ref et photo cliquables : cursor + hover */
.cmp-table-head a.cmp-th-ref,
.cmp-table-head a.cmp-th-photo {
  cursor: pointer !important;
  text-decoration: none !important;
  transition: background .15s !important;
}
.cmp-table-head a.cmp-th-ref:hover {
  background: var(--blue-lt) !important;
  color: var(--blue-dk) !important;
}
.cmp-table-head a.cmp-th-photo:hover img {
  transform: scale(1.05) !important;
  transition: transform .15s !important;
}
