:root {
  --sp-navy:#1B2C5E; --sp-blue:#1E60AB; --sp-cyan:#1FA9E0; --sp-cyan-soft:#E8F4FB;
  --sp-gray-50:#F7F9FB; --sp-gray-100:#EEF2F6; --sp-gray-200:#D5DAE0;
  --sp-gray-400:#94A3B0; --sp-gray-600:#4D5B6E; --sp-gray-900:#1A2332;
  --green:#16A085; --green-soft:#E6F5F1; --amber:#E59500; --amber-soft:#FFF5E5;
  --red:#C04545; --red-soft:#FCEAEA;
  --shadow-sm:0 1px 2px rgba(27,44,94,.04); --shadow-md:0 4px 12px rgba(27,44,94,.06);
  --sidebar-w:236px;
}
* { box-sizing:border-box; margin:0; padding:0; }
body { font-family:'Inter',-apple-system,system-ui,sans-serif; background:var(--sp-gray-50);
  color:var(--sp-gray-900); font-size:14px; line-height:1.5; -webkit-font-smoothing:antialiased; }
a { text-decoration:none; color:inherit; }

/* Layout */
.layout { display:flex; min-height:100vh; }
.sidebar { width:var(--sidebar-w); background:#fff; border-right:1px solid var(--sp-gray-200);
  position:fixed; top:0; bottom:0; left:0; display:flex; flex-direction:column; padding:18px 14px; }
.brand { display:flex; align-items:center; gap:10px; padding:4px 8px 18px; }
.brand-logo { width:34px; height:34px; border-radius:7px; background:linear-gradient(135deg,var(--sp-cyan),var(--sp-navy));
  display:flex; align-items:center; justify-content:center; color:#fff; font-weight:700; font-size:12px; }
.brand-logo-img { width:34px; height:34px; border-radius:7px; object-fit:cover; }
.nav .soon { display:flex; align-items:center; gap:9px; padding:8px 10px; border-radius:7px;
  color:var(--sp-gray-400); font-size:13.5px; font-weight:500; margin:1px 0; cursor:default; }
.badge-soon { margin-left:auto; font-size:9px; font-weight:700; text-transform:uppercase; letter-spacing:.4px;
  background:var(--sp-gray-100); color:var(--sp-gray-400); padding:2px 6px; border-radius:8px; }
.brand-text .top { font-size:10px; color:var(--sp-gray-400); font-weight:600; letter-spacing:.5px; text-transform:uppercase; }
.brand-text .bot { font-size:15px; color:var(--sp-navy); font-weight:700; }
.nav-group { margin-top:14px; }
.nav-group .label { font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:.6px;
  color:var(--sp-gray-400); padding:6px 10px; }
.nav a { display:flex; align-items:center; gap:9px; padding:8px 10px; border-radius:7px; color:var(--sp-gray-600);
  font-size:13.5px; font-weight:500; margin:1px 0; }
.nav a:hover { background:var(--sp-gray-100); color:var(--sp-navy); }
.nav a.active { background:var(--sp-cyan-soft); color:var(--sp-navy); font-weight:600; }
.nav a .ic { width:18px; text-align:center; opacity:.8; }
.sidebar-foot { margin-top:auto; padding:10px; border-top:1px solid var(--sp-gray-100); display:flex; align-items:center; gap:10px; }
.avatar { width:32px; height:32px; border-radius:50%; background:linear-gradient(135deg,var(--sp-blue),var(--sp-navy));
  color:#fff; display:flex; align-items:center; justify-content:center; font-weight:600; font-size:12px; }
.u-name { font-size:12.5px; font-weight:600; color:var(--sp-navy); }
.u-role { font-size:11px; color:var(--sp-gray-400); }

.main { margin-left:var(--sidebar-w); flex:1; display:flex; flex-direction:column; }
.topbar { height:60px; background:#fff; border-bottom:1px solid var(--sp-gray-200); display:flex; align-items:center;
  padding:0 28px; position:sticky; top:0; z-index:10; }
.topbar h1 { font-size:18px; color:var(--sp-navy); font-weight:700; letter-spacing:-.3px; }
.content { padding:26px 32px 50px; max-width:1600px; }
.sub { color:var(--sp-gray-600); font-size:13.5px; margin:-6px 0 20px; }

.dev-banner { background:var(--amber-soft); border:1px solid #F0D9A8; color:#8a5a00; font-size:12.5px;
  padding:8px 28px; }

/* Tarjetas KPI */
.kpis { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-bottom:24px; }
.kpi { background:#fff; border:1px solid var(--sp-gray-200); border-radius:12px; padding:18px 20px; box-shadow:var(--shadow-sm); }
.kpi .n { font-size:30px; font-weight:700; color:var(--sp-navy); letter-spacing:-.5px; }
.kpi .l { font-size:12.5px; color:var(--sp-gray-600); font-weight:500; margin-top:2px; }
.kpi.ok .n { color:var(--green); } .kpi.warn .n { color:var(--amber); } .kpi.bad .n { color:var(--red); }

.card { background:#fff; border:1px solid var(--sp-gray-200); border-radius:12px; box-shadow:var(--shadow-sm); padding:18px 22px; }
.card h3 { color:var(--sp-navy); font-size:15px; font-weight:700; margin-bottom:6px; }
.card p { color:var(--sp-gray-600); font-size:13px; }
.card-head { display:flex; justify-content:space-between; align-items:flex-start; gap:14px; padding-bottom:12px; margin-bottom:14px; }
.card-head .ref { font-size:14.5px; }
.card-body { font-size:13.5px; }
.alert { background:var(--red-soft); border:1px solid #f3c9c9; color:#8a2b2b; border-radius:10px; padding:12px 16px; font-size:13px; margin-bottom:18px; }
.muted { color:var(--sp-gray-400); }

/* KPIs en 4 columnas (variante) */
.kpis.k4 { grid-template-columns:repeat(4,1fr); }

/* Tabla */
.tablecard { background:#fff; border:1px solid var(--sp-gray-200); border-radius:12px; box-shadow:var(--shadow-sm); overflow:hidden; }
.tablecard .thead { padding:14px 20px; border-bottom:1px solid var(--sp-gray-100); display:flex; justify-content:space-between; align-items:center; }
.tablecard .thead h3 { color:var(--sp-navy); font-size:15px; font-weight:700; }
.tablecard .thead .meta { color:var(--sp-gray-400); font-size:12px; }
table { width:100%; border-collapse:collapse; }
th { text-align:left; padding:10px 20px; font-size:11px; color:var(--sp-gray-400); font-weight:700; text-transform:uppercase;
  letter-spacing:.6px; background:var(--sp-gray-50); border-bottom:1px solid var(--sp-gray-200); }
td { padding:12px 20px; border-bottom:1px solid var(--sp-gray-100); font-size:13px; vertical-align:middle; }
tr:last-child td { border-bottom:none; }
td.right, th.right { text-align:right; }
.mono { font-family:'JetBrains Mono',monospace; font-size:12.5px; color:var(--sp-gray-600); }
.ref { font-weight:600; color:var(--sp-navy); }
.motivo { display:inline-flex; align-items:center; gap:6px; font-size:11.5px; font-weight:700; padding:3px 9px; border-radius:12px; }
.motivo.cumpl { background:var(--amber-soft); color:var(--amber); }
.motivo.canc { background:var(--red-soft); color:var(--red); }
.motivo.reas { background:var(--sp-cyan-soft); color:var(--sp-blue); }
.btn { border:none; border-radius:8px; padding:7px 13px; font-size:12.5px; font-weight:600; cursor:pointer; font-family:inherit; }
.btn-primary { background:var(--sp-blue); color:#fff; }
.btn:disabled { opacity:.5; cursor:not-allowed; }
.empty { padding:30px 20px; text-align:center; color:var(--sp-gray-400); font-size:13.5px; }
.pill { display:inline-flex; align-items:center; font-size:11.5px; font-weight:600; padding:3px 9px; border-radius:12px; background:var(--sp-gray-100); color:var(--sp-gray-600); }
.section-title { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.6px; color:var(--sp-gray-400); margin:24px 0 12px; }
.atencion { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; margin-bottom:6px; }
.acard { background:#fff; border:1px solid var(--sp-gray-200); border-radius:12px; box-shadow:var(--shadow-sm); padding:16px 20px; display:flex; align-items:center; gap:16px; }
.acard .big { font-size:26px; font-weight:700; color:var(--sp-navy); min-width:46px; }
.acard .txt .t { font-weight:600; color:var(--sp-navy); font-size:13.5px; }
.acard .txt .s { color:var(--sp-gray-600); font-size:12px; }

/* Login */
.login-body { display:flex; align-items:center; justify-content:center; min-height:100vh;
  background:linear-gradient(135deg,#eef4fb,#f7f9fb); }
.login-card { background:#fff; border:1px solid var(--sp-gray-200); border-radius:18px; box-shadow:var(--shadow-lg);
  width:440px; max-width:94vw; padding:42px 40px 32px; }
.login-brand { display:flex; flex-direction:column; align-items:center; gap:12px; margin-bottom:24px; }
.login-brand img { width:88px; height:88px; border-radius:18px; object-fit:cover; box-shadow:var(--shadow-sm); }
.lb-top { font-size:11px; color:var(--sp-gray-400); font-weight:600; letter-spacing:.8px; text-transform:uppercase; text-align:center; }
.lb-bot { font-size:22px; color:var(--sp-navy); font-weight:700; text-align:center; }
.login-h1 { font-size:25px; color:var(--sp-navy); font-weight:700; text-align:center; }
.login-sub { color:var(--sp-gray-600); font-size:13.5px; margin-bottom:22px; text-align:center; }
.login-error { background:var(--red-soft); border:1px solid #f3c9c9; color:#8a2b2b; border-radius:9px; padding:10px 13px; font-size:12.5px; margin-bottom:14px; }
.login-label { display:block; font-size:12px; font-weight:600; color:var(--sp-gray-600); margin:10px 0 5px; }
.login-input { width:100%; padding:10px 12px; border:1px solid var(--sp-gray-200); border-radius:9px; font-size:14px; font-family:inherit; }
.login-input:focus { outline:none; border-color:var(--sp-blue); box-shadow:0 0 0 3px var(--sp-cyan-soft); }
.login-btn { width:100%; margin-top:18px; background:var(--sp-blue); color:#fff; border:none; border-radius:9px;
  padding:11px; font-size:14px; font-weight:600; cursor:pointer; font-family:inherit; }
.login-btn:hover { background:var(--sp-navy); }
.login-foot { text-align:center; color:var(--sp-gray-400); font-size:12px; margin-top:16px; }
.logout-link { color:var(--sp-gray-400); font-size:11px; }
.logout-link:hover { color:var(--sp-blue); }

/* Progreso + estado de entrega (vista asesor) */
.prog { width:120px; }
.prog-bar { height:7px; background:var(--sp-gray-100); border-radius:6px; overflow:hidden; }
.prog-bar > span { display:block; height:100%; background:var(--sp-blue); }
.prog-txt { font-size:11px; color:var(--sp-gray-400); margin-top:3px; }
.epill { display:inline-flex; align-items:center; gap:6px; font-size:11.5px; font-weight:700; padding:3px 10px; border-radius:12px; }
.epill .dot { width:8px; height:8px; border-radius:50%; }
.epill.entregado { background:var(--green-soft); color:var(--green); } .epill.entregado .dot{ background:var(--green); }
.epill.parcial { background:var(--amber-soft); color:var(--amber); } .epill.parcial .dot{ background:var(--amber); }
.epill.en_proceso { background:var(--sp-cyan-soft); color:var(--sp-blue); } .epill.en_proceso .dot{ background:var(--sp-blue); }
.epill.remis { background:#eef2ff; color:#4338ca; } .epill.remis .dot{ background:#4338ca; }
.epill.canc { background:var(--red-soft); color:var(--red); } .epill.canc .dot{ background:var(--red); }
.cancel-tag { font-size:10.5px; font-weight:700; color:var(--red); background:var(--red-soft); padding:2px 7px; border-radius:8px; margin-left:6px; }

/* Chips de filtro */
.chips { display:inline-flex; gap:6px; }
.chip { border:1px solid var(--sp-gray-200); background:#fff; color:var(--sp-gray-600); border-radius:14px;
  padding:5px 12px; font-size:12.5px; font-weight:600; cursor:pointer; font-family:inherit; }
.chip:hover { background:var(--sp-gray-50); }
.chip.on { background:var(--sp-cyan-soft); border-color:#cde7f6; color:var(--sp-navy); }
.chip .muted { font-weight:500; }
.volver-bar { padding:2px 0 12px; margin-bottom:4px; }
.bodega-ok, .bodega-parcial { display:flex; align-items:center; gap:8px; font-size:13px; font-weight:600; padding:8px 12px; border-radius:8px; margin-bottom:6px; }
.bodega-ok { background:var(--green-soft); color:var(--green); }
.bodega-ok .dot { width:8px; height:8px; border-radius:50%; background:var(--green); }
.bodega-parcial { background:var(--amber-soft); color:var(--amber); }
.bodega-parcial .dot { width:8px; height:8px; border-radius:50%; background:var(--amber); }
.nota-horizonte { font-size:12px; color:var(--sp-gray-600); background:var(--sp-gray-50); border-left:3px solid var(--sp-gray-200); padding:6px 10px; border-radius:6px; margin-bottom:6px; }
.linea-datos { display:grid; grid-template-columns:repeat(auto-fit, minmax(150px, 1fr)); gap:14px 24px; margin-bottom:14px; }
.linea-datos > div { display:flex; flex-direction:column; gap:3px; padding:8px 12px; background:var(--sp-gray-50); border-radius:8px; }
.linea-datos .lbl { font-size:10.5px; color:var(--sp-gray-400); font-weight:700; text-transform:uppercase; letter-spacing:.5px; }
.linea-datos .val { font-size:14px; color:var(--sp-gray-900); font-weight:600; }
th.sortable { cursor:pointer; user-select:none; }
th.sortable:hover { color:var(--sp-blue); }
th.sortable.sort-asc::after { content:" ▲"; font-size:9px; }
th.sortable.sort-desc::after { content:" ▼"; font-size:9px; }
.filtros-der { display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.tipo-filtro { font-size:12.5px; color:var(--sp-gray-600); display:inline-flex; align-items:center; gap:8px; }
.tipo-filtro select { padding:6px 10px; border:1px solid var(--sp-gray-200); border-radius:8px; font-size:13px;
  font-family:inherit; color:var(--sp-gray-900); background:#fff; cursor:pointer; }

/* Mensajes flash */
.flash { border-radius:9px; padding:11px 15px; font-size:13px; margin-bottom:8px; }
.flash.ok { background:var(--green-soft); border:1px solid #bfe6da; color:#0f6b58; }
.flash.error { background:var(--red-soft); border:1px solid #f3c9c9; color:#8a2b2b; }

/* Detalle OC: cabecera + formulario de captura */
.oc-head { background:linear-gradient(135deg,var(--sp-navy),var(--sp-blue)); color:#fff; border-radius:12px; padding:18px 22px; margin-bottom:18px; display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; }
.oc-head .doc { font-size:20px; font-weight:700; }
.oc-head .sub2 { font-size:12.5px; opacity:.9; margin-top:2px; }
.oc-head .amb { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.5px; background:rgba(255,255,255,.18); padding:4px 10px; border-radius:10px; align-self:center; }
.capture { background:#fff; border:1px solid var(--sp-gray-200); border-radius:12px; box-shadow:var(--shadow-sm); padding:16px 20px; margin-top:16px; }
.capture h3 { color:var(--sp-navy); font-size:14.5px; font-weight:700; margin-bottom:12px; }
.capture .row { display:flex; gap:14px; flex-wrap:wrap; align-items:flex-end; }
.fld { display:flex; flex-direction:column; gap:4px; }
.fld label { font-size:11.5px; font-weight:600; color:var(--sp-gray-600); }
.fld input, .fld select, .fld textarea { padding:8px 11px; border:1px solid var(--sp-gray-200); border-radius:8px; font-size:13px; font-family:inherit; }
.fld select { min-width:230px; } .fld input[type=date]{ min-width:150px; }
.chk { width:16px; height:16px; accent-color:var(--sp-blue); }

/* Captura del comprador: tira de totales + layout tabla/panel lateral */
.oc-meta-strip { display:flex; flex-wrap:wrap; gap:10px 32px; background:#fff; border:1px solid var(--sp-gray-200);
  border-radius:12px; box-shadow:var(--shadow-sm); padding:12px 20px; margin-bottom:16px; }
.oc-meta-strip > div { display:flex; flex-direction:column; gap:2px; }
.oc-meta-strip .lbl { font-size:10.5px; color:var(--sp-gray-400); font-weight:700; text-transform:uppercase; letter-spacing:.5px; }
.oc-meta-strip .val { font-size:14.5px; color:var(--sp-navy); font-weight:700; }
.capture-grid { display:grid; grid-template-columns:1fr 360px; gap:18px; align-items:start; }
.capture-side { background:#fff; border:1px solid var(--sp-gray-200); border-radius:12px; box-shadow:var(--shadow-sm);
  padding:18px 20px; position:sticky; top:16px; max-height:calc(100vh - 32px); overflow:auto; }
.capture-side h3 { color:var(--sp-navy); font-size:14.5px; font-weight:700; margin-bottom:4px; }
.capture-side .fld { margin-bottom:12px; }
.capture-side .fld select, .capture-side .fld input, .capture-side .fld textarea { width:100%; min-width:0; }
.form-hint { font-size:11px; color:var(--sp-gray-400); margin-top:3px; }
.combo-list { list-style:none; margin:4px 0 0; padding:4px; border:1px solid var(--sp-gray-200); border-radius:8px;
  max-height:220px; overflow:auto; background:#fff; box-shadow:var(--shadow-sm); }
.combo-list li { padding:7px 10px; border-radius:6px; font-size:13px; cursor:pointer; color:var(--sp-gray-900); }
.combo-list li:hover { background:var(--sp-cyan-soft); color:var(--sp-navy); }
.req { color:var(--red); margin-left:2px; }
.fld input.invalido { border-color:var(--red); box-shadow:0 0 0 3px var(--red-soft); }
@media (max-width:1100px){ .capture-grid { grid-template-columns:1fr; } .capture-side { position:static; } }

/* Valor destacado (tablero) */
.bigvalue { background:linear-gradient(135deg,var(--sp-navy),var(--sp-blue)); color:#fff; border-radius:12px;
  padding:18px 22px; margin-bottom:20px; box-shadow:var(--shadow-sm); }
.bigvalue .bv-label { font-size:12px; opacity:.85; font-weight:500; text-transform:uppercase; letter-spacing:.5px; }
.bigvalue .bv-num { font-size:30px; font-weight:700; letter-spacing:-.5px; margin-top:3px; }
