/* ============================================================
   CAPTA web — Diseño "Timeline" (Sesión 38).
   El listado es un FEED / línea de tiempo. Theme-first: claro + oscuro.
   TODAS las clases que usa app.js y los modales se conservan, restyleados.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;450;500;600;700;800&display=swap');

:root{
  --font:'Inter','Segoe UI',-apple-system,system-ui,sans-serif;
  --r-sm:10px; --r-md:13px; --r-lg:18px; --r-xl:22px; --r-pill:999px;
}

/* ---------- OSCURO (default) ---------- */
html[data-theme="dark"], :root{
  color-scheme:dark;
  --bg:#0C0D14; --panel:#14151F; --panel-2:#171823; --head:#1B1D46;
  --line:#262838; --line-2:#1F2130; --rail:#2A2C3E;
  --tx:#F1F2F8; --tx2:#A9ABC2; --tx3:#74768C;
  --bd:rgba(255,255,255,.10); --bd2:rgba(255,255,255,.17);
  --input:rgba(0,0,0,.26); --hover:rgba(255,255,255,.05); --zebra:rgba(255,255,255,.022);

  --acc1:#818CF8; --acc2:#A5B4FC; --grad:linear-gradient(145deg,#6366F1,#818CF8);
  --acc-soft:#1E1E3A; --acc-ring:rgba(129,140,248,.36); --on-accent:#fff;

  --ok:#4ADE80; --okbg:#10301E;
  --pend:#FBBF24; --pendbg:#3A2E10;
  --cola:#60A5FA; --colabg:#16263F;
  --lib:#FB923C; --libbg:#3A2410;
  --err:#F87171; --errbg:#3A1717;

  --pdf-bg:#33384c;
  --shadow:0 1px 2px rgba(0,0,0,.4), 0 14px 36px -16px rgba(0,0,0,.7);
  --shadow-pop:0 30px 70px -24px rgba(0,0,0,.85);
}

/* ---------- CLARO ---------- */
html[data-theme="light"]{
  color-scheme:light;
  --bg:#F6F7FB; --panel:#FFFFFF; --panel-2:#FBFBFE; --head:#FFFFFF;
  --line:#E7E8F0; --line-2:#EFF0F6; --rail:#E2E3ED;
  --tx:#15161D; --tx2:#52546A; --tx3:#878AA0;
  --bd:rgba(20,24,60,.11); --bd2:rgba(20,24,60,.17);
  --input:rgba(20,24,60,.04); --hover:rgba(20,24,60,.035); --zebra:rgba(20,24,60,.024);

  --acc1:#4F46E5; --acc2:#6366F1; --grad:linear-gradient(145deg,#4F46E5,#6366F1);
  --acc-soft:#EEF2FF; --acc-ring:rgba(79,70,229,.32); --on-accent:#fff;

  --ok:#15803D; --okbg:#DCFCE7;
  --pend:#D97706; --pendbg:#FEF3C7;
  --cola:#2563EB; --colabg:#DBEAFE;
  --lib:#C2410C; --libbg:#FFEDD5;
  --err:#DC2626; --errbg:#FEE2E2;

  --pdf-bg:#33384c;
  --shadow:0 1px 2px rgba(20,22,40,.04), 0 8px 24px -12px rgba(20,22,40,.12);
  --shadow-pop:0 24px 60px -22px rgba(31,28,90,.35);
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--font);
  background:var(--bg); color:var(--tx); min-height:100vh;
  line-height:1.5; letter-spacing:-.01em;
  -webkit-font-smoothing:antialiased;
  transition:background-color .3s, color .25s;
}
.tnum{font-variant-numeric:tabular-nums;letter-spacing:0}
button{font-family:inherit;cursor:pointer;color:inherit;border:none;background:none}
a{color:inherit;text-decoration:none}
input,select{font-family:inherit}
::selection{background:var(--acc-ring)}
svg{display:block}
.ico-svg{width:18px;height:18px;stroke:currentColor;stroke-width:1.9;fill:none;stroke-linecap:round;stroke-linejoin:round}
.muted{color:var(--tx2)}
:focus-visible{outline:2.5px solid var(--acc1);outline-offset:2px;border-radius:8px}
@media (prefers-reduced-motion: reduce){ *{transition:none!important;animation:none!important} }

/* ============================ SHELL ============================ */
.shell{max-width:1320px;margin:0 auto;padding:0 28px 64px}

/* ============================ TOPBAR ============================ */
.topbar{
  display:flex;align-items:center;gap:18px;
  padding:18px 0 16px;position:sticky;top:0;z-index:40;
  background:linear-gradient(var(--bg) 72%, transparent);
  backdrop-filter:blur(2px);
}
.brand{display:flex;align-items:center;gap:12px}
.brand .logo{
  width:42px;height:42px;border-radius:13px;flex-shrink:0;overflow:hidden;
  background:var(--grad);display:grid;place-items:center;color:#fff;
  box-shadow:0 8px 20px -8px var(--acc-ring), inset 0 1px 0 rgba(255,255,255,.3);
}
.brand .logo img{width:42px;height:42px;object-fit:cover}
.brand h1{font-size:17px;font-weight:800;letter-spacing:-.03em;line-height:1.1}
.brand .bsub{font-size:11.5px;color:var(--tx3);font-weight:500;letter-spacing:.02em}

.nav{display:flex;gap:4px;margin-left:8px}
.nav-btn{
  display:flex;align-items:center;gap:7px;
  padding:9px 13px;border-radius:11px;font-size:13.5px;font-weight:550;
  color:var(--tx2);transition:all .16s ease;
}
.nav-btn .ico-svg{width:16px;height:16px;color:var(--tx3)}
.nav-btn:hover{background:var(--panel);color:var(--tx);box-shadow:var(--shadow)}
.nav-btn:hover .ico-svg{color:var(--acc1)}
.nav-btn.active{background:var(--grad);color:#fff;box-shadow:0 8px 18px -8px var(--acc-ring)}
.nav-btn.active .ico-svg{color:#fff}

.spacer{flex:1}

.theme-toggle{
  width:64px;height:38px;border-radius:var(--r-pill);border:1px solid var(--bd2);
  background:var(--panel);position:relative;display:flex;align-items:center;padding:0 6px;
  box-shadow:var(--shadow);transition:background .2s}
.theme-toggle .t-ic{position:absolute;display:flex;color:var(--tx3)}
.theme-toggle .t-ic.sun{left:10px} .theme-toggle .t-ic.moon{right:10px}
.theme-toggle .t-ic .ico-svg{width:15px;height:15px}
.theme-toggle .knob{width:28px;height:28px;border-radius:50%;background:var(--grad);
  display:flex;align-items:center;justify-content:center;z-index:1;
  box-shadow:0 4px 12px -3px rgba(0,0,0,.4);transition:transform .26s cubic-bezier(.5,1.4,.5,1);
  transform:translateX(28px)}
.theme-toggle .knob .ico-svg{width:15px;height:15px;stroke:#fff}
html[data-theme="light"] .theme-toggle .knob{transform:translateX(0)}

.userchip{
  display:flex;align-items:center;gap:10px;
  padding:6px 7px 6px 8px;border-radius:13px;
  background:var(--panel);box-shadow:var(--shadow);border:1px solid var(--bd);
  transition:all .16s ease;max-width:240px;
}
.userchip:hover{border-color:var(--acc-ring)}
.userchip .avatar{
  width:32px;height:32px;border-radius:9px;flex-shrink:0;
  background:linear-gradient(145deg,#8B5CF6,var(--acc1));
  display:grid;place-items:center;color:#fff;font-size:13px;font-weight:700;
}
.userchip .uc-txt{min-width:0}
.userchip .nm{font-size:13px;font-weight:650;line-height:1.1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.userchip .rl{font-size:11px;color:var(--tx3);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.userchip .logout{
  margin-left:2px;width:32px;height:32px;border-radius:9px;display:grid;place-items:center;
  color:var(--tx3);transition:all .16s ease;flex-shrink:0}
.userchip .logout .ico-svg{width:17px;height:17px}
.userchip .logout:hover{background:var(--errbg);color:var(--err)}

/* ============================ UPLOAD BAR ============================ */
.uploadbar{
  margin-top:8px;display:flex;align-items:center;gap:20px;
  padding:20px 24px;border-radius:var(--r-lg);
  background:radial-gradient(120% 160% at 0% 0%, var(--acc-soft), transparent 60%), var(--panel);
  border:1px solid var(--bd);box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.upl-icon{
  width:52px;height:52px;border-radius:15px;flex-shrink:0;
  background:var(--acc-soft);color:var(--acc1);display:grid;place-items:center;
  border:1px dashed var(--acc-ring)}
.upl-icon .ico-svg{width:26px;height:26px}
.upl-txt h2{font-size:15.5px;font-weight:700;letter-spacing:-.02em}
.upl-txt p{font-size:13px;color:var(--tx2);margin-top:1px}
.upl-txt b{color:var(--acc1);font-weight:650}
.upl-actions{margin-left:auto;display:flex;gap:10px;flex-shrink:0}

/* ============================ BOTONES ============================ */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 17px;border-radius:12px;font-size:13.5px;font-weight:600;
  transition:all .18s cubic-bezier(.2,.7,.3,1);white-space:nowrap}
.btn .ico-svg{width:16px;height:16px}
.btn-primary{background:var(--grad);color:#fff;
  box-shadow:0 10px 22px -10px var(--acc-ring), inset 0 1px 0 rgba(255,255,255,.25)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 30px -12px var(--acc-ring), inset 0 1px 0 rgba(255,255,255,.25)}
.btn-primary:active{transform:translateY(0)}
.btn-primary .ico-svg{stroke:#fff}
.btn-ghost{background:var(--panel-2);color:var(--tx);border:1px solid var(--bd)}
.btn-ghost:hover{border-color:var(--acc-ring);color:var(--acc1);transform:translateY(-1px)}
.btn-upload{background:var(--grad);color:#fff;border-radius:12px;padding:11px 17px;
  font-size:13.5px;font-weight:600;display:inline-flex;align-items:center;gap:8px;
  box-shadow:0 10px 22px -10px var(--acc-ring);transition:all .18s}
.btn-upload:hover{transform:translateY(-2px)}
.btn-upload:disabled{opacity:.6;cursor:default;transform:none}
.btn:disabled,.btn-upload:disabled{opacity:.6;cursor:default}

/* ============================ SUMMARY BAND ============================ */
.band{margin-top:16px;display:grid;grid-template-columns:1.45fr 1fr;gap:16px}
@media(max-width:1080px){.band{grid-template-columns:1fr}}

/* KPI strip */
.kpis{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);
  border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow)}
@media(max-width:560px){.kpis{grid-template-columns:repeat(2,1fr)}}
.kpi{background:var(--panel);padding:16px 17px;display:flex;flex-direction:column;gap:9px}
.kpi .top{display:flex;align-items:center;gap:8px}
.kpi .ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;flex-shrink:0}
.kpi .ic .ico-svg{width:16px;height:16px}
.kpi .ic.k-green{background:var(--okbg);color:var(--ok)}
.kpi .ic.k-indigo{background:var(--acc-soft);color:var(--acc1)}
.kpi .ic.k-amber{background:var(--pendbg);color:var(--pend)}
.kpi .ic.k-blue{background:var(--colabg);color:var(--cola)}
.kpi .lbl{font-size:11.5px;color:var(--tx3);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.kpi .val{font-size:21px;font-weight:800;letter-spacing:-.03em;line-height:1}
.kpi .meta{font-size:11.5px;color:var(--tx2);font-weight:500;display:flex;align-items:center;gap:5px}
.kpi .meta .pos{color:var(--ok);font-weight:650}

/* Budget card */
.budget{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--shadow);padding:16px 18px;display:flex;flex-direction:column}
.budget .bh{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:13px}
.budget .bh .ti{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700}
.budget .bh .ti .ico-svg{width:17px;height:17px;color:var(--acc1)}
.excbadge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;
  padding:4px 9px;border-radius:20px;white-space:nowrap}
.excbadge .ico-svg{width:13px;height:13px}
.excbadge.over{color:var(--err);background:var(--errbg)}
.excbadge.ok{color:var(--ok);background:var(--okbg)}
.track{height:13px;border-radius:8px;background:var(--line-2);overflow:hidden;display:flex;position:relative}
.track .seg{height:100%}
.track .s-proc{background:linear-gradient(90deg,var(--ok),#16a34a)}
.track .s-topr{background:linear-gradient(90deg,var(--cola),#3b82f6)}
.track .s-pend{background:repeating-linear-gradient(45deg,var(--pend),var(--pend) 6px,transparent 6px,transparent 12px),var(--pendbg)}
.budrows{display:grid;grid-template-columns:1fr 1fr;gap:9px 18px;margin-top:16px}
.brow{display:flex;align-items:center;justify-content:space-between;gap:6px;font-size:12px}
.brow .l{display:flex;align-items:center;gap:7px;color:var(--tx2);font-weight:500}
.brow .l i{width:8px;height:8px;border-radius:2px;flex-shrink:0}
.brow .v{font-weight:700;letter-spacing:-.01em;text-align:right}
.brow .pct{color:var(--tx3);font-weight:600;font-size:11px;margin-left:5px}
.budget .kz{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  margin-top:14px;padding:10px 12px;border-radius:11px;
  background:var(--acc-soft);border:1px dashed var(--acc-ring)}
.budget .kz .l{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--acc1)}
.budget .kz .l .ico-svg{width:15px;height:15px}
.budget .kz .r{display:flex;align-items:center;gap:9px}
.budget .kz .amt{font-size:13.5px;font-weight:800;letter-spacing:-.02em}
.editbtn{display:grid;place-items:center;width:26px;height:26px;border-radius:8px;
  color:var(--acc1);background:var(--panel)}
.editbtn .ico-svg{width:13px;height:13px}
.editbtn:hover{background:var(--acc1);color:#fff}
.kz-input{width:120px;background:var(--input);border:1px solid var(--bd2);color:var(--tx);
  border-radius:7px;padding:3px 7px;font-family:inherit;font-size:13px}
.kz-ok,.kz-cancel{display:grid;place-items:center;width:24px;height:24px;border-radius:7px}
.kz-ok{background:var(--ok);color:var(--on-accent)} .kz-ok .ico-svg{width:13px;height:13px;stroke:var(--on-accent)}
.kz-cancel{color:var(--tx3)} .kz-cancel .ico-svg{width:13px;height:13px}
.kz-cancel:hover{color:var(--err)}

/* ============================ FEED HEADER / FILTROS ============================ */
.feedhead{margin-top:24px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.feedhead h3{font-size:16px;font-weight:800;letter-spacing:-.03em;display:flex;align-items:center;gap:9px}
.feedhead h3 .ico-svg{width:18px;height:18px;color:var(--acc1)}
.chips{display:flex;gap:7px;margin-left:6px;flex-wrap:wrap}
.chip{
  display:inline-flex;align-items:center;gap:7px;
  padding:7px 12px;border-radius:20px;font-size:12.5px;font-weight:550;
  background:var(--panel);border:1px solid var(--line);color:var(--tx2);
  transition:all .15s ease}
.chip:hover{border-color:var(--acc-ring);color:var(--tx);transform:translateY(-1px)}
.chip.on{background:var(--tx);color:var(--bg);border-color:var(--tx)}
html[data-theme="dark"] .chip.on{background:var(--acc1);color:#fff;border-color:var(--acc1)}
.chip .ct{font-size:11px;font-weight:750;padding:1px 7px;border-radius:10px;
  background:var(--line-2);color:var(--tx2);font-variant-numeric:tabular-nums}
.chip.on .ct{background:rgba(255,255,255,.22);color:inherit}
.chip i.led{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.searchwrap{margin-left:auto;position:relative}
.searchwrap .ico-svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--tx3)}
.searchwrap input{
  font-size:13px;color:var(--tx);
  background:var(--panel);border:1px solid var(--line);border-radius:11px;
  padding:9px 14px 9px 36px;width:230px;transition:all .15s ease}
.searchwrap input::placeholder{color:var(--tx3)}
.searchwrap input:focus{border-color:var(--acc1);width:260px;outline:none}
/* filtro por ZIP (combina con los chips de estado) */
.zipfilter{display:flex;align-items:center;gap:7px;background:var(--panel);border:1px solid var(--bd);border-radius:11px;padding:0 6px 0 11px;height:40px}
.zipfilter > .ico-svg{width:16px;height:16px;color:var(--tx3);flex:none}
.zipfilter select{border:none;background:none;outline:none;color:var(--tx);font-family:inherit;font-size:13px;font-weight:600;padding:8px 6px;cursor:pointer;max-width:190px}
.zipfilter select:hover{color:var(--acc1)}
.zipfilter select option{background:var(--panel);color:var(--tx);font-weight:500}

/* ============================ LAYOUT FEED + ASIDE ============================ */
.layout{margin-top:18px;display:grid;grid-template-columns:1fr 320px;gap:26px;align-items:start}
@media(max-width:1080px){.layout{grid-template-columns:1fr}}

/* feed = línea de tiempo */
.feed{position:relative}
.feed-body{position:relative;padding-left:30px}
.feed-body::before{
  content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;
  background:linear-gradient(var(--rail), var(--rail) 70%, transparent)}
.feed-empty{padding:34px;text-align:center;color:var(--tx3);font-size:13.5px}

.event{position:relative;margin-bottom:13px;cursor:pointer}
.event .node{
  position:absolute;left:-30px;top:24px;width:14px;height:14px;border-radius:50%;
  z-index:2;border:3px solid var(--panel);box-shadow:0 0 0 1.5px var(--line)}
.card{
  background:var(--panel);border:1px solid var(--line);border-radius:16px;
  box-shadow:var(--shadow);padding:15px 17px;position:relative;overflow:hidden;
  transition:transform .18s cubic-bezier(.2,.7,.3,1), box-shadow .18s ease, border-color .18s ease}
.card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:3px}
.event:hover .card{transform:translateX(4px);box-shadow:var(--shadow-pop);border-color:var(--acc-ring)}
.card.k-pend::before{background:var(--pend)}
.card.k-proc::before{background:var(--cola)}
.card.k-done::before{background:var(--ok)}
.card.k-lib::before{background:var(--lib)}
.card.k-err::before{background:var(--err)}

.crow1{display:flex;align-items:flex-start;gap:13px}
.prov-ic{
  width:38px;height:38px;border-radius:11px;flex-shrink:0;
  display:grid;place-items:center;font-size:14px;font-weight:800;color:#fff}
.prov-ic.prov-pend{background:linear-gradient(145deg,#F59E0B,#D97706)}
.prov-ic.prov-proc{background:linear-gradient(145deg,#3B82F6,#2563EB)}
.prov-ic.prov-done{background:linear-gradient(145deg,#22C55E,#15803D)}
.prov-ic.prov-lib{background:linear-gradient(145deg,#F97316,#C2410C)}
.prov-ic.prov-err{background:linear-gradient(145deg,#EF4444,#B91C1C)}
.crow1 .main{min-width:0;flex:1}
.crow1 .prov{font-size:14.5px;font-weight:700;letter-spacing:-.02em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.crow1 .sub{display:flex;align-items:center;gap:8px;margin-top:3px;font-size:12px;color:var(--tx2);flex-wrap:wrap}
.crow1 .sub .fac{font-weight:600;color:var(--tx)}
.crow1 .sub .dot{width:3px;height:3px;border-radius:50%;background:var(--tx3);flex-shrink:0}
.suc{display:inline-flex;align-items:center;gap:5px}
.suc .ico-svg{width:12px;height:12px;color:var(--tx3)}

.amt-col{text-align:right;flex-shrink:0;margin-left:8px;display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.amt-col .amt{font-size:16px;font-weight:800;letter-spacing:-.03em;line-height:1}
.zip{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:650;
  padding:3px 8px;border-radius:7px;background:var(--line-2);color:var(--tx2)}
.zip .ico-svg{width:11px;height:11px;color:var(--tx3)}
.zip.barrio{background:var(--libbg);color:var(--lib)} .zip.barrio .ico-svg{color:var(--lib)}
.zip.none{background:transparent;border:1px dashed var(--line);color:var(--tx3)}

.crow2{display:flex;align-items:center;gap:10px;margin-top:13px;padding-top:12px;
  border-top:1px solid var(--line-2);position:relative}
.crow2 .badge{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;
  padding:5px 11px;border-radius:20px;white-space:nowrap}
.crow2 .badge .ico-svg{width:12px;height:12px}
.b-pend{background:var(--pendbg);color:var(--pend)}
.b-cola{background:var(--colabg);color:var(--cola)}
.b-ok{background:var(--okbg);color:var(--ok)}
.b-lib{background:var(--libbg);color:var(--lib)}
.b-err{background:var(--errbg);color:var(--err)}

.sapwrap{flex:1;min-width:0}
.sap{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:11px;color:var(--tx2)}
.sap .tag{display:inline-flex;align-items:center;gap:4px;font-variant-numeric:tabular-nums;font-weight:600;
  background:var(--panel-2);border:1px solid var(--line);border-radius:7px;padding:2px 7px}
.sap .tag b{color:var(--acc1);font-weight:700;font-size:9.5px;text-transform:uppercase;letter-spacing:.03em}
.sap-empty{font-size:11.5px;color:var(--tx3);font-style:italic}

.crow2 .act{margin-left:auto;flex-shrink:0}
.processbtn{
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 14px;border-radius:10px;font-size:12.5px;font-weight:650;
  background:var(--grad);color:#fff;
  box-shadow:0 8px 18px -10px var(--acc-ring), inset 0 1px 0 rgba(255,255,255,.2);
  transition:all .17s cubic-bezier(.2,.7,.3,1)}
.processbtn .ico-svg{width:13px;height:13px;stroke:#fff}
.processbtn:hover{transform:translateY(-2px) scale(1.02)}
.processbtn:active{transform:translateY(0)}
.processbtn.act-err-btn{background:var(--errbg);color:var(--err);box-shadow:none;border:1px solid var(--bd)}
.processbtn.act-err-btn .ico-svg{stroke:var(--err)}
.processbtn.act-err-btn:hover{filter:brightness(1.06)}
.viewbtn{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 13px;border-radius:10px;font-size:12.5px;font-weight:600;
  color:var(--tx2);border:1px solid var(--line);background:var(--panel-2);transition:all .15s ease}
.viewbtn .ico-svg{width:13px;height:13px}
.viewbtn:hover{color:var(--acc1);border-color:var(--acc-ring)}
.viewbtn.act-undo:hover{color:var(--tx);border-color:var(--bd2)}
.viewbtn.act-lib{color:var(--lib);border-color:var(--bd)} .viewbtn.act-lib:hover{background:var(--libbg)}
.lock{font-size:12px;color:var(--tx3);display:inline-flex;align-items:center;gap:5px;font-weight:600}
.lock .ico-svg{width:13px;height:13px}

/* float editar/eliminar */
.rowfloat{display:flex;align-items:center;gap:2px;margin-left:4px;
  opacity:0;pointer-events:none;transition:opacity .12s}
.event:hover .rowfloat,.event:focus-within .rowfloat{opacity:1;pointer-events:auto}
.ricon{cursor:pointer;color:var(--tx3);padding:6px;border-radius:7px;transition:.15s;
  display:inline-flex;align-items:center;justify-content:center}
.ricon .ico-svg{width:14px;height:14px}
.ricon:hover{color:var(--tx);background:var(--panel-2)}
.ricon-del:hover{color:var(--err);background:var(--errbg)}

.feedfoot{display:flex;align-items:center;justify-content:center;gap:9px;margin:8px 0 0;padding:14px}
.feedfoot .ln{height:1px;flex:1;background:var(--line);max-width:90px}
.showing{font-size:11.5px;color:var(--tx3);font-variant-numeric:tabular-nums}

/* ============================ ASIDE ============================ */
.aside{display:flex;flex-direction:column;gap:16px;position:sticky;top:78px}
@media(max-width:1080px){.aside{position:static}}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--shadow);padding:17px 18px}
.panel h4{font-size:12px;font-weight:750;text-transform:uppercase;letter-spacing:.05em;
  color:var(--tx3);margin-bottom:15px;display:flex;align-items:center;gap:8px}
.panel h4 .ico-svg{width:15px;height:15px;color:var(--acc1)}

/* avance por proveedor */
.pv{display:block}
.prov-item{margin-bottom:15px}
.prov-item:last-child{margin-bottom:0}
.prov-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:7px}
.prov-top .nm{font-size:13px;font-weight:650;letter-spacing:-.01em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.prov-top .frac{font-size:11px;color:var(--tx3);font-weight:600;flex-shrink:0;margin-left:8px}
.prov-line{display:flex;align-items:center;gap:9px}
.prov-bar{flex:1;height:7px;border-radius:5px;background:var(--line-2);overflow:hidden}
.prov-bar .fill{height:100%;border-radius:5px;transition:width .5s cubic-bezier(.2,.7,.3,1)}
.prov-pct{font-size:11px;font-weight:700;min-width:32px;text-align:right}
.prov-foot{margin-top:6px}
.pv-pend-link{font-size:11px;color:var(--cola);cursor:pointer;font-weight:600}
.pv-pend-link:hover{text-decoration:underline}

/* tandas / zip queue */
.zipqueue{display:block}
.zipline{display:flex;align-items:center;gap:11px;padding:10px 0;border-bottom:1px solid var(--line-2)}
.zipline:last-child{border-bottom:none}
.zipchip{width:38px;height:38px;border-radius:11px;flex-shrink:0;display:grid;place-items:center;
  font-size:11px;font-weight:800;letter-spacing:-.02em;line-height:1;text-align:center}
.zipchip.may{background:var(--acc-soft);color:var(--acc1)}
.zipchip.bar{background:var(--libbg);color:var(--lib)}
.zipline .zi{flex:1;min-width:0}
.zipline .zi .t{font-size:12.5px;font-weight:650;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.zipline .zi .d{font-size:11px;color:var(--tx3);font-weight:500}
.zipline .send{display:grid;place-items:center;width:30px;height:30px;border-radius:9px;
  color:var(--acc1);background:var(--acc-soft);transition:all .16s ease;flex-shrink:0}
.zipline .send .ico-svg{width:15px;height:15px}
.zipline .send:hover{background:var(--acc1);color:#fff;transform:translateX(2px)}
.zipline .send:hover .ico-svg{stroke:#fff}
.bigsend{width:100%;margin-top:14px;justify-content:center}

/* nota + simular */
.note-panel{padding:0;background:transparent;border:none;box-shadow:none}
.note{font-size:12.5px;color:var(--tx2);background:var(--panel);border:1px dashed var(--bd2);
  border-radius:13px;padding:14px 16px;line-height:1.6}
.note b{color:var(--tx)}
.kbd{font-size:11px;background:var(--input);border:1px solid var(--bd);border-radius:6px;padding:2px 7px;color:var(--tx2)}
#btn-otto{font-size:12.5px}
#btn-otto .ico-svg{width:14px;height:14px}

.tinynote{text-align:center;font-size:11px;color:var(--tx3);margin-top:30px;padding-top:18px;
  border-top:1px solid var(--line);display:flex;align-items:center;justify-content:center;gap:7px}
.tinynote .ico-svg{width:14px;height:14px;color:var(--acc1)}

/* compat: clases viejas que app.js puede emitir todavía (no rompen nada) */
.act{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:650;
  border-radius:10px;padding:8px 13px;cursor:pointer;transition:.15s;font-family:inherit}
.act .ico-svg{width:14px;height:14px}
.act-go{background:var(--grad);color:#fff;box-shadow:0 6px 16px -8px var(--acc-ring)}
.act-go:hover{transform:translateY(-1px)} .act-go .ico-svg{stroke:#fff}
.act-undo{background:var(--panel-2);color:var(--tx2);border:1px solid var(--bd2)}
.act-undo:hover{background:var(--panel);color:var(--tx)}
.act-err{background:var(--errbg);color:var(--err);border:1px solid var(--bd)}
.act-err:hover{filter:brightness(1.06)}
.act-lib{background:var(--libbg);color:var(--lib);border:1px solid var(--bd)}
.act-done{color:var(--ok);font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:6px}
.bdot{width:6px;height:6px;border-radius:50%;background:currentColor}
.bdot.sp{animation:pulse2 1.4s infinite}
@keyframes pulse2{0%,100%{opacity:1}50%{opacity:.35}}

/* ============================ MODALES ============================ */
.modal{position:fixed;inset:0;background:rgba(6,10,20,.55);backdrop-filter:blur(4px);
  display:grid;place-items:center;z-index:100;padding:28px}
.modal[hidden]{display:none}
.sheet{width:min(980px,96vw);max-height:90vh;background:var(--panel);
  border:1px solid var(--bd2);border-radius:20px;box-shadow:var(--shadow-pop);overflow:hidden;
  display:flex;flex-direction:column}
.sheet-head{display:flex;align-items:flex-start;gap:12px;padding:18px 20px;border-bottom:1px solid var(--line)}
.sheet-head h3{font-size:17px;font-weight:700}
.sheet-head .sub{font-size:12.5px;color:var(--tx2);margin-top:2px}
.sheet-head > div:first-child{flex:1;min-width:0}
.x,.maxbtn{background:var(--panel-2);border:1px solid var(--line);color:var(--tx2);
  width:34px;height:34px;border-radius:10px;cursor:pointer;font-size:15px;transition:.15s;
  display:grid;place-items:center}
.x .ico-svg,.maxbtn .ico-svg{width:16px;height:16px}
.x:hover{background:var(--errbg);color:var(--err);border-color:var(--err)}
.maxbtn:hover{background:var(--panel);color:var(--tx)}
.maxbtn{font-size:14px}
.sheet.max{width:96vw!important;max-width:96vw;height:94vh;max-height:94vh}
.sheet.max .sheet-body{height:80vh}
.dl{margin-left:auto;background:var(--grad);color:#fff;border-radius:10px;
  padding:9px 15px;font-size:13px;font-weight:650;cursor:pointer;transition:.15s;
  box-shadow:0 6px 16px -8px var(--acc-ring);display:inline-flex;align-items:center;gap:7px}
.dl .ico-svg{width:15px;height:15px;stroke:#fff}
.dl:hover{transform:translateY(-1px)}
.sheet-body{display:grid;grid-template-columns:1fr 340px;gap:0;height:62vh;overflow:hidden}
@media(max-width:760px){.sheet-body{grid-template-columns:1fr;height:auto;max-height:62vh;overflow:auto}}
.pdf{background:var(--pdf-bg);padding:16px;display:flex;flex-direction:column;gap:10px;border-right:1px solid var(--line);min-height:0}
.pdf-bar{font-size:12px;color:rgba(255,255,255,.85);display:flex;align-items:center;gap:8px}
.pdf-bar .ico-svg{width:14px;height:14px}
.pdf-bar .muted{color:rgba(255,255,255,.6)}
.pdf embed,.pdf iframe{width:100%;flex:1;height:100%;min-height:0;border:none;border-radius:8px;background:#fff;box-shadow:0 14px 40px rgba(0,0,0,.5)}
.info{padding:18px 20px;display:flex;flex-direction:column;gap:6px;min-height:0;overflow:auto}
.info-row{display:flex;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px solid var(--line);font-size:13px}
.info-row .k{color:var(--tx2)}
.info-row .v{font-weight:600;text-align:right}
.info-row .badge{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;padding:4px 10px;border-radius:20px}
.info-row .badge .ico-svg{width:12px;height:12px}
.d-lote-sel{background:var(--input);border:1px solid var(--bd);border-radius:8px;
  padding:5px 8px;color:var(--tx);font-size:12.5px;font-family:inherit;outline:none;max-width:170px}
.d-lote-sel:focus{border-color:var(--acc1)}
.info-sap{margin-top:8px;background:var(--colabg);border:1px solid var(--bd);border-radius:11px;padding:12px 14px}
.info-sap .t{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--cola);font-weight:700;margin-bottom:8px}
.info-sap .sline{display:flex;justify-content:space-between;font-size:12.5px;padding:4px 0;color:var(--tx2)}
.info-sap .sline b{color:var(--tx);font-variant-numeric:tabular-nums}
.info-act{margin-top:14px;padding-top:14px;display:flex;flex-direction:column;gap:8px}
.info-act .act,.info-act .processbtn,.info-act .viewbtn{width:100%;justify-content:center;padding:11px}

/* formulario de revisión */
.fld{display:flex;flex-direction:column;gap:5px;font-size:12px;color:var(--tx2);margin-bottom:11px}
.fld input,.fld select{background:var(--input);border:1px solid var(--bd);border-radius:9px;
  padding:9px 11px;color:var(--tx);font-size:13.5px;font-family:inherit;outline:none;transition:.15s}
.fld input:focus,.fld select:focus{border-color:var(--acc1)}
.conf{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;padding:7px 12px;border-radius:9px;margin-bottom:14px}
.conf-alta{background:var(--okbg);color:var(--ok)}
.conf-media{background:var(--pendbg);color:var(--pend)}
.conf-baja{background:var(--errbg);color:var(--err)}
.spin{display:inline-block;width:13px;height:13px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;vertical-align:-2px}
@keyframes spin{to{transform:rotate(360deg)}}

/* enviar a gastos */
.exp-hist{margin-top:18px;border-top:1px solid var(--line);padding-top:14px}
.exp-hist-t{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--tx3);font-weight:700;margin-bottom:10px}
.lote-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 0;border-bottom:1px solid var(--line);font-size:13px}
.lote-row:last-child{border-bottom:none}
.lote-row b{font-weight:700}
.lote-dl{color:var(--cola);cursor:pointer;font-weight:600;font-size:12.5px}
.lote-dl:hover{text-decoration:underline}

/* rechazadas */
.rech-row{display:flex;align-items:center;gap:12px;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line);font-size:13px}
.rech-row:last-child{border-bottom:none}
.rech-zip{color:var(--lib);font-weight:600;white-space:nowrap}
.rech-dl{color:var(--cola);cursor:pointer;font-size:12.5px;white-space:nowrap}
.rech-dl:hover{text-decoration:underline}

/* usuarios */
.u-form{display:flex;gap:8px;flex-wrap:wrap}
.u-form input,.u-form select{background:var(--input);border:1px solid var(--bd);border-radius:9px;
  padding:9px 11px;color:var(--tx);font-size:13px;font-family:inherit;outline:none}
.u-form input{flex:1;min-width:120px}
.u-form input:focus,.u-form select:focus{border-color:var(--acc1)}
.u-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid var(--line);font-size:13px}
.u-row:last-child{border-bottom:none}
.u-badge{font-size:10.5px;font-weight:700;padding:3px 8px;border-radius:6px}
.u-admin{background:var(--colabg);color:var(--cola)}.u-oper{background:var(--panel-2);color:var(--tx2)}
.u-off{opacity:.5}
.u-toggle{cursor:pointer;color:var(--tx2);font-size:12.5px;font-weight:600}
.u-toggle:hover{color:var(--tx)}

/* subida múltiple (carrusel) */
.batch-prog{padding:40px 20px;text-align:center;color:var(--tx2);font-size:14px}
.batch-prog .barwrap{max-width:420px;margin:16px auto 0;height:10px;border-radius:6px;background:var(--input);overflow:hidden}
.batch-prog .barfill{height:100%;background:var(--grad);width:0;transition:width .3s}
.btable{width:100%;border-collapse:collapse;font-size:12.5px}
.btable th{position:sticky;top:0;background:var(--head);text-align:left;font-size:10.5px;letter-spacing:.5px;
  text-transform:uppercase;color:var(--tx3);font-weight:600;padding:9px 8px;z-index:1}
.btable td{padding:5px 8px;border-top:1px solid var(--line);vertical-align:middle}
.btable tr.warn td{background:var(--pendbg)}
.btable input,.btable select{width:100%;background:var(--input);border:1px solid var(--bd);border-radius:7px;
  padding:6px 7px;color:var(--tx);font-size:12.5px;font-family:inherit;outline:none}
.btable input:focus,.btable select:focus{border-color:var(--acc1)}
.bk{font-size:10.5px;font-weight:700;padding:3px 7px;border-radius:6px;white-space:nowrap}
.bk-may{background:var(--colabg);color:var(--cola)}.bk-bar{background:var(--libbg);color:var(--lib)}
.batch-nav{border-top:1px solid var(--line);padding:14px 18px;display:flex;gap:12px;align-items:center}
.batch-nav #b2-pos{font-size:13px;font-variant-numeric:tabular-nums}
.batch-nav #b2-del{margin-left:auto}
.batch-nav .act{padding:10px 16px}
.batch-zip{display:flex;align-items:center;gap:8px;font-size:13px}
.batch-zip select{background:var(--input);border:1px solid var(--bd);border-radius:9px;padding:8px 10px;
  color:var(--tx);font-size:13px;font-family:inherit;outline:none;min-width:160px}
.batch-zip b{color:var(--tx)}

/* toast */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(80px);
  background:var(--panel);border:1px solid var(--bd2);color:var(--tx);padding:13px 20px;border-radius:13px;
  box-shadow:var(--shadow-pop);font-size:13.5px;display:flex;align-items:center;gap:10px;opacity:0;transition:.35s;z-index:120}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}
.toast.err{border-color:var(--err)}

/* ============================ RESPONSIVE ============================ */
@media(max-width:760px){
  .shell{padding:0 14px 40px}
  .topbar{flex-wrap:wrap;gap:10px}
  .nav{order:3;margin-left:0;width:100%;overflow-x:auto}
  .uploadbar{flex-wrap:wrap}
  .upl-actions{margin-left:0;width:100%}
  .upl-actions .btn{flex:1;justify-content:center}
  .searchwrap{margin-left:0;width:100%}
  .searchwrap input{width:100%}
  .searchwrap input:focus{width:100%}
}
