/* =============================================================================
   Configurateur /composer — layout 3 colonnes desktop, stack sticky mobile.
   Dépend de main.css (variables --uf-*).
   ============================================================================= */

.uf-composer { padding: var(--uf-space-6) 0 var(--uf-space-9); }

.uf-composer__intro {
  max-width: 1200px;
  margin: 0 auto var(--uf-space-7);
  padding-inline: var(--uf-space-5);
}
.uf-composer__intro h1 {
  margin: var(--uf-space-2) 0 var(--uf-space-3);
}

.uf-composer__layout {
  max-width: 1280px;
  margin: 0 auto;
  padding-inline: var(--uf-space-5);
  display: grid;
  gap: var(--uf-space-6);
  grid-template-columns: 280px minmax(0, 1fr) 320px;
  align-items: start;
}

@media (max-width: 1100px) { .uf-composer__layout { grid-template-columns: 240px minmax(0, 1fr) 280px; } }
@media (max-width: 900px)  { .uf-composer__layout { grid-template-columns: 1fr; } .uf-composer__recap { order: 3; } }

.uf-composer__recap,
.uf-composer__preview {
  position: sticky; top: var(--uf-space-5);
  background: var(--uf-color-surface);
  border: 1px solid var(--uf-color-line);
  border-radius: var(--uf-radius-md);
  padding: var(--uf-space-5);
}

@media (max-width: 900px) {
  .uf-composer__recap,
  .uf-composer__preview { position: static; }
}

.uf-composer__recap-name {
  font-family: var(--uf-font-display);
  font-size: 22px;
  font-weight: 600;
  margin: var(--uf-space-2) 0 var(--uf-space-4);
}

.uf-composer__recap-block { margin-bottom: var(--uf-space-4); }

.uf-composer__recap-row {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  gap: var(--uf-space-2);
  align-items: center;
  padding: var(--uf-space-2) 0;
  border-bottom: 1px solid var(--uf-color-line);
  font-size: 14px;
}
.uf-composer__recap-row:last-child { border-bottom: none; }
.uf-composer__recap-row-name { color: var(--uf-color-ink); }
.uf-composer__recap-row-dose { font-family: var(--uf-font-mono); font-size: 13px; color: var(--uf-color-ink-soft); }
.uf-composer__recap-remove {
  width: 22px;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1px solid var(--uf-color-line);
  border-radius: 50%;
  color: var(--uf-color-ink-soft);
  font-size: 14px;
  line-height: 1;
  cursor: pointer;
  transition: border-color var(--uf-trans-fast), color var(--uf-trans-fast), background var(--uf-trans-fast);
}
.uf-composer__recap-remove:hover {
  border-color: var(--uf-color-accent);
  color: var(--uf-color-accent);
  background: color-mix(in srgb, var(--uf-color-accent) 8%, transparent);
}

.uf-composer__recap-meta {
  display: flex;
  flex-direction: column;
  gap: var(--uf-space-2);
  margin: 0;
  padding-top: var(--uf-space-3);
  border-top: 1px solid var(--uf-color-line);
}
.uf-composer__recap-meta > div { display: flex; justify-content: space-between; font-size: 13px; }
.uf-composer__recap-meta dt { font-family: var(--uf-font-mono); color: var(--uf-color-ink-soft); margin: 0; }
.uf-composer__recap-meta dd { margin: 0; color: var(--uf-color-ink); }

.uf-composer__editor { display: flex; flex-direction: column; gap: var(--uf-space-7); }

.uf-composer__step {
  border: 1px solid var(--uf-color-line);
  border-radius: var(--uf-radius-md);
  padding: var(--uf-space-5);
  margin: 0;
  background: var(--uf-color-surface);
}
.uf-composer__step legend {
  padding: 0 var(--uf-space-3);
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  gap: var(--uf-space-3);
}
.uf-step-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--uf-color-brand-soft);
  color: var(--uf-color-brand);
  flex: 0 0 auto;
  position: relative;
}
.uf-step-icon::after {
  content: "";
  position: absolute;
  inset: -3px;
  border-radius: 50%;
  border: 1px solid var(--uf-color-brand);
  opacity: 0.25;
}
.uf-step-meta {
  display: inline-flex;
  flex-direction: column;
  gap: 2px;
}
.uf-composer__step-title {
  font-family: var(--uf-font-display);
  font-size: 20px;
  font-weight: 600;
  color: var(--uf-color-ink);
  letter-spacing: -0.01em;
}
.uf-composer__step-sub {
  font-family: var(--uf-font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--uf-color-ink-soft);
  margin: var(--uf-space-5) 0 var(--uf-space-3);
}
.uf-composer__step.is-placeholder { opacity: 0.65; border-style: dashed; }

.uf-composer__filters {
  display: flex;
  flex-wrap: wrap;
  gap: var(--uf-space-2);
  margin-top: var(--uf-space-3);
}

/* Hiérarchisation famille : grands groupes (niveau 1) + sous-familles (niveau 2) */
.uf-composer__groups {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: var(--uf-space-2);
  margin-top: var(--uf-space-3);
}
.uf-group-btn--sm {
  padding: var(--uf-space-3);
  gap: 4px;
}
.uf-group-btn--sm .uf-group-btn__icon { width: 30px; height: 30px; }
.uf-group-btn--sm .uf-group-btn__name { font-size: 13px; }
.uf-composer__subfamilies {
  display: flex;
  flex-wrap: wrap;
  gap: var(--uf-space-2);
  margin-top: var(--uf-space-3);
  padding: var(--uf-space-3);
  background: var(--uf-color-bg);
  border-radius: var(--uf-radius-sm);
  border-left: 3px solid var(--uf-color-brand);
}

/* Définition uf-group-btn (dupliquée depuis catalog.css pour disponibilité partout) */
.uf-group-btn {
  --group-color: var(--uf-color-brand);
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--uf-space-3);
  padding: var(--uf-space-3) var(--uf-space-4);
  background: var(--uf-color-surface);
  border: 1.5px solid var(--uf-color-line);
  border-radius: var(--uf-radius-md);
  text-align: left;
  cursor: pointer;
  transition: border-color var(--uf-trans-fast), background var(--uf-trans-fast), transform var(--uf-trans-fast), box-shadow var(--uf-trans-fast);
  position: relative;
  overflow: hidden;
  min-height: 56px;
}
.uf-group-btn::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--group-color);
  opacity: 0.3;
  transition: opacity var(--uf-trans-fast), height var(--uf-trans-fast);
}
.uf-group-btn:hover {
  border-color: var(--group-color);
  transform: translateY(-2px);
  box-shadow: 0 6px 16px -10px rgba(31, 31, 29, 0.25);
}
.uf-group-btn:hover::before { opacity: 1; height: 4px; }
.uf-group-btn.is-active {
  border-color: var(--group-color);
  background: color-mix(in srgb, var(--group-color) 8%, var(--uf-color-surface));
}
.uf-group-btn.is-active::before { opacity: 1; height: 5px; }
.uf-group-btn__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: color-mix(in srgb, var(--group-color) 12%, var(--uf-color-bg));
  border-radius: 50%;
  flex-shrink: 0;
}
.uf-group-btn__name {
  font-family: var(--uf-font-display);
  font-size: 14px;
  font-weight: 600;
  color: var(--uf-color-ink);
  line-height: 1.2;
}
.uf-group-btn__count {
  font-family: var(--uf-font-mono);
  font-size: 11px;
  color: var(--uf-color-ink-soft);
}

.uf-famille-picto { display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.uf-famille-picto svg { display: block; }

/* Pagination (dupliquée depuis catalog.css) */
.uf-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--uf-space-2);
  margin: var(--uf-space-5) 0;
  flex-wrap: wrap;
}
.uf-pagination__btn {
  min-width: 38px;
  height: 38px;
  padding: 0 var(--uf-space-3);
  background: var(--uf-color-surface);
  border: 1px solid var(--uf-color-line);
  border-radius: var(--uf-radius-sm);
  font-family: var(--uf-font-mono);
  font-size: 14px;
  color: var(--uf-color-ink);
  cursor: pointer;
  transition: border-color var(--uf-trans-fast), background var(--uf-trans-fast);
}
.uf-pagination__btn:hover:not(:disabled) {
  border-color: var(--uf-color-brand);
  background: var(--uf-color-brand-soft);
}
.uf-pagination__btn.is-active {
  background: var(--uf-color-brand);
  color: var(--uf-color-surface);
  border-color: var(--uf-color-brand);
}
.uf-pagination__btn:disabled { opacity: 0.4; cursor: not-allowed; }
.uf-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--uf-space-2);
  padding: 6px 12px;
  border: 1px solid var(--uf-color-line);
  border-radius: var(--uf-radius-pill);
  background: var(--uf-color-surface);
  color: var(--uf-color-ink);
  font-size: 13px;
  cursor: pointer;
  transition: border-color var(--uf-trans-fast), background var(--uf-trans-fast),
              color var(--uf-trans-fast), transform var(--uf-trans-fast),
              box-shadow var(--uf-trans-fast);
}
.uf-pill:hover {
  border-color: var(--uf-color-brand);
  background: var(--uf-color-brand-soft);
  color: var(--uf-color-brand);
  transform: translateY(-1px);
}
.uf-pill.is-active {
  background: var(--uf-color-brand);
  color: var(--uf-color-surface);
  border-color: var(--uf-color-brand);
  box-shadow: 0 3px 10px -4px rgba(46, 93, 79, 0.5);
}
.uf-pill.is-active:hover {
  background: var(--uf-color-brand);
  color: var(--uf-color-surface);
}

.uf-composer__search { display: block; margin-top: var(--uf-space-3); }
.uf-composer__search input {
  width: 100%;
  padding: var(--uf-space-3) var(--uf-space-4);
  border: 1px solid var(--uf-color-line);
  border-radius: var(--uf-radius-sm);
  font: inherit;
  background: var(--uf-color-surface);
}

.uf-composer__aromes-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: var(--uf-space-3);
  margin-top: var(--uf-space-4);
}
.uf-arome-card {
  --arome-color: var(--uf-color-accent);
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: var(--uf-space-3) var(--uf-space-3);
  border: 1.5px solid var(--uf-color-line);
  border-radius: var(--uf-radius-sm);
  background: var(--uf-color-surface);
  text-align: center;
  cursor: pointer;
  transition: border-color var(--uf-trans-fast), background var(--uf-trans-fast), transform var(--uf-trans-fast), box-shadow var(--uf-trans-fast);
  overflow: hidden;
}
.uf-arome-card:hover:not(:disabled) {
  border-color: var(--arome-color);
  transform: translateY(-2px);
  box-shadow: 0 6px 14px -8px color-mix(in srgb, var(--arome-color) 40%, rgba(0,0,0,0.2));
}
.uf-arome-card.is-selected {
  border-color: var(--arome-color);
  background: color-mix(in srgb, var(--arome-color) 10%, var(--uf-color-surface));
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--arome-color) 18%, transparent);
}
.uf-arome-card.is-selected::before {
  content: "";
  position: absolute;
  top: -1.5px; right: -1.5px;
  width: 16px; height: 16px;
  background: var(--arome-color);
  clip-path: polygon(100% 0, 0 0, 100% 100%);
  border-top-right-radius: var(--uf-radius-sm);
}
.uf-arome-card.is-disabled { opacity: 0.45; cursor: not-allowed; }
.uf-arome-card__icon {
  width: 46px;
  height: 46px;
  background: color-mix(in srgb, var(--arome-color) 14%, var(--uf-color-bg));
  border-radius: 50%;
  padding: 6px;
  transition: background var(--uf-trans-fast);
}
.uf-arome-card.is-selected .uf-arome-card__icon {
  background: color-mix(in srgb, var(--arome-color) 22%, var(--uf-color-surface));
}
.uf-arome-card__name { font-size: 13.5px; font-weight: 600; font-family: var(--uf-font-display); line-height: 1.2; }
.uf-arome-card__hint { font-family: var(--uf-font-mono); font-size: 10.5px; color: var(--uf-color-ink-soft); }

.uf-swatch {
  display: inline-block;
  width: 14px; height: 14px;
  border-radius: 3px;
  border: 1px solid rgba(0, 0, 0, 0.08);
}
.uf-swatch--sm { width: 10px; height: 10px; }

.uf-composer__doses { margin-top: var(--uf-space-5); }
.uf-composer__dose {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--uf-space-2);
  padding: var(--uf-space-3) 0;
  border-bottom: 1px solid var(--uf-color-line);
}
.uf-composer__dose:last-child { border-bottom: none; }
.uf-composer__dose label {
  display: flex;
  align-items: center;
  gap: var(--uf-space-2);
  font-size: 14px;
}
.uf-composer__dose-name { flex: 1; }
.uf-composer__dose-value { font-family: var(--uf-font-mono); font-size: 14px; color: var(--uf-color-brand); }
.uf-composer__dose input[type="range"] { width: 100%; }

.uf-composer__sliders {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--uf-space-4);
  margin-top: var(--uf-space-3);
}
.uf-composer__sliders label { display: grid; gap: var(--uf-space-2); }
.uf-composer__sliders label > span { display: flex; justify-content: space-between; font-size: 14px; }
.uf-composer__sliders strong { font-family: var(--uf-font-mono); font-weight: 600; color: var(--uf-color-brand); }
.uf-composer__slider-lock {
  color: var(--uf-color-accent);
  font-style: italic;
}
.uf-composer__slider-lock strong {
  color: var(--uf-color-accent);
  font-style: normal;
}

/* Sliders custom — accent-color natif pour la fill, thumb pop personnalisé.
   Scopés au configurateur + mini-config. */
.uf-composer input[type="range"],
.uf-mini-config input[type="range"] {
  appearance: none;
  -webkit-appearance: none;
  width: 100%;
  height: 6px;
  /* Fill vert pilier jusqu'au thumb, puis ligne neutre — calculé par JS via --uf-range-p */
  background: linear-gradient(
    to right,
    var(--uf-color-brand) 0%,
    var(--uf-color-brand) var(--uf-range-p, 50%),
    var(--uf-color-line) var(--uf-range-p, 50%),
    var(--uf-color-line) 100%
  );
  border-radius: 3px;
  outline: none;
  margin: 10px 0;
  cursor: pointer;
  accent-color: var(--uf-color-brand);  /* fallback navigateurs anciens */
}
/* Track Webkit : transparent pour laisser apparaître le gradient sur le background du host */
.uf-composer input[type="range"]::-webkit-slider-runnable-track,
.uf-mini-config input[type="range"]::-webkit-slider-runnable-track {
  height: 6px;
  background: transparent;
  border-radius: 3px;
}
.uf-composer input[type="range"]::-moz-range-track,
.uf-mini-config input[type="range"]::-moz-range-track {
  height: 6px;
  background: transparent;
  border-radius: 3px;
}
/* Progress Firefox : transparent (le gradient sur le host fait déjà le job) */
.uf-composer input[type="range"]::-moz-range-progress,
.uf-mini-config input[type="range"]::-moz-range-progress {
  height: 6px;
  background: transparent;
  border-radius: 3px;
}
.uf-composer input[type="range"]::-webkit-slider-thumb,
.uf-mini-config input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 22px;
  height: 22px;
  margin-top: -8px;
  border-radius: 50%;
  background: var(--uf-color-accent, #E8744B);
  border: 2px solid var(--uf-color-brand);
  cursor: pointer;
  box-shadow: 0 2px 5px rgba(31, 31, 29, 0.18);
  transition: transform var(--uf-trans-fast);
}
.uf-composer input[type="range"]::-webkit-slider-thumb:hover,
.uf-mini-config input[type="range"]::-webkit-slider-thumb:hover {
  transform: scale(1.12);
}
.uf-composer input[type="range"]::-moz-range-thumb,
.uf-mini-config input[type="range"]::-moz-range-thumb {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--uf-color-accent, #E8744B);
  border: 2px solid var(--uf-color-brand);
  cursor: pointer;
  box-shadow: 0 2px 5px rgba(31, 31, 29, 0.18);
}
.uf-composer input[type="range"]:focus-visible,
.uf-mini-config input[type="range"]:focus-visible {
  outline: 2px solid var(--uf-color-brand);
  outline-offset: 4px;
}

.uf-composer__base-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--uf-space-3);
  margin-top: var(--uf-space-3);
}
.uf-composer__volume-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--uf-space-3);
  margin-top: var(--uf-space-3);
}
@media (max-width: 720px) {
  .uf-composer__base-cards { grid-template-columns: 1fr; }
  .uf-composer__volume-cards { grid-template-columns: repeat(2, 1fr); }
}
.uf-card-choice {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  padding: var(--uf-space-4) var(--uf-space-5);
  background: var(--uf-color-surface);
  border: 1.5px solid var(--uf-color-line);
  border-radius: var(--uf-radius-sm);
  text-align: left;
  cursor: pointer;
  transition: border-color var(--uf-trans-fast), background var(--uf-trans-fast), transform var(--uf-trans-fast), box-shadow var(--uf-trans-fast);
}
.uf-card-choice:hover {
  border-color: var(--uf-color-ink);
  transform: translateY(-1px);
  box-shadow: 0 4px 14px -8px rgba(31, 31, 29, 0.25);
}
.uf-card-choice.is-selected {
  border-color: var(--uf-color-brand);
  background: var(--uf-color-brand-soft);
  box-shadow: 0 0 0 2px var(--uf-color-brand-soft);
}
.uf-card-choice.is-selected::before {
  content: "";
  position: absolute;
  top: -1.5px; right: -1.5px;
  width: 16px; height: 16px;
  background: var(--uf-color-brand);
  clip-path: polygon(100% 0, 0 0, 100% 100%);
  border-top-right-radius: var(--uf-radius-sm);
}
.uf-card-choice strong { font-family: var(--uf-font-display); font-size: 16px; }
.uf-card-choice small { color: var(--uf-color-ink-soft); font-size: 12px; }

/* Étape 5 — Niveau de nicotine */
.uf-composer__nico-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: var(--uf-space-3);
  margin-top: var(--uf-space-3);
}
.uf-card-choice--nico {
  position: relative;
  align-items: center;
  text-align: center;
  padding: var(--uf-space-4) var(--uf-space-3);
}
.uf-card-choice--nico strong { font-size: 18px; letter-spacing: 0.2px; }
.uf-card-choice--nico.is-selected::after {
  content: "✓";
  position: absolute;
  top: 6px; right: 8px;
  font-family: var(--uf-font-mono);
  font-size: 11px;
  color: var(--uf-color-brand);
}
.uf-card-choice--nico.is-zero strong { color: var(--uf-color-ink-soft); }
.uf-card-choice--nico.is-zero.is-selected strong { color: var(--uf-color-brand); }

.uf-composer__nico-type {
  margin-top: var(--uf-space-4);
}
.uf-composer__nico-type-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--uf-space-3);
  margin-top: var(--uf-space-2);
}
@media (max-width: 560px) {
  .uf-composer__nico-type-cards { grid-template-columns: 1fr; }
}
.uf-card-choice--nico-type {
  align-items: flex-start;
  text-align: left;
  padding: var(--uf-space-4);
}
.uf-card-choice--nico-type strong { font-size: 15px; }
.uf-card-choice--nico-type small {
  display: block;
  font-size: 12px;
  line-height: 1.4;
  color: var(--uf-color-ink-soft);
  margin-top: 4px;
}
.uf-card-choice--nico-type.is-selected small { color: var(--uf-color-ink); }

.uf-composer__nico-info {
  margin-top: var(--uf-space-4);
  padding: var(--uf-space-4) var(--uf-space-5);
  background: var(--uf-color-surface);
  border: 1px solid var(--uf-color-line);
  border-left: 3px solid var(--uf-color-pop, #C5F04A);
  border-radius: var(--uf-radius-sm);
  display: grid;
  gap: var(--uf-space-2);
}
.uf-composer__nico-info-lead {
  display: flex;
  align-items: flex-start;
  gap: var(--uf-space-3);
  font-size: 14.5px;
  line-height: 1.45;
  color: var(--uf-color-ink);
  margin: 0;
}
.uf-composer__nico-info-lead .uf-icon {
  flex: 0 0 auto;
  margin-top: 2px;
  color: var(--uf-color-brand);
}
.uf-composer__nico-info-lead strong {
  font-family: var(--uf-font-mono);
  font-weight: 600;
  color: var(--uf-color-brand);
  padding: 0 4px;
}
.uf-composer__nico-info-conc {
  margin: 0;
  padding-left: 32px;
  color: var(--uf-color-ink-soft);
}
.uf-composer__nico-info-conc strong {
  font-family: var(--uf-font-mono);
  color: var(--uf-color-ink);
}
.uf-composer__nico-info-legal {
  margin: 0;
  padding: var(--uf-space-3);
  background: var(--uf-color-bg);
  border-radius: var(--uf-radius-sm);
  font-size: 12.5px;
  line-height: 1.5;
  color: var(--uf-color-ink-soft);
}
.uf-composer__nico-info-legal strong {
  color: var(--uf-color-ink);
  letter-spacing: 0.3px;
}

.uf-composer__final {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: var(--uf-space-4);
  margin-top: var(--uf-space-3);
}
.uf-composer__final label { display: grid; gap: var(--uf-space-2); font-size: 14px; }
.uf-composer__final input {
  padding: var(--uf-space-3) var(--uf-space-4);
  border: 1px solid var(--uf-color-line);
  border-radius: var(--uf-radius-sm);
  font: inherit;
  background: var(--uf-color-surface);
}
@media (max-width: 600px) { .uf-composer__final { grid-template-columns: 1fr; } }

.uf-composer__flacon { display: flex; justify-content: center; margin-bottom: var(--uf-space-4); }
.uf-composer__flacon flacon-dynamic { display: block; }
@media (max-width: 1100px) {
  .uf-composer__flacon flacon-dynamic svg { width: 200px; height: 266px; }
}

.uf-composer__price {
  text-align: center;
  margin-bottom: var(--uf-space-4);
  min-height: 64px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.uf-composer__price-ttc {
  display: block;
  font-family: var(--uf-font-display);
  font-size: 28px;
  font-weight: 600;
  color: var(--uf-color-ink);
}
.uf-composer__price-error {
  color: #B8324E;
  font-size: 13px;
  background: rgba(184, 50, 78, 0.08);
  border: 1px solid rgba(184, 50, 78, 0.3);
  border-radius: var(--uf-radius-sm);
  padding: var(--uf-space-2) var(--uf-space-3);
  margin: 0;
}

.uf-composer__actions {
  display: flex;
  flex-direction: column;
  gap: var(--uf-space-2);
}
.uf-composer__actions .uf-btn { width: 100%; justify-content: center; }
.uf-btn--ghost {
  background: transparent;
  color: var(--uf-color-ink-soft);
  border: none;
  text-decoration: underline;
  text-underline-offset: 0.25em;
  text-decoration-thickness: 1px;
  text-decoration-color: var(--uf-color-line);
  padding: var(--uf-space-2);
  font-size: 13px;
  transition: color var(--uf-trans-fast), text-decoration-color var(--uf-trans-fast);
}
.uf-btn--ghost:hover {
  color: var(--uf-color-accent);
  text-decoration-color: var(--uf-color-accent);
  text-decoration-thickness: 2px;
}
.uf-btn:disabled { opacity: 0.45; cursor: not-allowed; }
.uf-btn:disabled:hover { transform: none !important; box-shadow: none !important; }

.uf-composer__mentions { margin-top: var(--uf-space-4); }

.screen-reader-text {
  position: absolute !important;
  width: 1px; height: 1px;
  margin: -1px; padding: 0; overflow: hidden;
  clip: rect(0, 0, 0, 0); border: 0;
}

/* Sticky bottom bar (mobile uniquement) */
.uf-composer__sticky-bottom {
  display: none;
  position: fixed; bottom: 0; left: 0; right: 0;
  background: var(--uf-color-surface);
  border-top: 1px solid var(--uf-color-line);
  padding: var(--uf-space-3) var(--uf-space-4);
  z-index: 50;
  gap: var(--uf-space-3);
  align-items: center;
  box-shadow: 0 -4px 12px rgba(0, 0, 0, 0.06);
}
.uf-composer__sticky-bottom .uf-btn { padding: var(--uf-space-3) var(--uf-space-5); }
.uf-composer__sticky-name {
  flex: 1;
  font-family: var(--uf-font-display);
  font-size: 14px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.uf-composer__sticky-price {
  font-family: var(--uf-font-display);
  font-size: 18px;
  font-weight: 600;
}
@media (max-width: 900px) { .uf-composer__sticky-bottom { display: flex; } .uf-composer { padding-bottom: 92px; } }

/* Étiquette : aperçu courant dans l'étape 6 */
.uf-composer__label-current {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: var(--uf-space-4);
  margin-top: var(--uf-space-3);
  padding: var(--uf-space-4);
  border: 1px solid var(--uf-color-line);
  border-radius: var(--uf-radius-sm);
  background: var(--uf-color-bg);
}
.uf-composer__label-preview {
  width: 120px; height: 160px;
  border: 1px solid var(--uf-color-line);
  border-radius: var(--uf-radius-sm);
  overflow: hidden;
  background: var(--uf-color-surface);
}
.uf-composer__label-preview img {
  width: 100%; height: 100%; object-fit: cover;
}
.uf-composer__label-info {
  display: flex;
  flex-direction: column;
  gap: var(--uf-space-2);
}

/* Modale étiquette */
.uf-label-modal {
  border: 1px solid var(--uf-color-line);
  border-radius: var(--uf-radius-md);
  padding: 0;
  background: var(--uf-color-surface);
  color: var(--uf-color-ink);
  width: min(900px, 95vw);
  max-height: 90vh;
  box-shadow: 0 12px 48px rgba(0,0,0,0.18);
}
.uf-label-modal::backdrop {
  background: rgba(31, 31, 29, 0.55);
  backdrop-filter: blur(2px);
}
.uf-label-modal__inner {
  display: flex;
  flex-direction: column;
  max-height: 90vh;
}
.uf-label-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--uf-space-4) var(--uf-space-5);
  border-bottom: 1px solid var(--uf-color-line);
}
.uf-label-modal__header h2 {
  font-family: var(--uf-font-display);
  font-size: 20px;
  margin: 0;
}
.uf-label-modal__close {
  background: none; border: none;
  font-size: 28px; line-height: 1;
  cursor: pointer;
  color: var(--uf-color-ink-soft);
  padding: var(--uf-space-2);
}
.uf-label-modal__close:hover { color: var(--uf-color-ink); }

.uf-label-modal__tabs {
  display: flex;
  border-bottom: 1px solid var(--uf-color-line);
  padding: 0 var(--uf-space-5);
  gap: var(--uf-space-2);
  overflow-x: auto;
}
.uf-label-modal__tabs button {
  background: none; border: none;
  padding: var(--uf-space-3) var(--uf-space-4);
  font: inherit;
  color: var(--uf-color-ink-soft);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  white-space: nowrap;
}
.uf-label-modal__tabs button.is-active {
  color: var(--uf-color-ink);
  border-bottom-color: var(--uf-color-accent);
}

.uf-label-modal__body {
  padding: var(--uf-space-5);
  overflow-y: auto;
}

.uf-label-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: var(--uf-space-3);
  margin-top: var(--uf-space-3);
}
.uf-label-tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: var(--uf-space-2);
  background: var(--uf-color-bg);
  border: 1px solid var(--uf-color-line);
  border-radius: var(--uf-radius-sm);
  cursor: pointer;
  transition: border-color var(--uf-trans-fast);
}
.uf-label-tile:hover:not(:disabled) { border-color: var(--uf-color-accent); }
.uf-label-tile:disabled { opacity: 0.5; cursor: not-allowed; }
.uf-label-tile img {
  width: 100%; height: 140px;
  object-fit: contain;
  background: var(--uf-color-surface);
}
.uf-label-tile small { font-size: 11px; color: var(--uf-color-ink-soft); text-align: center; }

.uf-label-modal__search {
  display: flex;
  gap: var(--uf-space-3);
  margin-bottom: var(--uf-space-3);
}
.uf-label-modal__search input {
  flex: 1;
  padding: var(--uf-space-3) var(--uf-space-4);
  border: 1px solid var(--uf-color-line);
  border-radius: var(--uf-radius-sm);
  font: inherit;
}
.uf-label-modal__generate {
  display: flex;
  flex-direction: column;
  gap: var(--uf-space-3);
}
.uf-label-modal__generate textarea {
  min-height: 100px;
  padding: var(--uf-space-3) var(--uf-space-4);
  border: 1px solid var(--uf-color-line);
  border-radius: var(--uf-radius-sm);
  font: inherit;
  resize: vertical;
}

input[type="range"] {
  -webkit-appearance: none;
  appearance: none;
  height: 4px;
  background: var(--uf-color-line);
  border-radius: 2px;
  outline: none;
}
input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--uf-color-brand);
  cursor: pointer;
  transition: transform var(--uf-trans-fast);
}
input[type="range"]::-webkit-slider-thumb:hover { transform: scale(1.1); }
input[type="range"]::-moz-range-thumb {
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--uf-color-brand);
  cursor: pointer;
  border: none;
}

/* ===== Concepteur d'étiquettes — refonte UX 2026-05-15 ===== */

/* Bouton "Personnaliser l'étiquette" (état vide) */
.uf-composer__label-trigger {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}
.uf-composer__label-trigger svg {
	flex-shrink: 0;
}

/* Bloc actif avec preview + contrôles */
.uf-composer__label-current {
	display: grid;
	grid-template-columns: 140px 1fr;
	gap: var(--uf-space-4);
	padding: var(--uf-space-4);
	background: var(--uf-color-surface);
	border: 1.5px solid var(--uf-color-line);
	border-radius: var(--uf-radius-md);
	align-items: start;
}
@media (max-width: 540px) {
	.uf-composer__label-current {
		grid-template-columns: 1fr;
	}
}

/* Zone preview de l'étiquette */
.uf-composer__label-preview {
	position: relative;
	aspect-ratio: 2 / 3;
	border-radius: 6px;
	overflow: hidden;
	background:
		linear-gradient(45deg, rgba(0,0,0,0.04) 25%, transparent 25%) 0 0 / 12px 12px,
		linear-gradient(-45deg, rgba(0,0,0,0.04) 25%, transparent 25%) 0 0 / 12px 12px,
		var(--uf-color-bg);
	border: 1px solid var(--uf-color-line);
}
.uf-composer__label-preview img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.uf-composer__label-preview.is-broken::after {
	content: "Image illisible";
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(232, 116, 75, 0.08);
	color: #B92C3E;
	font-size: 12px;
	font-weight: 600;
	text-align: center;
	padding: 8px;
}

/* Badge statut modération */
.uf-composer__label-badge {
	position: absolute;
	top: 6px;
	right: 6px;
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 3px 8px;
	border-radius: 999px;
	font-family: var(--uf-font-body);
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.02em;
	background: rgba(255, 250, 240, 0.95);
	color: #B86E2C;
	box-shadow: 0 1px 4px rgba(0,0,0,0.1);
	backdrop-filter: blur(2px);
}
.uf-composer__label-badge.is-ok {
	background: rgba(232, 247, 232, 0.95);
	color: #2E5D4F;
}

/* Infos & contrôles à droite du preview */
.uf-composer__label-info {
	display: flex;
	flex-direction: column;
	gap: var(--uf-space-2);
}
.uf-composer__label-source {
	font-weight: 600;
	color: var(--uf-color-ink);
	margin: 0;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	font-size: 11px;
}
.uf-composer__label-opacity {
	display: flex;
	flex-direction: column;
	gap: 4px;
	font-size: 13px;
}
.uf-composer__label-opacity input[type="range"] {
	width: 100%;
}
.uf-composer__label-hint {
	padding: 8px 10px;
	background: rgba(232, 116, 75, 0.08);
	border-left: 2px solid #E8744B;
	border-radius: 3px;
	color: #8B4012;
	font-size: 12px;
	line-height: 1.4;
	margin: 0;
}
.uf-composer__label-actions {
	display: flex;
	gap: var(--uf-space-2);
	flex-wrap: wrap;
	margin-top: var(--uf-space-2);
}
.uf-composer__label-actions .uf-btn {
	font-size: 13px;
	padding: 6px 12px;
}

/* Onglet Upload : zone drop-friendly */
.uf-label-upload .uf-label-dropzone {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	padding: var(--uf-space-5);
	margin-top: var(--uf-space-3);
	border: 2px dashed var(--uf-color-line);
	border-radius: var(--uf-radius-md);
	background: var(--uf-color-bg);
	cursor: pointer;
	color: var(--uf-color-ink-soft);
	font-size: 13px;
	text-align: center;
	transition: border-color .15s, background .15s;
}
.uf-label-upload .uf-label-dropzone:hover {
	border-color: var(--uf-color-brand);
	background: var(--uf-color-surface);
}
.uf-label-upload .uf-label-dropzone.is-uploading {
	border-color: var(--uf-color-accent);
	color: var(--uf-color-accent);
	pointer-events: none;
}
.uf-label-upload .uf-label-dropzone svg {
	color: var(--uf-color-brand);
}
