:root{
  /* Paleta de la marca Tres Velas (azules del logo). Los nombres --green* se
     conservan por compatibilidad pero ahora apuntan a los azules de marca. */
  --green:#1577b0; --green-2:#29abe2; --green-soft:#e7f3fb;
  --ink:#15212b; --muted:#5b6b76; --line:#e1e9f0; --line-2:#eef3f8;
  --bg:#f4f7fb; --card:#ffffff; --amber:#c9821a; --amber-soft:#fbf0dd;
  --red:#b5462f; --red-soft:#f9e4de; --blue:#2f6fb0; --blue-soft:#e6f0fa;
  --shadow:0 14px 40px -22px rgba(20,50,80,.4);
  --radius:16px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:"Segoe UI",system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--bg);font-size:14.5px}
a{cursor:pointer;text-decoration:none;color:inherit}

.app{display:flex;min-height:100vh}

/* SIDEBAR */
.sidebar{width:264px;flex-shrink:0;background:#fff;border-right:1px solid var(--line);
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:12px;padding:20px 18px;border-bottom:1px solid var(--line-2)}
.brand .mark{width:42px;height:42px;border-radius:12px;flex-shrink:0;overflow:hidden;
  background:#fff;display:flex;align-items:center;justify-content:center;font-size:1.3rem}
.brand .mark img{width:100%;height:100%;object-fit:contain}
.brand-name{font-weight:800;letter-spacing:.04em;color:var(--green)}
.brand-sub{font-size:.72rem;color:var(--muted)}
.nav{padding:14px 12px;flex:1;overflow:auto}
.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:11px;
  color:var(--ink);font-weight:600;font-size:.92rem;margin-bottom:3px;transition:.13s}
.nav-item:hover{background:var(--green-soft)}
.nav-item.active{background:var(--green);color:#fff;box-shadow:var(--shadow)}
.nav-item .ni-ico{font-size:1.05rem;width:20px;text-align:center}
.nav-item.locked{color:#9fb0a8;cursor:not-allowed}
.nav-item.locked:hover{background:transparent}
.lock{margin-left:auto;font-size:.66rem;background:var(--line);color:var(--muted);
  padding:2px 7px;border-radius:999px;font-weight:700}
.nav-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.14em;color:#9fb0a8;
  font-weight:800;margin:18px 12px 8px}
.side-foot{padding:14px 16px;border-top:1px solid var(--line-2)}
.demo-pill{font-size:.72rem;color:var(--amber);background:var(--amber-soft);
  padding:7px 11px;border-radius:9px;text-align:center;font-weight:700}

/* scrim (oscurece el fondo cuando el cajón está abierto en móvil) */
.scrim{display:none;position:fixed;inset:0;background:rgba(13,30,45,.45);z-index:90}

/* MAIN */
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;justify-content:space-between;
  padding:16px 30px;background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.topbar-l{display:flex;align-items:center;gap:12px;min-width:0}
.menu-btn{display:none;border:1px solid var(--line);background:#fff;color:var(--ink);
  width:42px;height:42px;border-radius:11px;font-size:1.3rem;line-height:1;cursor:pointer;
  flex-shrink:0;align-items:center;justify-content:center}
.menu-btn:hover{border-color:var(--green-2)}
.crumb{font-weight:800;font-size:1.15rem}
.crumb-sub{font-size:.8rem;color:var(--muted)}
.top-right{display:flex;align-items:center;gap:14px}
.botstat{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:12px;
  padding:8px 14px;background:#fff}
.botstat .bs-1{font-weight:700;font-size:.84rem}
.botstat .bs-2{font-size:.74rem;color:var(--muted)}
.dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.dot.ok{background:var(--green-2);box-shadow:0 0 0 4px rgba(47,168,107,.18)}
.dot.warn{background:var(--amber)}
.dot.off{background:#b9c4be}

.content{padding:28px 30px 60px;max-width:1240px;width:100%}

/* generic */
.section-head{margin-bottom:18px}
.section-head h2{font-size:1.35rem;letter-spacing:-.01em}
.section-head p{color:var(--muted);font-size:.9rem;margin-top:2px}
.grid{display:grid;gap:16px}
.g4{grid-template-columns:repeat(4,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}
.cols{display:grid;grid-template-columns:1.5fr 1fr;gap:16px;align-items:start}
@media(max-width:1080px){.g4{grid-template-columns:repeat(2,1fr)}.cols{grid-template-columns:1fr}}
@media(max-width:680px){.g4,.g3,.g2{grid-template-columns:1fr}}

.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;box-shadow:var(--shadow)}
.card h3{font-size:1rem;margin-bottom:4px;display:flex;align-items:center;gap:8px}
.card .sub{color:var(--muted);font-size:.82rem;margin-bottom:14px}

/* KPI */
.kpi{display:flex;flex-direction:column;gap:6px}
.kpi .k-top{display:flex;align-items:center;justify-content:space-between}
.kpi .k-ico{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;
  justify-content:center;font-size:1.15rem;background:var(--green-soft)}
.kpi .k-val{font-size:2rem;font-weight:800;line-height:1}
.kpi .k-lbl{color:var(--muted);font-size:.84rem}
.kpi .k-delta{font-size:.74rem;font-weight:700;padding:2px 8px;border-radius:999px}
.k-delta.up{background:var(--green-soft);color:var(--green)}
.k-delta.flat{background:var(--line-2);color:var(--muted)}

/* badges */
.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;
  font-size:.76rem;font-weight:700}
.badge .bd{width:7px;height:7px;border-radius:50%}
.b-captured{background:var(--green-soft);color:var(--green)}.b-captured .bd{background:var(--green-2)}
.b-needs_dest{background:var(--amber-soft);color:var(--amber)}.b-needs_dest .bd{background:var(--amber)}
.b-error{background:var(--red-soft);color:var(--red)}.b-error .bd{background:var(--red)}

/* table */
.table-wrap{overflow:auto;border-radius:12px;border:1px solid var(--line)}
table{width:100%;border-collapse:collapse;font-size:.88rem}
thead th{text-align:left;padding:11px 14px;background:#f8fbf9;color:var(--muted);
  font-weight:700;font-size:.74rem;text-transform:uppercase;letter-spacing:.05em;
  border-bottom:1px solid var(--line);position:sticky;top:0}
tbody td{padding:11px 14px;border-bottom:1px solid var(--line-2)}
tbody tr:hover{background:#fafdfb}
tbody tr:last-child td{border-bottom:0}
.mono{font-variant-numeric:tabular-nums;color:var(--muted);font-size:.82rem}
.muted{color:var(--muted)}
.cell-strong{font-weight:700}

/* filter pills */
.pills{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.fpill{border:1px solid var(--line);background:#fff;border-radius:999px;padding:7px 14px;
  font-weight:600;font-size:.84rem;color:var(--muted);cursor:pointer;transition:.13s}
.fpill:hover{border-color:var(--green-2)}
.fpill.active{background:var(--green);color:#fff;border-color:var(--green)}
.search{border:1px solid var(--line);border-radius:10px;padding:9px 13px;font-size:.88rem;
  width:240px;outline:none}
.search:focus{border-color:var(--green-2)}

/* bar chart */
.bar-row{display:grid;grid-template-columns:120px 1fr 44px;align-items:center;gap:10px;margin:9px 0}
.bar-row .bl{font-size:.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-track{height:12px;background:var(--line-2);border-radius:999px;overflow:hidden}
.bar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--green),var(--green-2))}
.bar-row .bv{text-align:right;font-weight:700;font-size:.84rem;color:var(--muted)}

/* activity feed */
.feed{display:flex;flex-direction:column;gap:2px}
.feed-item{display:flex;gap:12px;padding:11px 4px;border-bottom:1px solid var(--line-2)}
.feed-item:last-child{border-bottom:0}
.feed-ico{width:34px;height:34px;border-radius:10px;flex-shrink:0;display:flex;align-items:center;
  justify-content:center;font-size:1rem;background:var(--green-soft)}
.feed-ico.warn{background:var(--amber-soft)}.feed-ico.err{background:var(--red-soft)}
.feed-main{flex:1;min-width:0}
.feed-main .fm-1{font-weight:600;font-size:.9rem}
.feed-main .fm-2{color:var(--muted);font-size:.8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.feed-time{color:#9fb0a8;font-size:.76rem;white-space:nowrap}

/* chofer card */
.chofer{display:flex;gap:16px;align-items:center}
.chofer .av{width:54px;height:54px;border-radius:14px;flex-shrink:0;color:#fff;font-weight:800;
  font-size:1.3rem;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--green),var(--green-2))}
.chofer .c-name{font-weight:800}
.chofer .c-veh{font-size:.8rem;color:var(--muted)}
.mini-stats{display:flex;gap:22px;margin-top:14px}
.mini-stats .ms .v{font-size:1.5rem;font-weight:800}
.mini-stats .ms .l{font-size:.76rem;color:var(--muted)}

/* sync */
.btn{border:0;border-radius:11px;padding:11px 18px;font-weight:700;font-size:.9rem;cursor:pointer;
  display:inline-flex;align-items:center;gap:8px;transition:.13s}
.btn.primary{background:var(--green);color:#fff;box-shadow:var(--shadow)}
.btn.primary:hover{background:#115d8c}
.btn.ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn.ghost:hover{border-color:var(--green-2)}
.btn[disabled]{opacity:.55;cursor:not-allowed}
.note{font-size:.8rem;color:var(--muted)}
.callout{display:flex;gap:12px;padding:14px 16px;border-radius:12px;background:var(--blue-soft);
  border:1px solid #cfe0f1;color:#27506f;font-size:.88rem;align-items:flex-start}
.callout.amber{background:var(--amber-soft);border-color:#e7d3a8;color:#7a5210}

/* config */
.kv{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--line-2)}
.kv:last-child{border-bottom:0}
.kv .k{color:var(--muted);font-size:.86rem}
.kv .v{font-weight:700;font-size:.9rem}
.qr{width:150px;height:150px;border-radius:14px;border:2px dashed var(--line);
  display:flex;align-items:center;justify-content:center;text-align:center;color:var(--muted);
  font-size:.78rem;padding:14px;background:#fafdfb}

.taglist{display:flex;flex-wrap:wrap;gap:8px}
.chip{border:1px solid var(--line);background:#fff;border-radius:9px;padding:7px 12px;
  font-size:.85rem;font-weight:600}
.chip .x{color:#9fb0a8;font-size:.75rem;margin-left:6px}

.empty{padding:40px;text-align:center;color:var(--muted)}
.locked-banner{display:flex;gap:14px;align-items:center;padding:18px;border-radius:14px;
  background:#fff;border:1px dashed var(--line);color:var(--muted)}
a.btn{text-decoration:none}

/* ---------- login (stub) ---------- */
.login-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;
  padding:24px;background:linear-gradient(135deg,#0e2433,#15558c)}
.login-card{background:#fff;border-radius:var(--radius);padding:30px 26px;width:100%;max-width:360px;
  box-shadow:0 24px 60px -20px rgba(0,0,0,.5)}
.login-brand{width:64px;height:64px;margin:0 auto 14px;border-radius:16px;overflow:hidden;background:#fff;
  display:flex;align-items:center;justify-content:center;font-size:2rem;border:1px solid var(--line)}
.login-brand img{width:100%;height:100%;object-fit:contain}
.login-card h2{text-align:center;font-size:1.2rem}
.login-sub{text-align:center;color:var(--muted);font-size:.85rem;margin-top:2px;margin-bottom:8px}
.login-card label{display:block;font-size:.78rem;font-weight:700;color:var(--muted);margin-top:12px}
.login-card input{width:100%;margin-top:5px;padding:11px 12px;font-size:.95rem;
  border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--ink)}
.login-card input:focus{outline:none;border-color:var(--green-2)}
.login-card .btn.primary{width:100%;justify-content:center;margin-top:18px}
.login-note{text-align:center;color:#9fb0a8;font-size:.74rem;margin-top:12px}

/* ---------- forms (ventas / manifiestos controls) ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.card label{display:block;font-size:.78rem;font-weight:700;color:var(--muted);margin-top:12px}
.card label:first-child{margin-top:0}
.card input,.card select,.card textarea{width:100%;margin-top:5px;padding:10px 12px;font-size:.92rem;
  border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--ink);appearance:none}
.card input:focus,.card select:focus{outline:none;border-color:var(--green-2)}
.card input.ro{background:var(--green-soft);font-weight:800;color:var(--green)}

/* ---------- manifiesto (document + print) ---------- */
.manifiesto{background:#fff;border:1px solid var(--line);border-radius:12px;padding:28px;
  max-width:820px;margin:0 auto;color:#10221a}
.mf-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;
  border-bottom:2px solid var(--ink);padding-bottom:12px}
.mf-title{font-size:1.15rem;font-weight:800;letter-spacing:.02em}
.mf-sub{color:var(--muted);font-size:.85rem;margin-top:2px}
.mf-meta{text-align:right;font-size:.85rem;line-height:1.7}
.mf-row2{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:16px 0}
.mf-k{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}
.mf-v{font-size:1rem;font-weight:700;border-bottom:1px solid var(--line);padding:4px 0;min-height:1.6em}
.mf-table{width:100%;border-collapse:collapse;margin-top:8px}
.mf-table th,.mf-table td{border:1px solid var(--line);padding:9px 10px;font-size:.9rem;text-align:left}
.mf-table th{background:var(--green-soft);color:var(--ink);font-size:.78rem;text-transform:uppercase;letter-spacing:.03em}
.mf-table td.num{text-align:right;font-variant-numeric:tabular-nums}
.mf-table [contenteditable]:focus{outline:2px solid var(--green-2);outline-offset:-2px;background:#fff}
.mf-note{font-size:.74rem;color:var(--muted);margin-top:8px}
.mf-firmas{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:46px;font-size:.85rem;text-align:center}
.mf-line{border-top:1px solid var(--ink);margin-bottom:6px}

/* ---------- móvil: sidebar como cajón deslizable ---------- */
@media(max-width:860px){
  .menu-btn{display:flex}
  .topbar{padding:12px 16px}
  .content{padding:20px 16px 60px}

  /* el cajón se sale de pantalla y entra al abrir */
  .sidebar{position:fixed;top:0;left:0;height:100vh;width:84%;max-width:300px;z-index:100;
    transform:translateX(-100%);transition:transform .22s ease;
    box-shadow:0 24px 60px -10px rgba(13,30,45,.5)}
  .app.nav-open .sidebar{transform:translateX(0)}
  .app.nav-open .scrim{display:block}

  /* el contenido ocupa todo el ancho (el sidebar ya no empuja) */
  .main{width:100%}
}

/* ---------- print: only the manifiesto ---------- */
@media print{
  .sidebar,.topbar,.no-print,.btn{display:none !important}
  body,.app,.main,.content{background:#fff !important;margin:0 !important;padding:0 !important;display:block !important}
  .manifiesto{border:none;border-radius:0;max-width:none;padding:0;margin:0}
  .mf-table th{background:#eee !important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  @page{margin:14mm}
}
