:root{--font-sans: "IBM Plex Sans", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--r-xs: 4px;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-xl: 20px;--pad-x: 14px;--pad-y: 12px;--gap: 10px;--card-h: 96px;--row-h: 44px;--fs-xs: 10.5px;--fs-sm: 12px;--fs-md: 13.5px;--fs-lg: 16px;--fs-xl: 22px;--fs-xxl: 32px;--radius: 10px;--radius-sm: 6px;--sidebar-w: 220px;--t-fast: .12s cubic-bezier(.2, .7, .3, 1)}[data-density=compact]{--pad-x: 10px;--pad-y: 8px;--gap: 6px;--card-h: 76px;--row-h: 36px;--fs-xs: 10px;--fs-sm: 11px;--fs-md: 12.5px;--fs-lg: 14px;--fs-xl: 18px;--fs-xxl: 26px}[data-theme=dark],:root{--bg-0: #0A0D12;--bg-1: #11161F;--bg-2: #181F2B;--bg-3: #232D3D;--bg-elev: #1E2735;--line: rgba(255,255,255,.07);--line-strong: rgba(255,255,255,.14);--text-1: #E8EEF6;--text-2: #94A4B7;--text-3: #5C6B7E;--text-inv: #0A0D12;--ok: #36D399;--warn: #F2B144;--crit: #FF5C5C;--info: #6BB5FF;--shadow-card: 0 1px 0 rgba(255,255,255,.04) inset, 0 4px 16px rgba(0,0,0,.35);--shadow-pop: 0 24px 60px rgba(0,0,0,.55);--shadow-modal: var(--shadow-pop);--map-overlay: rgba(10,13,18,.65);color-scheme:dark;--text: var(--text-1);--text-muted: var(--text-2);--text-dim: var(--text-3);--border: var(--line);--border-strong: var(--line-strong)}[data-theme=light]{--bg-0: #F4F6F9;--bg-1: #FFFFFF;--bg-2: #F8FAFC;--bg-3: #EEF2F7;--bg-elev: #FFFFFF;--line: rgba(15,23,42,.08);--line-strong: rgba(15,23,42,.16);--text-1: #0E1726;--text-2: #4F5F77;--text-3: #8190A4;--text-inv: #FFFFFF;--ok: #15A35E;--warn: #D17806;--crit: #DA2A2A;--info: #1C7AD6;--shadow-card: 0 1px 2px rgba(15,23,42,.05), 0 4px 14px rgba(15,23,42,.06);--shadow-pop: 0 20px 50px rgba(15,23,42,.18);--shadow-modal: var(--shadow-pop);--map-overlay: rgba(255,255,255,.78);color-scheme:light}[data-accent=amber],:root{--accent: #F2A03A;--accent-2: #FFB95F;--accent-soft: rgba(242,160,58,.16);--accent-hover: var(--accent-2)}[data-accent=cyan]{--accent: #36C4D6;--accent-2: #6FE0EE;--accent-soft: rgba(54,196,214,.18);--accent-hover: var(--accent-2)}[data-accent=magenta]{--accent: #E5489B;--accent-2: #FF73B8;--accent-soft: rgba(229,72,155,.18);--accent-hover: var(--accent-2)}[data-accent=lime]{--accent: #C0E548;--accent-2: #DBFF73;--accent-soft: rgba(192,229,72,.18);--accent-hover: var(--accent-2)}:root{--tractor: var(--accent);--trailer: #F2B144}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;background:var(--bg-0);color:var(--text-1);font-family:var(--font-sans);font-feature-settings:"ss03","cv11";-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow:hidden}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}.mono{font-family:var(--font-mono);font-feature-settings:"zero","ss01"}.tnum{font-variant-numeric:tabular-nums}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-3)}.chip{display:inline-flex;align-items:center;gap:4px;height:18px;padding:0 6px;border-radius:4px;font-size:10px;font-weight:600;letter-spacing:.02em;text-transform:uppercase}.chip--accent{background:var(--accent-soft);color:var(--accent)}.chip--ok{background:#36d39924;color:var(--ok)}.chip--warn{background:#f2b14424;color:var(--warn)}.chip--crit{background:#ff5c5c24;color:var(--crit)}.chip--info{background:#6bb5ff24;color:var(--info)}.chip--muted{background:var(--bg-3);color:var(--text-2)}.dot{display:inline-block;width:6px;height:6px;border-radius:50%}.dot--ok{background:var(--ok);box-shadow:0 0 0 3px #36d3992e}.dot--warn{background:var(--warn);box-shadow:0 0 0 3px #f2b1442e}.dot--crit{background:var(--crit);box-shadow:0 0 0 3px #ff5c5c2e}.dot--muted{background:var(--text-3)}.kbd{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:4px;background:var(--bg-3);border:1px solid var(--line);font-family:var(--font-mono);font-size:10px;color:var(--text-2)}.flag{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:14px;padding:0 4px;border-radius:3px;background:var(--bg-3);font-family:var(--font-mono);font-size:9.5px;font-weight:700;color:var(--text-2);letter-spacing:.04em}@keyframes pulse{0%,to{box-shadow:0 0 0 0 var(--accent-soft)}50%{box-shadow:0 0 0 6px transparent}}.pulse{animation:pulse 1.8s ease-in-out infinite}.shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;height:100vh}.sidebar{background:var(--bg-1);border-right:1px solid var(--line);display:flex;flex-direction:column}.sidebar .brand{display:flex;align-items:center;gap:10px;padding:14px 16px;font-weight:600;font-size:14px;letter-spacing:-.01em;border-bottom:1px solid var(--line)}.sidebar .brand .mark{width:26px;height:26px;border-radius:6px;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:grid;place-items:center;color:var(--text-inv);font-family:var(--font-mono);font-weight:700;font-size:11px;letter-spacing:-.02em;box-shadow:0 4px 12px var(--accent-soft)}.sidebar .brand .name{font-weight:600}.sidebar .brand .name .mono{color:var(--text-3);font-weight:400}.sidebar nav{padding:8px;flex:1;overflow-y:auto}.sidebar .nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--r-sm);color:var(--text-2);font-size:13px;font-weight:500;cursor:pointer;transition:background var(--t-fast),color var(--t-fast);margin-bottom:1px}.sidebar .nav-item:hover{background:var(--bg-2);color:var(--text-1)}.sidebar .nav-item.active{background:var(--accent-soft);color:var(--accent)}.sidebar .nav-item .icon{font-size:15px;width:18px;text-align:center}.sidebar .nav-item .badge{margin-left:auto;font-size:10.5px;background:var(--crit);color:#fff;padding:1px 7px;border-radius:999px;font-weight:600}.user-pill{margin:8px;padding:10px 12px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-sm);display:flex;align-items:center;gap:10px}.user-pill .avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--text-inv);font-weight:700;font-size:11px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--font-mono)}.user-pill .info{flex:1;min-width:0}.user-pill .name{font-size:12.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-pill .role{font-size:10.5px;color:var(--text-3);text-transform:uppercase;letter-spacing:.04em}.user-pill .logout{background:transparent;border:0;color:var(--text-3);padding:4px 6px;border-radius:4px;font-size:14px;transition:var(--t-fast)}.user-pill .logout:hover{color:var(--crit);background:var(--bg-3)}.sidebar .foot{padding:12px 16px;border-top:1px solid var(--line);display:flex;align-items:center;gap:8px}.sidebar .foot select{flex:1;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-sm);padding:6px 10px;font-size:12px}.main{overflow:hidden;display:flex;flex-direction:column;background:var(--bg-0);height:100vh}.topbar{display:flex;align-items:center;gap:14px;height:56px;padding:0 18px;flex-shrink:0;background:var(--bg-1);border-bottom:1px solid var(--line);position:relative;z-index:10;white-space:nowrap}.topbar>*{flex-shrink:0}.tb-live{display:flex;align-items:center;gap:6px;height:28px;padding:0 10px;border-radius:999px;background:var(--accent-soft);color:var(--accent);font-size:11px;font-weight:600}.tb-search{display:flex;align-items:center;gap:8px;height:32px;padding:0 12px;border-radius:8px;background:var(--bg-2);color:var(--text-3);font-size:12px;min-width:220px}.tb-search:hover{background:var(--bg-3)}.tb-stat{display:flex;flex-direction:column;gap:0;line-height:1.1}.tb-stat-n{font-family:var(--font-mono);font-size:18px;font-weight:600;color:var(--text-1)}.tb-stat-l{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em}.tb-spacer{flex:1}.tb-icon-btn{width:32px;height:32px;border-radius:8px;display:grid;place-items:center;color:var(--text-2);background:transparent;border:0}.tb-icon-btn:hover{background:var(--bg-2);color:var(--text-1)}.tb-sep{width:1px;height:24px;background:var(--line)}.tb-time{font-family:var(--font-mono);font-size:12px;color:var(--text-2)}.page-head{height:56px;padding:0 24px;display:flex;align-items:center;gap:12px;background:var(--bg-1);border-bottom:1px solid var(--line)}.page-head h1{font-size:16px;font-weight:600;letter-spacing:-.01em;margin:0}.page-head .spacer{flex:1}.page-head .stat{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:var(--bg-2);border:1px solid var(--line);border-radius:999px;font-size:12px;color:var(--text-2)}.page-head .stat b{color:var(--text-1);font-weight:600}.page-head .stat.crit,.page-head .stat.crit b{color:var(--crit)}.page-body{flex:1;overflow-y:auto;padding:20px 24px}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:1px solid var(--line-strong);background:var(--bg-2);color:var(--text-1);border-radius:var(--r-sm);font-size:12.5px;font-weight:500;transition:var(--t-fast)}.btn:hover{background:var(--bg-3);border-color:var(--text-3)}.btn.primary{background:var(--accent);border-color:var(--accent);color:var(--text-inv)}.btn.primary:hover{background:var(--accent-2);border-color:var(--accent-2)}.btn.danger{color:var(--crit);border-color:var(--crit)}.btn.danger:hover{background:var(--crit);color:#fff}.btn.ghost{background:transparent;border-color:var(--line)}.btn.sm{padding:4px 10px;font-size:11.5px}.table{width:100%;border-collapse:collapse;background:var(--bg-1);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden}.table th,.table td{text-align:left;padding:10px 14px;border-bottom:1px solid var(--line);font-size:13px;vertical-align:middle}.table thead th{background:var(--bg-2);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-2)}.table tbody tr{transition:background var(--t-fast)}.table tbody tr:hover{background:var(--bg-2)}.table tbody tr:last-child td{border-bottom:0}.table .num{text-align:right;font-variant-numeric:tabular-nums;font-family:var(--font-mono)}.table .muted{color:var(--text-2)}.table .empty-row td{text-align:center;padding:40px;color:var(--text-3)}.pill{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;background:var(--bg-3);color:var(--text-2);border:1px solid var(--line)}.pill.active,.pill.ok,.pill.delivered,.pill.crossed,.pill.cleared,.pill.in_progress,.pill.paid{background:#36d39924;color:var(--ok);border-color:transparent}.pill.planned,.pill.en_route,.pill.assigned,.pill.sent{background:var(--accent-soft);color:var(--accent);border-color:transparent}.pill.at_border,.pill.loading,.pill.unloading,.pill.warn,.pill.overdue{background:#f2b14424;color:var(--warn);border-color:transparent}.pill.critical,.pill.cancelled,.pill.suspended{background:#ff5c5c24;color:var(--crit);border-color:transparent}.pill.tractor{background:var(--accent-soft);color:var(--accent);border-color:transparent}.pill.trailer{background:#f2b14424;color:var(--warn);border-color:transparent}.pill .dot{width:6px;height:6px;border-radius:50%;background:currentColor}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#05070ab3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;padding:24px;animation:fade var(--t-fast)}@keyframes fade{0%{opacity:0}to{opacity:1}}.modal{width:100%;max-width:480px;max-height:90vh;overflow-y:auto;background:var(--bg-1);border:1px solid var(--line-strong);border-radius:var(--r-md);box-shadow:var(--shadow-pop);animation:pop var(--t-fast)}.modal.wide{max-width:640px}@keyframes pop{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal .head{padding:14px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}.modal .head h2{margin:0;font-size:14.5px;font-weight:600}.modal .head .x{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:4px;color:var(--text-2);background:transparent;border:0}.modal .head .x:hover{background:var(--bg-3);color:var(--text-1)}.modal .body{padding:16px 18px}.modal .foot{padding:12px 18px;border-top:1px solid var(--line);display:flex;gap:8px;justify-content:flex-end}.form-row{margin-bottom:12px}.form-row.split{display:grid;grid-template-columns:1fr 1fr;gap:10px}.form-row label{display:block;font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-2);margin-bottom:4px}.field{display:block;width:100%;padding:9px 12px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-sm);font-size:13.5px;color:var(--text-1);transition:border-color var(--t-fast);font-family:var(--font-sans)}.field:focus{outline:none;border-color:var(--accent)}textarea.field{min-height:60px;resize:vertical}.empty{padding:60px 12px;text-align:center;color:var(--text-3);font-size:13px}.board{display:grid;grid-template-columns:320px 1fr 340px;grid-template-rows:1fr;height:calc(100vh - 56px);background:var(--bg-0);overflow:hidden;min-width:0}.board-pane{background:var(--bg-1);overflow:hidden;display:flex;flex-direction:column;border-right:1px solid var(--line)}.board-pane:last-child{border-right:0;border-left:1px solid var(--line)}.board-pane--map{background:var(--bg-0);position:relative}.board-pane--map>.map{position:absolute;top:0;right:0;bottom:0;left:0}.pane-body{flex:1;overflow-y:auto;padding:var(--gap);display:flex;flex-direction:column;gap:var(--gap)}.section-head{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--line);background:var(--bg-1)}.section-head h3{margin:0;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-2);display:flex;align-items:center;gap:6px}.section-head .right{margin-left:auto;display:flex;align-items:center;gap:4px}.asset-card{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-md);padding:var(--pad-y) var(--pad-x);cursor:pointer;transition:all .12s ease;position:relative;overflow:hidden}.asset-card:hover{background:var(--bg-3);border-color:var(--line-strong)}.asset-card.is-focused{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.asset-card--status{display:flex;flex-direction:column;gap:8px;padding:14px}.ac-status-row{display:flex;align-items:center;gap:8px}.ac-plate-big{font-size:16px;font-weight:700;color:var(--text-1);letter-spacing:.02em}.ac-hitchline{display:flex;align-items:center;gap:6px;color:var(--text-1);padding:6px 0;border-top:1px dashed var(--line);border-bottom:1px dashed var(--line)}.ac-bot-row{display:flex;align-items:center;justify-content:space-between}.ac-driver{display:flex;align-items:center;gap:8px;min-width:0}.ac-driver .name{font-size:12px;font-weight:600;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.ac-driver .meta{font-size:10px;color:var(--text-3)}.ac-metrics{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.ac-metric{display:flex;align-items:baseline;gap:3px}.ac-metric .mono{font-size:18px;font-weight:600;color:var(--text-1);line-height:1}.ac-metric .unit{font-size:9px;color:var(--text-3)}.ac-leg{display:flex;align-items:center;gap:6px;padding-top:6px;border-top:1px solid var(--line);font-size:10.5px;color:var(--text-2)}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0;color:#fff;font-weight:700;font-family:var(--font-mono);letter-spacing:-.02em}.fuel-bar{display:flex;align-items:center;gap:4px}.fuel-bar .bar{height:3px;background:var(--bg-3);border-radius:2px;overflow:hidden}.fuel-bar .fill{height:100%;background:var(--accent);transition:width var(--t-fast)}.fuel-bar .fill.low{background:var(--crit)}.fuel-bar .fill.med{background:var(--warn)}.fuel-bar .pct{font-size:9px;color:var(--text-3);font-family:var(--font-mono);font-variant-numeric:tabular-nums;min-width:22px;text-align:right}.map-controls{position:absolute;top:14px;left:14px;z-index:5;display:flex;flex-direction:column;gap:8px}.map-pill{background:var(--map-overlay);-webkit-backdrop-filter:blur(14px) saturate(160%);backdrop-filter:blur(14px) saturate(160%);border:1px solid var(--line);border-radius:10px;display:flex;padding:3px}.map-pill button{padding:5px 10px;border-radius:7px;font-size:11px;color:var(--text-2);background:transparent;border:0}.map-pill button.is-on{background:var(--accent);color:var(--text-inv);font-weight:600}.scrubber{position:absolute;left:18px;right:18px;bottom:18px;z-index:5;background:var(--map-overlay);-webkit-backdrop-filter:blur(14px) saturate(160%);backdrop-filter:blur(14px) saturate(160%);border:1px solid var(--line);border-radius:12px;padding:10px 14px;display:flex;align-items:center;gap:12px}.scrubber-track{flex:1;height:4px;background:var(--bg-3);border-radius:999px;position:relative;cursor:pointer}.scrubber-fill{position:absolute;left:0;top:0;bottom:0;background:var(--accent);border-radius:999px}.scrubber-handle{position:absolute;top:50%;transform:translate(-50%,-50%);width:12px;height:12px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}.scrubber-time{font-family:var(--font-mono);font-size:11px;color:var(--text-2);min-width:80px}.scrubber-play{width:28px;height:28px;border-radius:50%;background:var(--accent);color:var(--text-inv);display:grid;place-items:center;border:0}.maplibregl-popup-content{background:var(--bg-elev)!important;color:var(--text-1)!important;border:1px solid var(--line-strong);border-radius:var(--r-sm)!important;font-size:12px}.maplibregl-popup-tip{border-top-color:var(--bg-elev)!important}.maplibregl-ctrl button{background:var(--bg-2)!important}.maplibregl-ctrl button span{filter:invert(.9)}.marker{width:18px;height:18px;border-radius:50%;border:2px solid var(--bg-0);box-shadow:0 2px 8px #00000080;cursor:pointer;transition:transform var(--t-fast);display:grid;place-items:center;font-size:9px;font-weight:700;color:var(--text-inv)}.marker:hover{transform:scale(1.2)}.marker.tractor{background:var(--accent)}.marker.trailer{background:var(--warn)}.marker.offline{background:var(--text-3);border-color:var(--line);color:var(--text-2)}.trip-card{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;cursor:pointer;transition:background .12s ease,border-color .12s ease}.trip-card:hover{background:var(--bg-3)}.trip-card.is-active{border-color:var(--accent)}.trip-card.is-unassigned{border-style:dashed}.tc-head{display:flex;align-items:center;gap:8px;padding:10px var(--pad-x)}.tc-ref{font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--text-1)}.tc-customer{font-size:11px;color:var(--text-3);flex:1;min-width:0;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;text-align:right}.tc-route{display:flex;align-items:center;gap:6px;padding:0 var(--pad-x) 8px;font-size:11px;color:var(--text-2)}.tc-route .arrow{color:var(--text-3)}.tc-legs{display:flex;padding:0 var(--pad-x) 10px;gap:2px}.tc-leg-seg{flex:1;height:4px;border-radius:2px;background:var(--bg-3);position:relative;overflow:hidden}.tc-leg-seg.is-done{background:var(--ok)}.tc-leg-seg.is-active{background:var(--accent)}.tc-leg-seg.is-active:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.45),transparent);animation:legshimmer 1.8s linear infinite}@keyframes legshimmer{0%{transform:translate(-100%)}to{transform:translate(200%)}}.tc-meta{display:flex;align-items:center;gap:8px;padding:8px var(--pad-x);border-top:1px solid var(--line);font-size:10px;color:var(--text-3)}.tc-meta b{color:var(--text-2);font-weight:500}.alert-row{display:grid;grid-template-columns:28px 1fr auto;gap:10px;padding:10px 14px;border-bottom:1px solid var(--line);align-items:center}.alert-row:hover{background:var(--bg-2)}.alert-row.is-new{animation:alertenter .35s ease-out}@keyframes alertenter{0%{background:var(--accent-soft)}to{background:transparent}}.al-icon{width:28px;height:28px;border-radius:7px;display:grid;place-items:center;background:var(--bg-3);font-size:14px}.al-icon--high{background:#ff5c5c33;color:var(--crit)}.al-icon--med{background:#f2b14429;color:var(--warn)}.al-icon--low{background:#6bb5ff24;color:var(--info)}.al-title{font-size:12px;font-weight:600;color:var(--text-1)}.al-sub{font-size:10.5px;color:var(--text-3);display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:2px}.al-ack-btn{width:22px;height:22px;border-radius:5px;display:grid;place-items:center;background:var(--bg-3);color:var(--text-2);border:0}.al-ack-btn:hover{background:var(--accent);color:var(--text-inv)}.section-h2{font-size:11px;font-weight:600;letter-spacing:.06em;color:var(--text-3);text-transform:uppercase;margin:0 0 10px}.card{background:var(--bg-1);border:1px solid var(--line);border-radius:var(--r-md);padding:16px 18px;margin-bottom:12px}.card h3{margin:0 0 4px;font-size:13px;font-weight:600}.card p{margin:0;font-size:12.5px;color:var(--text-2)}.card .actions{margin-top:12px;display:flex;gap:8px}.leg-card{margin-bottom:10px}.timeline{padding:4px 0}.tl-row{display:grid;grid-template-columns:28px 1fr auto;gap:12px;padding-bottom:14px;position:relative}.tl-row:not(:last-child):after{content:"";position:absolute;left:13px;top:28px;bottom:0;width:2px;background:var(--line-strong)}.tl-dot{width:28px;height:28px;border-radius:50%;background:var(--bg-3);border:2px solid var(--bg-1);display:inline-flex;align-items:center;justify-content:center;font-size:13px;z-index:1}.tl-body{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-sm);padding:8px 12px}.tl-head{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:12px}.tl-meta{margin-top:4px;font-size:11px;color:var(--text-3);display:flex;gap:6px;align-items:center}.tl-meta .dot-sep{color:var(--text-3);margin:0 2px}.tl-note{margin-top:6px;font-size:12px;color:var(--text-1);background:var(--bg-1);padding:6px 10px;border-radius:4px;border-left:2px solid var(--accent)}.leg-row{display:grid;grid-template-columns:1fr 1fr 1.5fr 80px 32px;gap:8px;align-items:end;margin-bottom:8px}.leg-row .field{padding:7px 10px;font-size:12.5px}.leg-row .x-btn{height:34px;width:32px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-sm);color:var(--text-2);display:inline-flex;align-items:center;justify-content:center}.leg-row .x-btn:hover{color:var(--crit);border-color:var(--crit)}.qr-box{background:var(--bg-2);padding:12px;border-radius:var(--r-md);display:inline-block}.qr-box img{display:block}.qr-meta{margin-top:12px;font-size:12px;color:var(--text-2);font-family:var(--font-mono);word-break:break-all;background:var(--bg-2);padding:8px 10px;border-radius:var(--r-sm);border:1px solid var(--line)}.proof-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.proof-card{background:var(--bg-1);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;display:flex;flex-direction:column;transition:border-color var(--t-fast)}.proof-card:hover{border-color:var(--line-strong)}.proof-thumb{position:relative;background:var(--bg-2);aspect-ratio:16 / 10;display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden}.proof-thumb img{width:100%;height:100%;object-fit:cover}.proof-icon{font-size:42px;opacity:.6}.proof-kind-pill{position:absolute;left:8px;top:8px;background:#0f131ad9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:2px 8px;border-radius:999px;font-size:11px;color:var(--text-1);border:1px solid var(--line)}.proof-body{padding:10px 12px;font-size:12.5px}.proof-trip{font-weight:600;color:var(--accent);cursor:pointer}.proof-trip:hover{color:var(--accent-hover)}.proof-meta{margin-top:4px;font-size:11.5px;color:var(--text-2);display:flex;align-items:center;gap:4px}.proof-meta .dot-sep{color:var(--text-3);margin:0 2px}.proof-notes{margin-top:6px;background:var(--bg-2);padding:6px 10px;border-radius:4px;font-size:12px;border-left:2px solid var(--line-strong)}.proof-status{margin-top:8px;font-size:12px;font-weight:500;padding:4px 8px;border-radius:4px}.proof-status.ok{background:#36d39924;color:var(--ok)}.proof-status.reject{background:#ff5c5c24;color:var(--crit)}.proof-chip{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--bg-2);border:1px solid var(--line);border-radius:4px;font-size:13px}.proof-chip.ok{border-color:var(--ok)}.proof-chip.reject{border-color:var(--crit);opacity:.5}.proof-chip.pending{border-color:var(--warn);animation:pulse 2s ease-in-out infinite}
