/* ═══════════════════════════════════════════════
   MÓDULO STOCK / INVENTARIO
═══════════════════════════════════════════════ */
.sv-wrap { padding-bottom: 60px; }
.sv-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:20px; }
.sv-title  { display:flex; align-items:center; gap:12px; }
.sv-title h2 { font-family:var(--font-h); font-size:24px; font-weight:700; margin:0; }
.sv-title p  { margin:2px 0 0; font-size:12px; color:var(--t3); }
.sv-actions  { display:flex; gap:8px; }
.sv-btn-icon {
  width:40px; height:40px; border-radius:var(--r); border:1px solid var(--border2);
  background:var(--bg2); color:var(--t2); display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:background .2s,color .2s,border-color .2s;
}
.sv-btn-icon:hover    { background:var(--p3); border-color:var(--p); color:var(--p2); }
.sv-btn-icon.sv-act   { background:var(--p);  border-color:var(--p); color:#fff; }

/* Filtros */
.sv-filtros { display:flex; gap:8px; margin-bottom:20px; flex-wrap:wrap; align-items:center; }
/* .sv-search / .sv-clr migrados a .search-box / .search-box-clear en components.css */
.sv-sel-ubi {
  background:var(--bg2); border:1px solid var(--border2); border-radius:var(--r);
  color:var(--t1); font-size:13px; padding:10px 12px; outline:none; cursor:pointer;
  font-family:var(--font-b); transition:border-color .2s;
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 10px center; padding-right:28px;
}
.sv-sel-ubi:focus { border-color:var(--p); }
.sv-alerta-btn {
  display:flex; align-items:center; gap:6px;
  background:var(--bg2); border:1px solid var(--border2); border-radius:var(--r);
  color:var(--t3); font-size:13px; padding:10px 12px;
  cursor:pointer; transition:all .2s; font-family:var(--font-b);
}
.sv-alerta-btn.sv-alerta-on { background:rgba(249,115,22,.12); border-color:rgba(249,115,22,.5); color:#fb923c; }

/* Tabs */
.sv-tabs { display:flex; gap:6px; margin-bottom:20px; overflow-x:auto; }
.sv-tabs::-webkit-scrollbar { display:none; }
.sv-badge {
  display:inline-flex; align-items:center; justify-content:center;
  width:18px; height:18px; border-radius:50%;
  background:#f97316; color:#fff; font-size:10px; font-weight:700; margin-left:4px;
}

/* Cards de stock */
.sv-list { display:flex; flex-direction:column; gap:2px; }
.sv-card {
  display:flex; align-items:center; justify-content:space-between;
  background:var(--bg2); border:1px solid var(--border); border-left:3px solid transparent;
  padding:12px 16px; gap:12px; transition:background .15s, border-left-color .2s;
}
.sv-card:first-child { border-radius:var(--r) var(--r) 0 0; border-bottom:none; }
.sv-card:not(:first-child):not(:last-child) { border-top:none; border-bottom:none; }
.sv-card:last-child  { border-radius:0 0 var(--r) var(--r); border-top:none; }
.sv-card:only-child  { border-radius:var(--r); border:1px solid var(--border); }
.sv-card:hover       { background:var(--bg3); }
.sv-card.sv-alerta-card { border-left-color:#f97316; background:rgba(249,115,22,.04); }

.sv-left { display:flex; align-items:center; gap:10px; flex:0 0 auto; max-width:200px; }
.sv-img  { width:44px; height:44px; border-radius:var(--r2); overflow:hidden; flex-shrink:0; }
.sv-img img { width:100%; height:100%; object-fit:cover; }
.sv-img-ph {
  width:100%; height:100%; background:var(--bg3); border-radius:var(--r2);
  display:flex; align-items:center; justify-content:center;
}
.sv-info { display:flex; flex-direction:column; gap:1px; min-width:0; }
.sv-prod { font-size:13px; font-weight:600; color:var(--t1); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sv-sku  { font-size:11px; color:var(--t3); font-family:monospace; }
.sv-ubi  { font-size:11px; color:var(--t3); display:flex; align-items:center; gap:3px; }

/* Metricas */
.sv-metrics { display:flex; align-items:center; gap:4px; flex:1; justify-content:flex-end; flex-wrap:nowrap; overflow-x:auto; }
.sv-met     { display:flex; flex-direction:column; align-items:center; min-width:58px; padding:4px 8px; border-radius:var(--r2); }
.sv-met.sv-met-ro     { background:var(--bg3); opacity:.7; }
.sv-met.sv-met-alerta { background:rgba(249,115,22,.08); border-radius:var(--r2); }
.sv-met-val { font-size:14px; font-weight:700; color:var(--t1); }
.sv-met-lbl { font-size:10px; color:var(--t3); text-transform:uppercase; letter-spacing:.04em; }
.sv-met-min { font-size:9px; color:#f97316; margin-top:1px; }

@media (max-width: 600px) {
  .sv-card    { flex-wrap:wrap; align-items:flex-start; padding:10px 12px; gap:8px; }
  .sv-left    { max-width:100%; flex:1 1 100%; }
  .sv-prod    { white-space:normal; overflow:visible; text-overflow:clip; font-size:13px; }
  .sv-metrics { flex:1 1 100%; justify-content:space-between; overflow-x:visible; flex-wrap:wrap;
                padding-top:8px; border-top:1px solid var(--border); }
  .sv-met     { min-width:0; flex:1 1 18%; padding:4px 4px; }
  .sv-met-val { font-size:13px; }
}
.sv-editable {
  display:flex; align-items:center; gap:4px;
  border-bottom:1px dashed var(--p); padding-bottom:1px; cursor:pointer;
}
.sv-oferta-val { color:var(--t3); }
.sv-oferta-on  { color:#4ade80 !important; }
.sv-edit-input {
  width:72px; background:var(--bg3); border:1.5px solid var(--p);
  border-radius:var(--r2); color:var(--t1); font-size:14px; font-weight:700;
  padding:3px 6px; outline:none; text-align:center; font-family:var(--font-b);
}

/* Ordenes cards */
.sv-ord-card {
  background:var(--bg2); border:1px solid var(--border); border-radius:var(--r);
  padding:16px; cursor:pointer; transition:background .2s, transform .15s; margin-bottom:10px;
}
.sv-ord-card:hover { background:var(--bg3); transform:translateY(-1px); border-color:var(--border2); }
.sv-ord-top  { display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.sv-ord-id   { font-size:12px; color:var(--t3); font-weight:600; }
/* Estado de orden: migrado a .badge + .badge-pending/progress/completed/cancelled */
.sv-ord-tipo {
  font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.05em;
  padding:2px 8px; border-radius:4px; margin-right:8px;
}
.sv-tipo-transferencia { background:rgba(56,189,248,.12); color:#38bdf8; }
.sv-tipo-surtir        { background:rgba(74,222,128,.12); color:#4ade80; }
.sv-tipo-devolucion    { background:rgba(96,165,250,.12); color:#60a5fa; }
.sv-tipo-salida        { background:rgba(251,146,60,.12); color:#fb923c; }
.sv-tipo-merma         { background:rgba(248,113,113,.12); color:#f87171; }
.sv-ord-ruta { display:flex; align-items:center; gap:8px; margin-bottom:8px; }
.sv-ord-ubi  { font-size:14px; font-weight:600; color:var(--t1); }
.sv-ord-meta { display:flex; gap:14px; font-size:12px; color:var(--t3); flex-wrap:wrap; }

/* Detalle orden */
.sv-det-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.sv-det-ruta {
  display:flex; align-items:center; gap:14px; margin-bottom:12px;
  background:var(--bg2); border:1px solid var(--border); border-radius:var(--r); padding:12px 16px;
}
.sv-det-ubi       { display:flex; flex-direction:column; }
.sv-det-ubi small { font-size:11px; color:var(--t3); }
.sv-det-ubi strong{ font-size:15px; font-weight:600; }
.sv-det-items     { margin-bottom:16px; }
.sv-det-item {
  display:flex; align-items:center; gap:10px; padding:10px 0;
  border-bottom:1px solid var(--border);
}
.sv-det-item:last-child { border-bottom:none; }
.sv-det-item-name { flex:1; font-size:14px; font-weight:500; }
.sv-det-item-qty  { font-size:14px; font-weight:700; color:var(--t1); min-width:50px; text-align:right; }

/* Incidencias */
.sv-inc-section { margin:16px 0; }
.sv-inc-title { font-size:12px; font-weight:700; color:var(--t3); text-transform:uppercase; letter-spacing:.05em; margin-bottom:8px; }
.sv-inc-row {
  display:flex; align-items:center; gap:8px; padding:8px 12px; margin-bottom:6px;
  background:var(--bg2); border:1px solid var(--border); border-radius:var(--r2);
}
.sv-inc-row.sv-inc-confirmed { border-color:rgba(74,222,128,.3); background:rgba(74,222,128,.05); }
.sv-inc-row.sv-inc-pending   { border-color:rgba(249,115,22,.3); background:rgba(249,115,22,.05); }
.sv-inc-info { flex:1; font-size:13px; }
/* Badges de incidencias: migrados a .badge + .badge-completed/pending */
.sv-btn-sm {
  padding:6px 12px; border-radius:var(--r2); border:none; font-size:12px;
  font-weight:600; cursor:pointer; font-family:var(--font-b); transition:opacity .2s;
}
.sv-btn-sm:hover { opacity:.8; }
.sv-btn-sm.sv-btn-confirm { background:var(--p); color:#fff; }
.sv-btn-sm.sv-btn-report  { background:rgba(249,115,22,.15); color:#fb923c; border:1px solid rgba(249,115,22,.3); }

/* Codigo salida */
.sv-code-box {
  background:var(--bg2); border:2px dashed var(--p); border-radius:var(--r);
  padding:16px; text-align:center; margin:12px 0;
}
.sv-code-val { font-size:32px; font-weight:700; font-family:monospace; color:var(--p2); letter-spacing:8px; }
.sv-code-lbl { font-size:12px; color:var(--t3); margin-top:4px; }
.sv-code-input {
  width:180px; text-align:center; font-size:24px; font-weight:700;
  letter-spacing:6px; font-family:monospace; padding:12px;
}
.sv-code-ok { color:var(--ok); font-size:13px; font-weight:600; margin-top:8px; }

/* -- MODALES: migrados a components.css (.modal, .modal-backdrop, .modal-handle, .modal-title, .modal-sub, .modal-tall) -- */

/* Formularios en modal */
.sv-fg       { margin-bottom:14px; }
.sv-fg label {
  display:block; font-size:11px; font-weight:600; color:var(--t3);
  text-transform:uppercase; letter-spacing:.06em; margin-bottom:6px;
}
.sv-opt { font-weight:400; text-transform:none; letter-spacing:0; color:var(--t3); }
.sv-input, .sv-select, .sv-textarea {
  width:100%; background:var(--bg2); border:1px solid var(--border2);
  border-radius:var(--r2); color:var(--t1); font-size:15px; font-family:var(--font-b);
  padding:11px 14px; outline:none; box-sizing:border-box; transition:border-color .2s;
}
.sv-input:focus, .sv-select:focus, .sv-textarea:focus {
  border-color:var(--p); box-shadow:0 0 0 3px var(--p3);
}
.sv-select {
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center; padding-right:36px;
}
.sv-textarea { resize:none; }
.sv-row      { display:flex; gap:10px; }
.sv-row .sv-fg { flex:1; }

/* Items orden */
.sv-hint-sel { font-size:13px; color:var(--t3); padding:8px 0; }
.sv-items    { display:flex; flex-direction:column; gap:8px; }
.sv-item-row { display:flex; gap:8px; align-items:center; }
.sv-item-sel { flex:1; font-size:13px; padding:9px 12px; }
.sv-item-qty { width:82px; font-size:14px; text-align:center; }
.sv-btn-rm   {
  width:32px; height:32px; border-radius:var(--r2); flex-shrink:0;
  background:rgba(239,68,68,.1); border:1px solid rgba(239,68,68,.3);
  color:#f87171; font-size:18px; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
}
.sv-btn-add  {
  background:none; border:1.5px dashed var(--p); border-radius:var(--r2);
  color:var(--p2); font-size:13px; font-weight:600; padding:9px; cursor:pointer;
  transition:background .2s; font-family:var(--font-b); width:100%;
}
.sv-btn-add:hover { background:var(--p3); }

/* Nuevo en PV — precios sugeridos */
.sv-item-wrap   { display:flex; flex-direction:column; gap:0; }
.sv-nuevo-precio {
  display:flex; flex-direction:column; gap:6px;
  background:var(--bg3); border:1px dashed var(--p);
  border-radius:0 0 var(--r2) var(--r2); padding:8px 10px 8px;
  margin-top:-2px;
}
.sv-nuevo-badge {
  font-size:10px; font-weight:700; color:var(--p2);
  text-transform:uppercase; letter-spacing:.06em;
}
.sv-nuevo-fields { display:flex; gap:6px; flex-wrap:wrap; }
.sv-nuevo-met {
  display:flex; flex-direction:column; align-items:center;
  min-width:72px; flex:1;
  background:var(--bg2); border:1px solid var(--border2);
  border-radius:var(--r2); padding:5px 8px 4px;
  transition:border-color .2s;
}
.sv-nuevo-met:focus-within { border-color:var(--p); box-shadow:0 0 0 2px var(--p3); }
.sv-nuevo-met input {
  width:100%; background:none; border:none; outline:none;
  text-align:center; font-size:14px; font-weight:700;
  color:var(--t1); padding:0; min-width:0; font-family:var(--font-b);
  -moz-appearance:textfield;
}
.sv-nuevo-met input::-webkit-outer-spin-button,
.sv-nuevo-met input::-webkit-inner-spin-button { -webkit-appearance:none; margin:0; }
.sv-nuevo-met input::placeholder { color:var(--t3); font-weight:400; font-size:13px; }
.sv-nuevo-met .sv-met-lbl { margin-top:2px; }

/* Oferta */
.sv-oferta-hint      { font-size:13px; color:var(--t3); margin-bottom:14px; font-style:italic; }
.sv-oferta-hint.warn { color:#fb923c; }

/* Botones */
.sv-btn-primary {
  width:100%; padding:14px; border-radius:var(--r); border:none;
  background:linear-gradient(135deg, var(--p), #5b21b6); color:#fff;
  font-size:15px; font-weight:600; font-family:var(--font-h);
  cursor:pointer; transition:opacity .2s, transform .15s;
  display:flex; align-items:center; justify-content:center; gap:8px; margin-top:8px;
}
.sv-btn-primary:hover:not(:disabled) { opacity:.9; transform:translateY(-1px); }
.sv-btn-primary:disabled { opacity:.5; cursor:not-allowed; }
.sv-btn-secondary {
  width:100%; padding:12px; border-radius:var(--r); margin-top:8px;
  border:1px solid var(--border2); background:var(--bg2);
  color:var(--t1); font-size:14px; font-weight:600; cursor:pointer;
  transition:background .2s; font-family:var(--font-b);
}
.sv-btn-secondary:hover { background:var(--bg3); }
.sv-btn-danger {
  width:100%; padding:12px; border-radius:var(--r); margin-top:8px;
  border:1px solid rgba(239,68,68,.4); background:rgba(239,68,68,.1);
  color:#f87171; font-size:14px; font-weight:600; cursor:pointer;
  transition:background .2s; font-family:var(--font-b);
}
.sv-btn-danger:hover { background:rgba(239,68,68,.2); }

/* Loading y estados */
.sv-loading { display:flex; justify-content:center; align-items:center; padding:48px; }
.sv-loading .spinner { width:32px; height:32px; border-width:3px; border-color:var(--border2); border-top-color:var(--p); }
/* .sv-spin migrado a .spinner en components.css */

/* keyframes sv-fadeIn / sv-slideUp: migrados a components.css como modal-fadeIn / modal-slideUp */
