/* ═══════════════════════════════════════════════════
   COMPOSANTS — ALTHEA MAP v4
═══════════════════════════════════════════════════ */

/* ── INPUTS ── */
input[type=text], input[type=date], select, textarea {
  width: 100%;
  padding: 9px 12px;
  background: var(--paper);
  border: 1.5px solid var(--border2);
  border-radius: var(--r8);
  font-family: var(--fb);
  font-size: 13px;
  color: var(--ink);
  transition: border-color var(--ease), box-shadow var(--ease);
  outline: none;
  box-shadow: var(--sh0);
}
input:focus, select:focus, textarea:focus {
  border-color: var(--bluel);
  box-shadow: 0 0 0 3px rgba(59,130,246,.1);
}
textarea { resize: vertical; min-height: 75px; }
label.fl {
  display: block;
  font-size: 10.5px;
  font-weight: 600;
  color: var(--ink3);
  margin-bottom: 5px;
  text-transform: uppercase;
  letter-spacing: .06em;
}

/* ── BOUTONS ── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px 16px;
  border-radius: var(--r8);
  font-family: var(--fb);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  border: none;
  transition: all var(--ease);
  white-space: nowrap;
}
.btn-p    { background: var(--blue); color: #fff; box-shadow: var(--sh-blue), var(--sh1); }
.btn-p:hover { background: var(--blued); transform: translateY(-1px); }
.btn-s    { background: var(--paper); color: var(--ink2); border: 1.5px solid var(--border2); box-shadow: var(--sh0); }
.btn-s:hover { background: var(--paper3); }
.btn-g    { background: transparent; color: var(--ink3); padding: 6px 10px; }
.btn-g:hover { background: var(--paper3); color: var(--ink); }
.btn-d    { background: rgba(220,38,38,0.06); color: var(--red); border: 1.5px solid rgba(220,38,38,0.15); }
.btn-d:hover { background: rgba(220,38,38,0.1); }
.btn-sm   { padding: 5px 12px; font-size: 12px; }
.btn-lg   { padding: 12px 28px; font-size: 15px; }
.btn-ic   { width: 32px; height: 32px; padding: 0; border-radius: var(--r8); }

/* ── CARD ── */
.card {
  background: var(--paper);
  border-radius: var(--r16);
  padding: 20px;
  box-shadow: var(--sh-card);
}

/* ── BADGE ── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 2px 8px;
  border-radius: 20px;
  font-size: 10.5px;
  font-weight: 700;
}
.b-std   { background: #EFF6FF; color: var(--blue); }
.b-pv    { background: #FFFBEB; color: var(--amber); }
.b-green { background: #ECFDF5; color: var(--green); }
.b-red   { background: #FEF2F2; color: var(--red); }

/* ── SWITCH ── */
.sw-tr {
  width: 44px; height: 24px;
  border-radius: 12px; cursor: pointer;
  transition: background var(--ease);
  position: relative; flex-shrink: 0;
  background: #FCA5A5; user-select: none;
}
.sw-th {
  position: absolute; top: 3px; left: 3px;
  width: 18px; height: 18px; background: #fff;
  border-radius: 50%; transition: transform var(--ease);
  box-shadow: 0 1px 4px rgba(0,0,0,.2);
}
.sw-tr.on { background: #34D399; }
.sw-tr.on .sw-th { transform: translateX(20px); }

/* ── NAV ITEMS — Sidebar Tech-Pro sombre ── */
.nlbl {
  font-family: 'DM Mono', ui-monospace, Consolas, monospace;
  font-size: 9.5px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #64748B;
  padding: 14px 10px 6px;
  user-select: none;
}
.ni {
  display: flex;
  align-items: center;
  height: 34px;
  padding: 0 10px;
  border-radius: 8px;
  margin: 1px 0;
  cursor: pointer;
  font-size: 13px;
  font-weight: 500;
  color: #94A3B8;
  transition: background-color 0.12s ease, color 0.12s ease;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ni:hover { background: rgba(255,255,255,0.05); color: #CBD5E1; }
.ni.active {
  background: rgba(55,138,221,0.18);
  color: #E6F1FB;
  font-weight: 600;
  box-shadow: inset 3px 0 0 #378ADD;
  border-radius: 0 8px 8px 0;
}
.ni.active:hover { background: rgba(55,138,221,0.24); }
.ni-ico { width: 16px; height: 16px; fill: currentColor; flex-shrink: 0; margin-right: 8px; opacity: 0.7; }
.ni.active .ni-ico { fill: #85B7EB; opacity: 1; }
.ni-sub {
  height: 30px !important;
  padding-left: 24px !important;
  font-size: 12.5px !important;
  color: #748296;
}
.ni-sub:hover { background: rgba(255,255,255,0.05); color: #CBD5E1; }
.ni-sub.active { background: rgba(55,138,221,0.18); color: #E6F1FB; box-shadow: inset 3px 0 0 #378ADD; border-radius: 0 8px 8px 0; }
.ni-pv {
  width: 6px; height: 6px; border-radius: 50%;
  background: #EF9F27; margin-left: auto; flex-shrink: 0;
}
.ni.active .ni-pv { background: #85B7EB; }

/* ── WIZARD SUIVANT / PRÉCÉDENT ── */
.nav-wizard {
  margin-top: auto;
  padding: 12px 4px 4px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.nav-btn-next, .nav-btn-prev {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 38px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: opacity 0.15s ease, background 0.15s ease;
  user-select: none;
}
.nav-btn-next {
  background: #378ADD;
  color: #FFFFFF;
}
.nav-btn-next:hover { background: #2F7DCB; }
.nav-btn-prev {
  background: rgba(255,255,255,0.06);
  color: #94A3B8;
  border: 1px solid rgba(255,255,255,0.08);
}
.nav-btn-prev:hover { background: rgba(255,255,255,0.1); color: #CBD5E1; }
.nav-btn-next.disabled, .nav-btn-prev.disabled {
  opacity: 0.3;
  cursor: default;
  pointer-events: none;
}

/* ── INDICATEUR SYNC ── */
.sync-dot {
  width: 8px; height: 8px; border-radius: 50%;
  flex-shrink: 0;
}
.sync-dot.ok      { background: var(--sync-ok); box-shadow: 0 0 0 2px rgba(5,150,105,.2); }
.sync-dot.pending { background: var(--sync-pending); animation: pulse 1.5s infinite; }
.sync-dot.error   { background: var(--sync-error); }
.sync-dot.offline { background: var(--sync-offline); }

@keyframes pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: .4; }
}

/* ── TOAST ── */
.toast {
  background: var(--ink2);
  color: #fff;
  padding: 10px 16px;
  border-radius: var(--r8);
  font-size: 13px;
  box-shadow: var(--sh3);
  pointer-events: auto;
  animation: toastIn .2s ease;
  max-width: 340px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.toast.success { background: var(--green); }
.toast.error   { background: var(--red); }
.toast.warning { background: var(--amber); }
.toast-action {
  background: rgba(255,255,255,.2);
  border: none;
  color: #fff;
  border-radius: 4px;
  padding: 3px 10px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  margin-left: auto;
}
.toast-action:hover { background: rgba(255,255,255,.35); }

@keyframes toastIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── FORMULAIRES SECTIONS ── */
.section-wrap { max-width: 860px; }
.section-title {
  font-family: var(--fh);
  font-size: 20px; font-weight: 800;
  color: var(--ink); margin-bottom: 24px;
}
.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}
.field-full { grid-column: 1 / -1; }
.field-group { display: flex; flex-direction: column; gap: 5px; }
.field-group label {
  font-size: 10.5px; font-weight: 700;
  color: var(--ink3); text-transform: uppercase; letter-spacing: .06em;
}
.field-input {
  width: 100%; padding: 9px 12px;
  background: var(--paper);
  border: 1.5px solid var(--border2);
  border-radius: var(--r8);
  font-family: var(--fb); font-size: 13px;
  color: var(--ink); outline: none;
  transition: border-color var(--ease), box-shadow var(--ease);
  box-shadow: var(--sh0);
}
.field-input:focus {
  border-color: var(--bluel);
  box-shadow: 0 0 0 3px rgba(59,130,246,.1);
}

/* ── SECTIONS TITRES ── */
.s-h1 {
  font-family: var(--fh);
  font-size: 22px; font-weight: 800;
  color: var(--ink); margin-bottom: 4px;
}
.s-sub {
  font-size: 13px; color: var(--ink3);
  margin-bottom: 24px;
}

/* ── SECTIONS STANDARD (renderStd) ── */
.s-wrap { max-width: 860px; padding: 24px 24px 48px; }

.sec-t {
  font-size: 10.5px; font-weight: 700; color: var(--ink3);
  text-transform: uppercase; letter-spacing: .08em;
  padding: 16px 0 8px; margin-top: 8px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 6px;
}
.sec-t:first-child { padding-top: 0; }

.sec-sub-t {
  font-size: 11.5px; font-weight: 700; color: var(--blue);
  padding: 10px 0 4px; margin-top: 4px;
  text-transform: uppercase; letter-spacing: .05em;
}

/* Toggle card */
.tc {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px;
  background: var(--paper);
  border: 1.5px solid var(--border);
  border-radius: var(--r8);
  margin-bottom: 5px;
  transition: border-color var(--ease), box-shadow var(--ease);
}
.tc:hover { border-color: var(--border2); box-shadow: var(--sh0); }
.tc-lbl { font-size: 13px; color: var(--ink2); font-weight: 500; flex: 1; }
.tc-right { display: flex; align-items: center; gap: 10px; }

.sw-lbl {
  font-size: 11px; font-weight: 700; min-width: 28px; text-align: right;
}
.sw-lbl.on  { color: var(--green); }
.sw-lbl.off { color: var(--ink4); }

/* Select card */
.cc {
  padding: 12px 14px;
  background: var(--paper);
  border: 1.5px solid var(--border);
  border-radius: var(--r8);
  margin-bottom: 5px;
}
.cc-hdr { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.cc-t { font-size: 13px; color: var(--ink2); font-weight: 500; }

/* Bloc observations */
.obs-b {
  background: var(--paper2);
  border-radius: var(--r8);
  padding: 10px 14px;
  margin: 6px 0 14px;
  border: 1px solid var(--border);
}
.obs-lbl {
  font-size: 10.5px; font-weight: 700; color: var(--ink3);
  text-transform: uppercase; letter-spacing: .06em; margin-bottom: 6px;
}
.obs-b textarea {
  background: transparent; border: none !important;
  box-shadow: none !important; padding: 0;
  min-height: 54px; font-size: 12.5px;
}
.obs-b textarea:focus { border: none !important; box-shadow: none !important; }

/* Bandeau charge ALTHEA / CLIENT */
.charge-banner {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px; border-radius: var(--r8); margin-bottom: 14px;
  border: 1.5px solid var(--border2);
}
.charge-althea { background: var(--bluexl); border-color: var(--bluel) !important; }
.charge-client { background: #FFFBEB; border-color: #F59E0B !important; }
.charge-lbl { font-size: 13px; font-weight: 700; }
.charge-althea .charge-lbl { color: var(--blued); }
.charge-client .charge-lbl { color: #92400E; }
.charge-btns { display: flex; gap: 6px; }
.charge-btn {
  padding: 5px 14px; border-radius: 20px;
  font-size: 12px; font-weight: 700;
  cursor: pointer; border: 1.5px solid var(--bluel);
  background: transparent; color: var(--blued);
  transition: all .18s; font-family: var(--fb);
}
.charge-btn.active { background: var(--blue); color: #fff; }
.charge-btn.client { border-color: #F59E0B; color: #92400E; }
.charge-btn.client.active { background: #F59E0B; color: #fff; }
.charge-note {
  padding: 10px 14px; background: #FFFBEB;
  border: 1px dashed #F59E0B;
  border-radius: var(--r8); margin-bottom: 14px;
  font-size: 12px; color: #92400E;
}
.charge-overlay { opacity: 0.42; pointer-events: none; filter: grayscale(0.25); }

/* ══════════════════════════════════════════════════════
   SECTIONS APPLE PREMIUM — renderStd v2
══════════════════════════════════════════════════════ */
@keyframes ap-textpop {
  0%   { transform: scale(1) }
  40%  { transform: scale(1.18) }
  70%  { transform: scale(.95) }
  100% { transform: scale(1) }
}
@keyframes ap-slidedown {
  0%   { opacity: 0; transform: translateY(-6px) }
  100% { opacity: 1; transform: translateY(0) }
}
.ap-anim { display: inline-block; animation: ap-textpop .35s cubic-bezier(.34,1.56,.64,1); }

.ap-wrap {
  padding: 28px 8px 48px;
  max-width: 100%;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}
.ap-crumb {
  font-family: 'DM Mono', ui-monospace, Consolas, monospace;
  font-size: 10px; color: #64748B;
  letter-spacing: .05em;
  margin-bottom: 4px;
}
.ap-head {
  display: flex; align-items: flex-start;
  justify-content: space-between; gap: 16px;
}
.ap-title {
  font-size: 26px; font-weight: 600;
  letter-spacing: -.025em;
  color: #0F172A; line-height: 1.15;
}
.ap-sub {
  font-size: 13px; color: var(--ink3);
  margin-top: 3px;
}
.ap-ratio {
  font-family: 'DM Mono', ui-monospace, Consolas, monospace;
  font-size: 14px; color: #0F172A;
  padding-top: 8px; flex-shrink: 0;
}
.ap-gbar {
  height: 2px; background: #E2E8F0;
  margin: 12px 0 20px;
}
.ap-gfill {
  height: 100%; background: #007AFF;
  transition: width .35s cubic-bezier(.4,0,.2,1);
}

/* Bandeau charge */
.ap-charge {
  background: var(--paper);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 12px;
  padding: 13px 16px; margin-bottom: 6px;
  display: flex; align-items: center; gap: 12px;
}
.ap-charge-txt { flex: 1; font-size: 14px; font-weight: 500; color: var(--ink); }
.ap-charge-btns { display: flex; gap: 6px; }
.ap-cpb {
  padding: 7px 16px; border-radius: 6px;
  font-family: 'DM Mono', ui-monospace, Consolas, monospace;
  font-size: 11px; font-weight: 500; letter-spacing: .05em;
  cursor: pointer;
  background: #F8F9FB; color: #94A3B8;
  border: 1px solid #E2E8F0;
  user-select: none;
  transition: background-color .15s ease, color .15s ease, border-color .15s ease;
}
.ap-cpb:active { transform: scale(0.98); }
.ap-cpb.act-a { background: #007AFF; color: #fff; border-color: #007AFF; }
.ap-cpb.act-c { background: #FF9F0A; color: #fff; border-color: #FF9F0A; }

/* Message client */
.ap-client-msg {
  background: #FFF4E0; border-radius: 10px;
  padding: 10px 14px; margin-bottom: 6px;
  font-size: 11px; color: #7C4A00; line-height: 1.4;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  box-shadow: 0 1px 3px rgba(255,159,10,.15);
}

/* Label section + barre progression */
.ap-sec-lbl {
  font-size: 11px; font-weight: 600;
  color: var(--ink3); text-transform: uppercase; letter-spacing: .07em;
  padding: 16px 4px 6px;
  display: flex; justify-content: space-between; align-items: center;
}
.ap-sec-lbl span:last-child {
  font-weight: 500; text-transform: none; letter-spacing: 0;
}
.ap-pbar {
  height: 2px; background: var(--border);
  border-radius: 999px; overflow: hidden; margin-bottom: 2px;
}
.ap-pfill {
  height: 100%; border-radius: 999px; background: #007AFF;
  transition: width .35s cubic-bezier(.4,0,.2,1);
}

/* Groupe */
.ap-grp {
  background: var(--paper);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 12px; overflow: hidden;
}

/* Lignes */
.ap-row, .ap-sel-row {
  display: flex; align-items: center;
  padding: 15px 18px; min-height: 54px;
  position: relative;
}
/* Lignes select : le lien "+ Ajouter une option" sous le select agrandit la
   cellule → on aligne en haut et on recale label/badge sur le 1er rang (select) */
.ap-sel-row { align-items: flex-start; }
.ap-sel-row .ap-rl    { padding-top: 6px; }
.ap-sel-row .ap-badge { margin-top: 4px; }
/* Police des selects cohérente partout (sections custom = Inter, comme renderStd) */
.ap-wrap select { font-family: 'Inter', sans-serif; font-size: 12px; }
.ap-row + .ap-row::before,
.ap-sel-row + .ap-row::before,
.ap-row + .ap-sel-row::before,
.ap-sel-row + .ap-sel-row::before {
  content: ''; position: absolute;
  top: 0; left: 16px; right: 0; height: .5px;
  background: rgba(0,0,0,.08);
}
.ap-rl {
  flex: 1; font-size: 15px; color: var(--ink);
  font-weight: 400; line-height: 1.35; padding-right: 12px;
}
.ap-rl em {
  display: block; font-size: 12px;
  color: var(--ink3); font-style: normal; margin-top: 1px;
}

/* Séparateur interne */
.ap-sep-row {
  padding: 7px 16px; font-size: 11px; font-weight: 600;
  color: var(--ink3); text-transform: uppercase; letter-spacing: .06em;
  background: var(--paper2); border-top: .5px solid rgba(0,0,0,.08);
}

/* Badge Standard / +Value */
.ap-badge {
  font-family: 'DM Mono', ui-monospace, Consolas, monospace;
  font-size: 9.5px;
  letter-spacing: .03em;
  padding: 3px 8px;
  border-radius: 4px;
  cursor: pointer;
  user-select: none;
  flex-shrink: 0;
  margin-right: 12px;
  transition: background-color .15s ease, color .15s ease, border-color .15s ease;
}
.ap-badge:active { transform: scale(0.96); }
.ap-badge.b-std { background: #F8F9FB; color: #94A3B8; border: 1px solid #E2E8F0; }
.ap-badge.b-pv  { background: #FAEEDA; color: #BA7517; border: 1px solid #FAC775; }

/* Label OUI / NON */
.ap-tog-lbl {
  font-size: 11px; font-weight: 600;
  min-width: 26px; text-align: right; margin-right: 8px;
  transition: color .2s;
}
.ap-tog-lbl.ton  { color: #34C759; }
.ap-tog-lbl.toff { color: #FF3B30; }

/* Toggle iOS */
.ap-tog {
  width: 38px; height: 22px; border-radius: 999px;
  background: #FF3B30; position: relative;
  cursor: pointer; flex-shrink: 0;
  transition: background .22s cubic-bezier(.4,0,.2,1);
  user-select: none;
}
.ap-tog.on { background: #34C759; }
.ap-tog-th {
  position: absolute; top: 2px; left: 2px;
  width: 18px; height: 18px; border-radius: 50%;
  background: #fff;
  box-shadow: 0 2px 5px rgba(0,0,0,.25), 0 0 0 .5px rgba(0,0,0,.06);
  transition: transform .22s cubic-bezier(.4,0,.2,1);
  pointer-events: none;
}
.ap-tog.on .ap-tog-th { transform: translateX(16px); }

/* Select */
.ap-sel-w { width: 250px; flex-shrink: 0; }
.ap-sel {
  flex-shrink: 0; width: 250px;
  background: var(--paper2); border: .5px solid rgba(0,0,0,.12);
  border-radius: 8px; outline: none;
  font-family: 'Inter', sans-serif; font-size: 12px; color: var(--ink);
  -webkit-appearance: none; appearance: none;
  cursor: pointer; padding: 7px 10px; color-scheme: light;
}

/* Observations */
.ap-obs {
  background: var(--paper); border-radius: 12px;
  border: 1px solid rgba(0,0,0,.08);
  overflow: hidden; margin-top: 6px;
}
.ap-obs-lbl {
  font-size: 11px; font-weight: 600; color: var(--ink3);
  text-transform: uppercase; letter-spacing: .07em;
  padding: 13px 16px 6px;
}
.ap-obs-ta {
  display: block; width: 100%;
  border: none; background: transparent;
  font-family: 'Inter', sans-serif; font-size: 14px; color: var(--ink);
  outline: none; resize: none; line-height: 1.55;
  padding: 0 16px 13px; min-height: 64px;
}
.ap-obs-ta::placeholder { color: var(--ink4); }

/* Flash navigation depuis la synthèse */
@keyframes row-flash {
  0%   { background: #FFF4C2; }
  100% { background: transparent; }
}
.row-flash { animation: row-flash .9s ease; }

/* ── SECTIONS PER-ROOM (menuiseries, élec, plomberie…) ── */
.piece-b {
  background: var(--paper);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 12px;
  padding: 16px;
  margin-bottom: 12px;
}
.piece-hdr { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }
.piece-ico { width: 17px; height: 17px; fill: #007AFF; flex-shrink: 0; }
.mrow {
  display: grid; gap: 8px; align-items: start;
  padding: 10px;
  background: var(--paper2);
  border-radius: 8px;
  margin-bottom: 6px;
}
.mrow-ext, .mrow-int { grid-template-columns: 2fr 1fr 1fr 1fr 1fr auto; }
.add-row {
  display: flex; align-items: center; justify-content: center; gap: 6px;
  padding: 8px 12px;
  background: transparent;
  border: 1.5px dashed var(--border2);
  border-radius: 8px;
  color: var(--ink3);
  font-size: 12px; font-weight: 600;
  cursor: pointer;
  transition: border-color .15s ease, color .15s ease;
  width: 100%; margin-top: 3px;
  font-family: 'Inter', sans-serif;
}
.add-row:hover { border-color: #007AFF; color: #007AFF; }
.add-piece {
  display: flex; align-items: center; justify-content: center; gap: 6px;
  width: 100%; padding: 12px;
  background: var(--paper);
  border: 1.5px dashed rgba(0,122,255,.35);
  border-radius: 12px;
  color: #007AFF;
  font-weight: 600; font-size: 13px;
  cursor: pointer;
  transition: background-color .15s ease, border-color .15s ease;
  font-family: 'Inter', sans-serif;
  margin-bottom: 12px;
}
.add-piece:hover { background: rgba(0,122,255,.05); }
.gl-ral {
  background: var(--paper);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 12px;
  padding: 16px;
  margin-bottom: 16px;
}
.gl-ral-t {
  font-family: 'DM Mono', ui-monospace, Consolas, monospace;
  font-size: 10px; letter-spacing: .05em; text-transform: uppercase;
  color: #64748B;
  margin-bottom: 10px;
}
.gl-ral-ta {
  width: 100%; resize: vertical;
  background: var(--paper2);
  border: 1px solid rgba(0,0,0,.1);
  border-radius: 8px;
  padding: 8px 10px !important;
  min-height: 0 !important;
}
.opt-row { display: flex; gap: 6px; margin-top: 6px; }
.csel-add-t {
  font-size: 11px; color: #007AFF;
  cursor: pointer; font-weight: 600;
  display: block; margin-top: 3px;
}
.sw-lbl { font-size: 11px; font-weight: 600; min-width: 28px; text-align: center; }
.sw-lbl.on  { color: #34C759; }
.sw-lbl.off { color: #FF3B30; }

/* ── GESTION DES LISTES ── */
.lst-info {
  background: #E6F1FB;
  border: 1px solid #B5D4F4;
  border-radius: 10px;
  padding: 12px 16px;
  margin-bottom: 18px;
  font-size: 13px;
  color: #185FA5;
}
.lst-cat {
  font-family: 'DM Mono', ui-monospace, Consolas, monospace;
  font-size: 11px; letter-spacing: .06em; text-transform: uppercase;
  color: #64748B;
  margin: 18px 0 8px;
}
.lst-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 10px;
}
.lst-b { padding: 12px; margin-bottom: 0; }
.lst-hdr { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; gap: 8px; }
.lst-lbl { font-weight: 600; font-size: 13px; color: #1E293B; }
.lst-count {
  font-family: 'DM Mono', ui-monospace, Consolas, monospace;
  font-size: 10px;
  color: var(--ink3);
  background: var(--paper2);
  padding: 2px 8px;
  border-radius: 4px;
  flex-shrink: 0;
}
.lst-count.mod { background: #E6F1FB; color: #185FA5; }
.lst-items.clamped { max-height: 120px; overflow: hidden; }
.lst-row {
  display: flex; align-items: center; gap: 6px;
  padding: 3px 0;
  border-bottom: .5px solid var(--paper2);
}
.lst-val { flex: 1; font-size: 13px; color: var(--ink); min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lst-act {
  cursor: pointer; color: var(--ink3);
  font-size: 13px; padding: 2px 4px;
  flex-shrink: 0;
  transition: color .12s ease;
}
.lst-act:hover { color: #007AFF; }
.lst-act.lst-del:hover { color: #FF3B30; }
.lst-more {
  font-size: 11px; color: #007AFF;
  cursor: pointer; display: block; margin-top: 4px;
  font-weight: 600;
}

/* Picker RAL */
.ral-w { position: relative; }
.ral-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 11px;
  background: var(--paper);
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 8px;
  cursor: pointer;
  font-size: 12px; font-weight: 500;
  transition: border-color .15s ease;
  width: 100%; color: var(--ink2);
}
.ral-btn:hover { border-color: rgba(0,122,255,.4); }
.ral-dot { width: 14px; height: 14px; border-radius: 3px; flex-shrink: 0; border: 1px solid rgba(0,0,0,.1); }
.ral-dot-e { background: repeating-conic-gradient(#E2E8F0 0% 25%, #fff 0% 50%) 50% / 8px 8px; }
.ral-dd {
  position: absolute; top: calc(100% + 4px); left: 0;
  width: 268px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 12px;
  box-shadow: 0 8px 20px -6px rgba(15,23,42,.18);
  z-index: 400; overflow: hidden;
}
.ral-swatches { display: grid; grid-template-columns: repeat(10,1fr); gap: 3px; padding: 10px; }
.ral-sw { aspect-ratio: 1; border-radius: 3px; cursor: pointer; border: 2px solid transparent; transition: transform .12s; }
.ral-sw:hover { transform: scale(1.15); }
.ral-sw.sel { border-color: #007AFF; }
.ral-ls { max-height: 150px; overflow-y: auto; border-top: 1px solid var(--border); }
.ral-op { display: flex; align-items: center; gap: 7px; padding: 7px 11px; cursor: pointer; font-size: 12px; transition: background .12s; }
.ral-op:hover { background: var(--paper2); }
.ral-op.sel { background: rgba(0,122,255,.08); }
.ral-cr { display: flex; gap: 5px; padding: 7px 11px; border-top: 1px solid var(--border); background: var(--paper2); }
.ral-cr input { flex: 1; min-width: 0; }
