:root{--bg:#f6f7f9;--card:#fff;--text:#101828;--muted:#667085;--line:#e5e7eb;--primary:#1f6feb;--danger:#b42318;--ok:#067647;--warn:#b54708;--primary-soft:#dbeafe;--ok-soft:#ecfdf3;--pending-soft:#fff7ed}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text)}a{color:var(--primary);text-decoration:none}.topbar{background:#111827;color:white;padding:14px 22px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}.brand{font-weight:800}.topbar nav{display:flex;gap:12px;flex-wrap:wrap}.topbar a{color:#e5e7eb;font-size:14px}.container{max-width:1280px;margin:auto;padding:24px}.login{max-width:440px;margin:10vh auto}.card{background:white;border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:0 1px 3px rgba(0,0,0,.04)}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:18px}.two{display:grid;grid-template-columns:1fr 1fr;gap:18px}.label{color:var(--muted);font-size:13px}.value{font-size:28px;font-weight:800;margin-top:4px}h1{margin:0 0 18px}h2{margin-top:0}.card h2{margin-bottom:8px}input,select,textarea{width:100%;padding:10px 11px;border:1px solid #cfd4dc;border-radius:10px;background:white;font:inherit}textarea{min-height:92px}label{font-size:13px;color:#344054;display:block;margin-bottom:6px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.full{grid-column:1/-1}button,.btn{display:inline-block;padding:10px 14px;border-radius:10px;border:0;background:var(--primary);color:white;cursor:pointer;font-weight:700}.secondary{background:#475467}.danger{background:var(--danger)}table{width:100%;border-collapse:collapse;background:white;border:1px solid var(--line);border-radius:14px;overflow:hidden}th,td{padding:11px 12px;border-bottom:1px solid var(--line);vertical-align:top;text-align:left;font-size:14px}th{background:#f9fafb;color:#344054}.small{font-size:12px;color:var(--muted)}.status{display:inline-block;border:1px solid var(--line);border-radius:999px;padding:4px 8px;background:#f9fafb}.alert{padding:12px 14px;border-radius:10px;margin:0 0 14px}.ok{background:#ecfdf3;color:var(--ok);border:1px solid #abefc6}.err{background:#fef3f2;color:var(--danger);border:1px solid #fecdca}.warn{background:#fffaeb;color:var(--warn);border:1px solid #fedf89}.toolbar{display:flex;justify-content:space-between;align-items:end;gap:12px;flex-wrap:wrap;margin-bottom:16px}.filters{display:flex;gap:10px;align-items:end;flex-wrap:wrap}.docbox{height:720px;border:1px solid var(--line);border-radius:12px;background:#f9fafb;overflow:hidden}.docbox iframe{width:100%;height:100%;border:0}.pre{white-space:pre-wrap;background:#0b1020;color:#d0d5dd;border-radius:12px;padding:12px;max-height:360px;overflow:auto;font-size:12px}

.timeline-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:18px}.route-line{position:relative;margin-left:8px}.route-event{position:relative;display:flex;gap:12px;border-left:3px solid var(--line);padding:0 0 18px 18px}.route-event .dot{position:absolute;left:-9px;top:3px;width:15px;height:15px;border-radius:50%;background:white;border:3px solid var(--primary)}.route-event.done .dot{border-color:var(--ok);background:#ecfdf3}.event-body{background:#f9fafb;border:1px solid var(--line);border-radius:12px;padding:10px;width:100%}
.fill-badge{display:inline-block;border:1px solid var(--line);background:#f9fafb;border-radius:999px;padding:4px 8px;font-weight:800}.fill-panel{border:1px solid var(--line);background:#f9fafb;border-radius:12px;padding:12px}.fill-panel strong{font-size:16px}

.dashboard-timelines{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:18px;margin:0 0 18px}.truck-card-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;flex-wrap:wrap;margin-bottom:8px}.truck-meta{color:var(--muted);font-size:12px}.timeline-graphic{position:relative;padding:28px 10px 8px;margin:8px 0 14px}.timeline-rail{position:relative;height:4px;background:var(--line);border-radius:999px}.timeline-rail-fill{position:absolute;left:0;top:0;height:100%;background:linear-gradient(90deg,var(--ok),#32d583);border-radius:999px}.truck-marker{position:absolute;top:-14px;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:2px}.truck-marker .truck-icon{width:34px;height:34px;border-radius:999px;background:#111827;color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:0 2px 10px rgba(0,0,0,.15)}.truck-marker .truck-label{font-size:11px;color:var(--muted);background:white;border:1px solid var(--line);border-radius:999px;padding:2px 6px}.timeline-nodes{position:relative;height:0}.timeline-node{position:absolute;top:-8px;transform:translateX(-50%);width:18px;height:18px;border-radius:999px;border:3px solid var(--primary);background:#fff}.timeline-node.done{border-color:var(--ok);background:var(--ok-soft)}.timeline-node.pending{border-color:var(--warn);background:var(--pending-soft)}.timeline-node-label{position:absolute;top:16px;transform:translateX(-50%);width:120px;text-align:center}.timeline-node-label .node-time{font-size:11px;color:var(--muted);font-weight:700}.timeline-node-label .node-place{font-size:12px;font-weight:700;line-height:1.2;margin-top:2px}.timeline-node-label .node-kind{display:inline-block;margin-top:4px;padding:2px 6px;border:1px solid var(--line);border-radius:999px;font-size:11px;background:#fff}.timeline-node-label .node-fill{margin-top:4px}.timeline-spacer{height:90px}.truck-steps{display:grid;grid-template-columns:1fr;gap:10px}.truck-step{border:1px solid var(--line);border-radius:12px;padding:10px;background:#f9fafb}.truck-step.done{background:#f3fcf6;border-color:#b7e6c5}.truck-step.pending{background:#fffaf0;border-color:#f2d28b}.truck-step-top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.truck-step-title{font-weight:800}.truck-step-meta{margin-top:3px;color:var(--muted);font-size:12px}.section-stack{display:flex;flex-direction:column;gap:18px}.section-actions{display:flex;justify-content:space-between;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:8px}.subtle-link{font-size:12px}.muted-box{padding:10px 12px;border:1px dashed var(--line);border-radius:12px;background:#fafafa;color:var(--muted);font-size:13px}

@media(max-width:900px){.two{grid-template-columns:1fr}.docbox{height:420px}.timeline-spacer{height:110px}.dashboard-timelines{grid-template-columns:1fr}}
