: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)}@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.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-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}.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}.canvas{display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden;background:var(--bg-0)}.asset-card--list{display:grid;grid-template-columns:60px 1fr 80px;gap:10px;align-items:center}.asset-card--list .ac-left{display:flex;flex-direction:column;gap:4px;align-items:center;color:var(--text-1)}.asset-card--list .ac-mid{min-width:0;display:flex;flex-direction:column;gap:3px}.asset-card--list .ac-row1{display:flex;align-items:center;gap:6px}.asset-card--list .ac-row2{display:flex;align-items:center;gap:5px;min-width:0;font-size:11px;color:var(--text-2)}.asset-card--list .ac-row3{display:flex;align-items:center;gap:4px;padding-top:2px;border-top:1px dashed var(--line);font-size:10px;color:var(--text-2)}.asset-card--list .ac-plate{font-size:12px;font-weight:600;color:var(--text-1)}.asset-card--list .ac-right{display:flex;flex-direction:column;align-items:flex-end;gap:3px}.asset-card--list .ac-speed{display:flex;align-items:baseline;gap:3px}.asset-card--list .ac-speed .mono{font-size:18px;font-weight:600;color:var(--text-1);line-height:1}.asset-card--list .ac-unit{font-size:9px;color:var(--text-3)}.assets--grid{display:grid!important;grid-template-columns:repeat(2,1fr);gap:6px}.asset-card--grid{display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px;min-height:110px;color:var(--text-1)}.ac-grid-head{display:flex;align-items:center;justify-content:space-between;width:100%}.ac-plate-sm{font-size:11px;font-weight:600;color:var(--text-1)}.ac-grid-foot{display:flex;align-items:center;gap:6px;width:100%;justify-content:center}.asset-card.is-hovered{background:var(--bg-3)}.breadcrumb{display:flex;align-items:center;gap:10px;padding:12px 18px;background:var(--bg-1);border-bottom:1px solid var(--line)}.crumb-link{font-size:12px;color:var(--text-3);background:transparent;border:0;cursor:pointer;padding:0}.crumb-link:hover{color:var(--text-1)}.crumb-sep{color:var(--text-3)}.crumb-current{font-size:13px;color:var(--text-1);font-weight:600}.detail-grid{display:grid;grid-template-columns:1fr 380px;gap:16px;padding:18px;height:calc(100vh - 105px);overflow:hidden}.detail-main{background:var(--bg-1);border:1px solid var(--line);border-radius:var(--r-lg);overflow:auto}.detail-side{background:var(--bg-1);border:1px solid var(--line);border-radius:var(--r-lg);overflow:auto;display:flex;flex-direction:column}.detail-head{padding:18px;border-bottom:1px solid var(--line)}.kv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0}.kv-cell{padding:12px 14px;border-bottom:1px solid var(--line)}.kv-cell:nth-child(odd){border-right:1px solid var(--line)}.kv-label{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}.kv-val{font-size:13.5px;color:var(--text-1);font-weight:500}.kv-val.mono{font-family:var(--font-mono)}.tabs{display:flex;gap:2px;padding:0 18px;border-bottom:1px solid var(--line);background:var(--bg-1)}.tab{padding:11px 14px;font-size:12px;color:var(--text-3);border:0;background:transparent;cursor:pointer;border-bottom:2px solid transparent}.tab:hover{color:var(--text-1)}.tab.is-active{color:var(--text-1);border-bottom-color:var(--accent)}.tweaks{position:fixed;bottom:18px;right:18px;z-index:50;background:var(--bg-1);border:1px solid var(--line-strong);border-radius:var(--r-md);box-shadow:var(--shadow-pop);width:280px;overflow:hidden;font-size:12px}.tweaks .head{display:flex;align-items:center;gap:8px;padding:10px 12px;cursor:pointer;background:var(--bg-2);border-bottom:1px solid var(--line)}.tweaks .head .title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-2);flex:1}.tweaks .body{padding:12px;display:flex;flex-direction:column;gap:12px;max-height:70vh;overflow-y:auto}.tweaks .group{display:flex;flex-direction:column;gap:6px}.tweaks .group-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3)}.tweaks .radio-row{display:flex;gap:4px;flex-wrap:wrap}.tweaks .radio-row button{padding:5px 10px;border-radius:6px;font-size:11px;color:var(--text-2);background:var(--bg-3);border:0;cursor:pointer;transition:var(--t-fast)}.tweaks .radio-row button.is-on{background:var(--accent);color:var(--text-inv);font-weight:600}.tweaks .swatches{display:flex;gap:8px}.tweaks .swatch{width:24px;height:24px;border-radius:6px;border:2px solid transparent;cursor:pointer;transition:var(--t-fast)}.tweaks .swatch.is-on{border-color:var(--text-1)}.trailer-strip{display:flex;gap:6px;flex-wrap:wrap;padding:4px 0}.trailer-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:8px;background:var(--bg-2);border:1px solid var(--line);font-size:11px;cursor:pointer}.trailer-pill:hover{background:var(--bg-3)}.trailer-pill .mono{font-weight:600}.marker--plate{width:14px;height:14px;border-radius:50%;background:var(--accent);border:2px solid var(--bg-0);box-shadow:0 2px 6px #0006;cursor:pointer;transition:transform var(--t-fast),box-shadow var(--t-fast);font-size:0;line-height:0;position:relative}.marker--plate.is-trailer{background:var(--warn);width:12px;height:12px}.marker--plate.is-offline{background:var(--text-3)}.marker--plate.is-focused{box-shadow:0 0 0 4px var(--accent-soft),0 4px 12px #00000080;transform:scale(1.35)}.marker--plate:hover{transform:scale(1.3);box-shadow:0 0 0 3px var(--accent-soft),0 4px 10px #00000080}.marker--plate:after{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:50%;border:2px solid transparent;pointer-events:none}.marker--plate.is-moving{animation:pulse-marker 2s ease-in-out infinite}@keyframes pulse-marker{0%,to{box-shadow:0 0 0 0 var(--accent-soft),0 2px 6px #0006}50%{box-shadow:0 0 0 8px transparent,0 2px 6px #0006}}.marker--plate.is-focused.is-moving{animation:none}.tooltip{position:absolute;z-index:100;pointer-events:none;background:var(--bg-elev);color:var(--text-1);border:1px solid var(--line-strong);border-radius:8px;padding:8px 10px;font-size:11px;box-shadow:var(--shadow-pop);white-space:nowrap}.auth-shell{display:grid;grid-template-columns:1.1fr 1fr;height:100vh;min-height:700px;background:var(--bg-0);color:var(--text-1)}.auth-brand{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--bg-1) 0%,var(--bg-0) 100%);border-right:1px solid var(--line);display:flex;flex-direction:column}.auth-corridor{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:0;opacity:.85}.auth-brand-inner{position:relative;z-index:1;display:flex;flex-direction:column;padding:48px 56px;height:100%}.auth-logo{display:flex;align-items:center;gap:12px;flex-shrink:0}.auth-logo>div{white-space:nowrap}.auth-brand-headline{flex:1;display:flex;flex-direction:column;justify-content:center;margin:-40px 0}.auth-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:24px 0;border-top:1px solid var(--line)}.auth-stat{display:flex;flex-direction:column;gap:4px}.auth-foot{display:flex;align-items:center;gap:10px;font-size:11px;color:var(--text-3)}.auth-form-pane{display:flex;flex-direction:column;padding:56px 48px 24px;overflow:auto;position:relative}.auth-form-inner{width:100%;max-width:380px;margin:auto;display:flex;flex-direction:column;gap:14px}.auth-langs{position:absolute;top:18px;right:24px;display:flex;gap:4px;background:var(--bg-2);border:1px solid var(--line);border-radius:8px;padding:3px}.auth-lang{font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--text-3);padding:4px 8px;border-radius:5px;background:transparent;border:0;cursor:pointer}.auth-lang:hover{color:var(--text-1)}.auth-lang.is-on{background:var(--accent);color:#0a0d12;font-weight:700}.auth-title{font-size:26px;font-weight:600;letter-spacing:-.01em;line-height:1.2;margin-top:8px}.auth-sub{font-size:13px;color:var(--text-2);line-height:1.55;margin-bottom:8px}.auth-back-link{font-size:11px;color:var(--text-3);background:transparent;border:0;cursor:pointer;align-self:flex-start;margin-bottom:-8px;padding:0}.auth-back-link:hover{color:var(--text-1)}.auth-form{display:flex;flex-direction:column;gap:14px}.auth-field{display:flex;flex-direction:column;gap:6px}.auth-field-head{display:flex;align-items:center;justify-content:space-between;font-size:11px;color:var(--text-3);font-weight:500;text-transform:uppercase;letter-spacing:.06em}.auth-field input,.auth-field select{height:40px;padding:0 12px;background:var(--bg-2);border:1px solid var(--line);border-radius:8px;color:var(--text-1);font-size:14px;outline:none;transition:border-color .12s,background .12s}.auth-field input:focus{border-color:var(--accent);background:var(--bg-1);box-shadow:0 0 0 3px var(--accent-soft)}.auth-row{display:flex;align-items:center;gap:12px}.auth-check{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:12px;color:var(--text-2)}.auth-check input{display:none}.auth-check .check-box{width:16px;height:16px;border-radius:4px;background:var(--bg-2);border:1.5px solid var(--line-strong);flex:0 0 auto;display:grid;place-items:center;transition:all .12s}.auth-check input:checked+.check-box{background:var(--accent);border-color:var(--accent)}.auth-check input:checked+.check-box:after{content:"";width:8px;height:4px;border-left:2px solid #0a0d12;border-bottom:2px solid #0a0d12;transform:rotate(-45deg) translate(1px,-1px)}.auth-primary{height:44px;background:var(--accent);color:#0a0d12;font-size:14px;font-weight:700;border-radius:10px;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .12s,transform .06s;border:0;cursor:pointer}.auth-primary:hover:not(:disabled){background:var(--accent-2)}.auth-primary:active:not(:disabled){transform:scale(.98)}.auth-primary:disabled{background:var(--bg-3);color:var(--text-3);cursor:not-allowed}.auth-secondary{height:44px;background:var(--bg-2);color:var(--text-1);border:1px solid var(--line-strong);font-size:13px;font-weight:600;border-radius:10px;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer}.auth-secondary:hover{background:var(--bg-3)}.auth-spinner{width:14px;height:14px;border-radius:50%;border:2px solid rgba(10,13,18,.3);border-top-color:#0a0d12;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-or{display:flex;align-items:center;gap:12px;font-size:11px;color:var(--text-3);margin:6px 0}.auth-or:before,.auth-or:after{content:"";flex:1;height:1px;background:var(--line)}.auth-sso{display:flex;flex-direction:column;gap:8px}.auth-sso-btn{display:flex;align-items:center;justify-content:center;gap:10px;height:38px;padding:0 14px;background:var(--bg-2);border:1px solid var(--line);border-radius:8px;font-size:13px;color:var(--text-1);cursor:pointer}.auth-sso-btn:hover{background:var(--bg-3)}.auth-policy{font-size:11px;color:var(--text-3);line-height:1.5;margin-top:4px}.auth-policy a{color:var(--accent)}.auth-mode-switch{display:flex;align-items:center;justify-content:center;gap:6px;padding-top:18px;border-top:1px solid var(--line);font-size:12px;color:var(--text-3)}.auth-mode-switch button{color:var(--accent);font-weight:600;background:transparent;border:0;cursor:pointer}.otp-row{display:flex;gap:8px;margin:14px 0 18px}.otp-cell{flex:1;min-width:0;height:54px;text-align:center;background:var(--bg-2);border:1px solid var(--line-strong);border-radius:10px;color:var(--text-1);font-size:22px;font-weight:600;outline:none;font-family:var(--font-mono)}.otp-cell:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.reg-steps{display:flex;align-items:center;gap:0;margin-bottom:4px}.reg-step{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;background:var(--bg-2);border:1.5px solid var(--line-strong);font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--text-3)}.reg-step.is-done{background:var(--accent);color:#0a0d12;border-color:var(--accent)}.reg-step.is-active{background:var(--accent);color:#0a0d12;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.reg-step-line{flex:1;height:2px;background:var(--bg-3)}.reg-step-line.is-done{background:var(--accent)}.invite-meta{background:var(--bg-2);border:1px solid var(--line);border-radius:10px;padding:10px 14px;display:flex;flex-direction:column;gap:6px}.kv-inline{display:flex;align-items:baseline;gap:8px}.kv-inline-l{font-size:11px;color:var(--text-3);width:100px;flex-shrink:0}.kv-inline-v{font-size:12px;color:var(--text-1)}.tg-card{display:flex;gap:16px;align-items:center;background:var(--bg-2);border:1px solid var(--line);border-radius:12px;padding:16px}.tg-qr{width:110px;height:110px;padding:6px;background:#fff;border-radius:8px;flex-shrink:0}.settings-grid{display:grid;grid-template-columns:240px 1fr;gap:0;flex:1;overflow:hidden;background:var(--bg-0);height:100%}.settings-nav{background:var(--bg-1);border-right:1px solid var(--line);padding:16px 12px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.settings-nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;color:var(--text-2);font-size:13px;text-align:left;transition:background .1s;background:transparent;border:0;cursor:pointer}.settings-nav-item:hover{background:var(--bg-2);color:var(--text-1)}.settings-nav-item.is-on{background:var(--accent-soft);color:var(--accent);font-weight:600}.settings-nav-icon{display:grid;place-items:center;flex:0 0 auto}.settings-nav-divider{height:1px;background:var(--line);margin:10px 4px}.settings-nav-logout{color:var(--crit)}.settings-nav-logout:hover{background:#ff5c5c1a;color:var(--crit)}.settings-main{overflow-y:auto;padding:28px 32px;display:flex;flex-direction:column;gap:18px;max-width:880px}.settings-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.settings-title{font-size:22px;font-weight:600;letter-spacing:-.01em;margin:0}.settings-subtitle{font-size:12.5px;color:var(--text-3);margin:4px 0 0}.settings-card{background:var(--bg-1);border:1px solid var(--line);border-radius:12px;overflow:hidden}.settings-card-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--line)}.settings-card-title{font-size:13px;font-weight:600;margin:0;letter-spacing:.01em}.settings-card-sub{font-size:11px;color:var(--text-3);margin:4px 0 0}.settings-card-body{padding:14px 18px;display:flex;flex-direction:column;gap:10px}.field-row{display:grid;grid-template-columns:180px 1fr;align-items:center;padding:11px 18px;border-bottom:1px solid var(--line);font-size:13px}.field-row:last-child{border-bottom:0}.field-row-label{font-size:12px;color:var(--text-3)}.field-row-val{color:var(--text-1);display:flex;align-items:center;gap:8px}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0}.toggle-row+.toggle-row{border-top:1px solid var(--line)}.settings-card-body>.toggle-row:first-child{padding-top:0}.settings-card-body>.toggle-row:last-child{padding-bottom:0}.toggle-row-label{font-size:13px;font-weight:500}.toggle-row-sub{font-size:11px;color:var(--text-3);margin-top:2px}.toggle{width:36px;height:20px;border-radius:999px;background:var(--bg-3);transition:background .15s;position:relative;flex:0 0 auto;border:0;cursor:pointer}.toggle.is-on{background:var(--accent)}.toggle-knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:var(--text-1);transition:transform .15s}.toggle.is-on .toggle-knob{background:#0a0d12;transform:translate(16px)}.btn-primary{background:var(--accent);color:#0a0d12;font-weight:700;padding:8px 14px;border-radius:8px;font-size:12.5px;display:inline-flex;align-items:center;gap:6px;border:0;cursor:pointer}.btn-primary:hover{background:var(--accent-2)}.btn-secondary{background:var(--bg-2);color:var(--text-1);border:1px solid var(--line-strong);padding:8px 14px;border-radius:8px;font-size:12.5px;font-weight:500;display:inline-flex;align-items:center;gap:6px;cursor:pointer}.btn-secondary:hover{background:var(--bg-3)}.btn-ghost{color:var(--text-2);padding:8px 14px;border-radius:8px;font-size:12.5px;background:transparent;border:0;cursor:pointer}.btn-ghost:hover{background:var(--bg-2);color:var(--text-1)}.account-hero{display:flex;align-items:center;gap:18px}.tg-bot-card{display:flex;align-items:center;gap:14px;padding:12px 14px;background:var(--bg-2);border:1px solid var(--line);border-radius:10px}.fleet-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.fleet-stat{background:var(--bg-2);border:1px solid var(--line);border-radius:10px;padding:14px;display:flex;flex-direction:column;gap:4px}.fleet-stat--ok{border-left:3px solid var(--ok)}.fleet-stat--warn{border-left:3px solid var(--warn)}.fleet-stat--info{border-left:3px solid var(--info)}.fleet-stat--muted{border-left:3px solid var(--text-3)}.lang-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.lang-card{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;background:var(--bg-2);border:1px solid var(--line);cursor:pointer;transition:all .12s}.lang-card:hover{border-color:var(--line-strong);background:var(--bg-3)}.lang-card.is-on{border-color:var(--accent);background:var(--accent-soft)}.seg-control{display:inline-flex;padding:3px;background:var(--bg-2);border:1px solid var(--line);border-radius:8px}.seg-control button{padding:5px 12px;border-radius:5px;font-size:12px;color:var(--text-2);background:transparent;border:0;cursor:pointer}.seg-control button.is-on{background:var(--accent);color:#0a0d12;font-weight:600}.ac-open-cta{position:absolute;top:0;right:0;width:22px;height:22px;background:var(--accent);color:#0a0d12;display:grid;place-items:center;border-bottom-left-radius:8px;border:0;cursor:pointer}.ac-open-cta:hover{background:var(--accent-2)}.asset-card{position:relative;overflow:hidden}.mobile-header,.tabbar,.more-sheet-bg,.board-segments,.cards{display:none}.card-row{background:var(--bg-1);border:1px solid var(--line);border-radius:var(--r-md);padding:12px 14px;margin-bottom:10px;display:flex;flex-direction:column;gap:8px;font-size:13px;list-style:none}.card-row .cr-head{display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px;color:var(--text-1)}.card-row .cr-head .grow{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card-row .cr-meta{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px;font-size:12px;color:var(--text-2)}.card-row .cr-meta .lbl{color:var(--text-3);font-size:10.5px;text-transform:uppercase;letter-spacing:.04em}.card-row .cr-meta .val{color:var(--text-1);font-weight:500}.card-row .cr-actions{display:flex;gap:8px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:8px;margin-top:2px}.card-row .cr-actions .btn{flex:1;justify-content:center;min-height:36px}@media (max-width: 768px){.shell{grid-template-columns:1fr;height:100vh}.sidebar{display:none}.main{padding-bottom:calc(56px + env(safe-area-inset-bottom))}.mobile-header{display:flex;align-items:center;gap:10px;height:48px;padding:0 14px;background:var(--bg-1);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}.mh-brand{display:flex;align-items:center;gap:8px;cursor:pointer}.mh-name{font-weight:700;font-size:13px;letter-spacing:-.01em}.mh-spacer{flex:1}.mh-alert{position:relative;width:38px;height:38px;border-radius:999px;background:var(--bg-2);border:1px solid var(--line);display:grid;place-items:center;color:var(--text-1)}.mh-alert .mh-badge{position:absolute;top:-4px;right:-4px;background:var(--crit);color:#fff;font-size:10px;font-weight:700;border-radius:999px;padding:1px 5px;min-width:16px;text-align:center}.mh-avatar{width:38px;height:38px;border-radius:999px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--text-inv);font-weight:700;font-size:12px;border:0;display:grid;place-items:center;font-family:var(--font-mono)}.tabbar{display:flex;align-items:stretch;position:fixed;left:0;right:0;bottom:0;height:calc(56px + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);background:var(--bg-1);border-top:1px solid var(--line);z-index:30}.tabbar .tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:transparent;border:0;color:var(--text-3);font-size:10px;font-weight:500;padding:6px 4px;min-height:44px;position:relative}.tabbar .tab.active{color:var(--accent)}.tabbar .tab .tab-icon{display:grid;place-items:center;height:20px}.tabbar .tab .tab-label{line-height:1;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tabbar .tab .tab-badge{position:absolute;top:4px;right:calc(50% - 16px);background:var(--crit);color:#fff;font-size:9px;font-weight:700;border-radius:999px;padding:1px 4px;min-width:14px;text-align:center}.more-sheet-bg{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:40;animation:fadeIn .15s ease}.more-sheet{position:absolute;left:0;right:0;bottom:0;background:var(--bg-1);border-top-left-radius:16px;border-top-right-radius:16px;padding:8px 14px calc(20px + env(safe-area-inset-bottom));box-shadow:0 -12px 40px #0006;animation:slideUp .2s ease;max-height:80vh;overflow-y:auto}.more-grab{width:40px;height:4px;border-radius:2px;background:var(--line-strong);margin:6px auto 14px}.more-user{display:flex;align-items:center;gap:12px;padding:10px 12px;margin-bottom:12px;background:var(--bg-2);border-radius:var(--r-md)}.more-user .avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--text-inv);font-weight:700;display:grid;place-items:center;font-family:var(--font-mono)}.more-user .info{flex:1;min-width:0}.more-user .name{font-weight:600;font-size:14px}.more-user .role{font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:.04em}.more-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:12px}.more-item{display:flex;align-items:center;gap:10px;padding:14px 12px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-md);font-size:13px;font-weight:500;color:var(--text-1);min-height:48px}.more-item.active{background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}.more-icon{display:grid;place-items:center;width:20px}.more-row{display:flex;gap:10px;align-items:stretch}.more-row select{flex:1;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-md);padding:12px;font-size:13px;color:var(--text-1)}.more-logout{flex:1;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-md);padding:12px;color:var(--crit);font-weight:600;font-size:13px;display:inline-flex;align-items:center;justify-content:center;gap:8px}.page-head{padding:0 14px;gap:8px;height:52px}.page-head h1{font-size:15px}.page-head .stat{padding:3px 8px;font-size:11px}.page-body{padding:12px 14px}.table{font-size:12px}.table th,.table td{padding:8px 10px}.page-body>.table,.page-body>.table-wrap{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.page-body.has-cards>.table{display:none}.page-body.has-cards>.cards{display:block;padding:0;margin:0}.form-row.split{grid-template-columns:1fr}.modal{width:calc(100vw - 24px);max-width:none;margin:12px;max-height:calc(100vh - 24px);overflow-y:auto}.modal.wide{max-width:none}.modal .head,.modal .body{padding:14px 16px}.modal .foot{padding:12px 16px;flex-wrap:wrap;gap:8px}.modal .foot .btn{flex:1;min-height:40px;justify-content:center}.btn{min-height:36px;padding:8px 14px;font-size:13px}.btn.sm{min-height:32px;padding:6px 12px;font-size:12px}.detail-grid{grid-template-columns:1fr;grid-auto-rows:auto;height:auto;padding:12px;gap:12px;overflow:visible}.detail-grid .map{height:240px}.proof-grid,.grid-cards{grid-template-columns:1fr!important}.auth-shell{grid-template-columns:1fr;min-height:0;height:100vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.auth-shell .auth-brand{display:none}.auth-shell .auth-form-pane{padding:28px 20px calc(28px + env(safe-area-inset-bottom));overflow:visible;min-height:100vh}.topbar{height:48px;padding:0 10px;gap:6px;overflow-x:auto}.topbar .tb-logo .name,.topbar .tb-search,.topbar .tb-time{display:none}.topbar .tb-spacer{flex:0 0 8px}.topbar .tb-stat-n{font-size:14px}.topbar .tb-stat-l{font-size:9px}.topbar .tb-icon-btn{width:34px;height:34px}.board-segments{display:flex;gap:4px;padding:8px 12px;background:var(--bg-1);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5}.board-segments button{flex:1;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-sm);padding:10px;min-height:40px;color:var(--text-2);font-size:12px;font-weight:600}.board-segments button.active{background:var(--accent);color:var(--text-inv);border-color:var(--accent)}.canvas{height:100vh;padding-bottom:calc(56px + env(safe-area-inset-bottom))}.board{grid-template-columns:1fr;grid-template-rows:auto 1fr;height:calc(100vh - 104px - env(safe-area-inset-bottom));position:relative}.board>.board-pane{position:absolute;left:0;right:0;top:56px;bottom:0;border-right:0;border-left:0;visibility:hidden}.board[data-mview=list]>.board-pane[data-pane=list]{visibility:visible}.board[data-mview=map]>.board-pane[data-pane=map]{visibility:visible}.board[data-mview=info]>.board-pane[data-pane=info]{visibility:visible}.scrubber{padding:6px 10px}.tweaks-panel{display:none}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.rp-section-head{display:flex;align-items:center;gap:8px;padding:14px 16px 10px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-2)}.rp-section-head .icon{display:flex}.rp-section-head .grow{flex:1}.rp-section-head.crit{color:var(--crit)}.rp-section-head .sim-btn{font-size:11px;padding:4px 10px;border-radius:6px;background:var(--bg-3);color:var(--text-2);border:0;cursor:pointer;display:inline-flex;align-items:center;gap:4px}.rp-section-head .sim-btn:hover{color:var(--text-1)}.rp-section-head .sim-btn.is-on{background:var(--accent);color:var(--text-inv)}.rp-group-head{padding:14px 16px 6px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);display:flex;align-items:center;gap:6px;cursor:pointer;-webkit-user-select:none;user-select:none}.rp-group-head .arrow{transition:transform .15s;display:inline-block}.rp-group-head.collapsed .arrow{transform:rotate(-90deg)}.alert-row{display:grid;grid-template-columns:36px 1fr 32px;gap:10px;padding:10px 16px;align-items:center;border-bottom:1px solid var(--line)}.alert-row:hover{background:var(--bg-2)}.alert-row.is-acked{opacity:.45}.al-icon{width:36px;height:36px;border-radius:8px;display:grid;place-items:center}.al-icon--high{background:#ff5c5c29;color:var(--crit)}.al-icon--med{background:#f2b14424;color:var(--warn)}.al-icon--low{background:#6bb5ff24;color:var(--info)}.al-title{font-size:14px;font-weight:600;color:var(--text-1);letter-spacing:-.01em;line-height:1.2}.al-sub{display:flex;flex-wrap:wrap;align-items:baseline;gap:6px;font-size:12px;color:var(--text-3);margin-top:4px}.al-sub .plate{font-family:var(--font-mono);color:var(--text-1);font-weight:600;font-size:13px}.al-sub .metric{color:var(--crit);font-weight:700;font-size:14px;font-family:var(--font-mono)}.al-sub .metric.warn{color:var(--warn)}.al-sub .metric.info{color:var(--info)}.al-sub .ts{font-family:var(--font-mono)}.al-sub .sep{color:var(--text-3)}.al-ack-btn{width:32px;height:32px;border-radius:8px;display:grid;place-items:center;background:var(--bg-3);color:var(--text-2);border:0;cursor:pointer;transition:var(--t-fast)}.al-ack-btn:hover{background:var(--accent);color:var(--text-inv)}.alert-row.is-acked .al-ack-btn{opacity:.4;pointer-events:none}.trip-card{background:var(--bg-2);border:1px solid var(--line);border-radius:14px;margin:0 12px 8px;padding:14px 14px 12px;cursor:pointer;transition:background .12s,border-color .12s}.trip-card:hover{background:var(--bg-3);border-color:var(--line-strong)}.tc-row1{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:8px}.tc-ref{font-family:var(--font-mono);font-size:14px;font-weight:700;color:var(--text-1);letter-spacing:-.01em}.tc-customer{margin-left:auto;font-size:11px;color:var(--text-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.tc-pill{display:inline-flex;align-items:center;height:20px;padding:0 9px;border-radius:5px;font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}.tc-pill.high{background:#ff5c5c2e;color:var(--crit)}.tc-pill.normal{background:#6bb5ff24;color:var(--info)}.tc-pill.atborder{background:#f2b1442e;color:var(--warn)}.tc-pill.delivered{background:#36d39929;color:var(--ok)}.tc-pill.unassigned{background:#f2b1442e;color:var(--warn)}.tc-pill.cancelled{background:var(--bg-3);color:var(--text-2)}.tc-route{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--text-1);margin-bottom:10px}.tc-route .chev{color:var(--text-3)}.tc-legs{display:flex;gap:4px}.tc-leg-seg{flex:1;height:6px;border-radius:999px;background:var(--bg-3);position:relative;overflow:hidden}.tc-leg-seg.is-done{background:var(--ok);box-shadow:0 0 6px #36d39966}.tc-leg-seg.is-active{background:var(--warn);box-shadow:0 0 8px #f2b14473}.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}.tc-leg-seg.is-cancelled{background:#ff5c5c2e}.tc-meta{display:none}
