@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Sans:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap";@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600;700&display=swap&subset=cyrillic,cyrillic-ext,latin,latin-ext";: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}[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]{--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);--map-overlay: rgba(10,13,18,.65);color-scheme:dark}[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);--map-overlay: rgba(255,255,255,.78);color-scheme:light}[data-theme=contrast]{--bg-0: #000000;--bg-1: #0A0A0A;--bg-2: #141414;--bg-3: #1F1F1F;--bg-elev: #1A1A1A;--line: rgba(255,255,255,.18);--line-strong: rgba(255,255,255,.35);--text-1: #FFFFFF;--text-2: #C7C7C7;--text-3: #8C8C8C;--text-inv: #000000;--ok: #00FF95;--warn: #FFC842;--crit: #FF3D3D;--info: #5BE3FF;--shadow-card: 0 0 0 1px rgba(255,255,255,.06);--shadow-pop: 0 12px 40px rgba(0,0,0,.8);--map-overlay: rgba(0,0,0,.78);color-scheme:dark}[data-accent=amber]{--accent: #F2A03A;--accent-2: #FFB95F;--accent-soft: rgba(242,160,58,.16)}[data-accent=cyan]{--accent: #36C4D6;--accent-2: #6FE0EE;--accent-soft: rgba(54,196,214,.18)}[data-accent=magenta]{--accent: #E5489B;--accent-2: #FF73B8;--accent-soft: rgba(229,72,155,.18)}[data-accent=lime]{--accent: #C0E548;--accent-2: #DBFF73;--accent-soft: rgba(192,229,72,.18)}*{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}button,input,select,textarea{font:inherit;color:inherit}button{background:transparent;border:0;cursor:pointer;padding:0}.mono{font-family:var(--font-mono);font-feature-settings:"zero","ss01"}.tnum{font-variant-numeric:tabular-nums}.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;white-space:nowrap;flex:0 0 auto}.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)}.divider{height:1px;background:var(--line)}.vline{width:1px;background:var(--line);align-self:stretch}.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)}@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}@keyframes blip{0%{transform:scale(1);opacity:1}to{transform:scale(2.4);opacity:0}}.leaflet-container{background:var(--bg-1)!important;font-family:var(--font-sans)!important;isolation:isolate}.leaflet-tile{opacity:1!important}[data-theme=dark] .leaflet-container[data-tile-variant=real] .leaflet-tile,[data-theme=contrast] .leaflet-container[data-tile-variant=real] .leaflet-tile{filter:invert(1) hue-rotate(180deg) brightness(.9) saturate(.6)}.leaflet-control-attribution{background:#0006!important;color:#ffffff80!important;font-size:9px!important}[data-theme=light] .leaflet-control-attribution{background:#ffffffd9!important;color:var(--text-3)!important}.leaflet-control-zoom{display:none!important}::-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)}.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-logo{display:flex;align-items:center;gap:8px;white-space:nowrap}.tb-logo-mark{width:28px;height:28px;border-radius:7px;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:grid;place-items:center;color:#0a0d12;font-weight:700;font-family:var(--font-mono);font-size:12px;letter-spacing:-.02em;box-shadow:0 4px 12px var(--accent-soft)}.tb-logo-text{font-weight:600;font-size:15px;letter-spacing:-.01em}.tb-logo-text .mono{color:var(--text-3);font-weight:400}.tb-sep{width:1px;height:24px;background:var(--line)}.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)}.tb-icon-btn:hover{background:var(--bg-2);color:var(--text-1)}.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-time{font-family:var(--font-mono);font-size:12px;color:var(--text-2)}.tb-page-title{font-size:16px;font-weight:600;letter-spacing:-.01em;color:var(--text-1);white-space:nowrap}.lang-select{position:relative;flex:0 0 auto}.lang-select-btn{display:flex;align-items:center;gap:7px;height:32px;padding:0 10px;border-radius:8px;background:var(--bg-2);border:1px solid var(--line);color:var(--text-1);font-size:12.5px;font-weight:500}.lang-select-btn:hover{background:var(--bg-3);border-color:var(--line-strong)}.lang-select-name{white-space:nowrap}.lang-select-menu{position:absolute;top:calc(100% + 6px);right:0;z-index:1000;min-width:168px;padding:5px;background:var(--bg-elev);border:1px solid var(--line-strong);border-radius:11px;box-shadow:var(--shadow-pop);display:flex;flex-direction:column;gap:2px;animation:langmenu .14s ease-out}@keyframes langmenu{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.lang-select-item{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:7px;width:100%;text-align:left;font-size:13px;color:var(--text-2)}.lang-select-item:hover{background:var(--bg-2);color:var(--text-1)}.lang-select-item.is-on{color:var(--text-1);font-weight:600;background:var(--accent-soft)}.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;isolation:isolate}.board-pane--map>div:first-child{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)}.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.is-droptarget{border-color:var(--accent);border-style:dashed;background:var(--accent-soft)}.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}.ac-open-cta:hover{background:var(--accent-2)}.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}.asset-card--list .ac-glyph{position:relative;color:var(--text-1);display:flex;align-items:center;gap:2px}.asset-card--list .ac-trailer-mini{color:var(--text-3);opacity:.7}.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}.asset-card--list .ac-row3{display:flex;align-items:center;gap:4px;padding-top:2px;border-top:1px dashed var(--line)}.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}.assets--status{display:flex!important;flex-direction:column;gap:8px}.asset-card--status{display:flex;flex-direction:column;gap:8px;padding:14px;border-radius:var(--r-md)}.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:4px;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}.ac-metrics{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.ac-metric{display:flex;align-items:baseline;gap:3px}.ac-leg{display:flex;align-items:center;gap:6px;padding-top:6px;border-top:1px solid var(--line);min-width:0}.ac-plate,.ac-plate-big,.ac-plate-sm{white-space:nowrap}.ac-leg,.asset-card--list .ac-row3{flex-wrap:wrap;row-gap:2px}.ac-leg>span,.asset-card--list .ac-row3>span{white-space:nowrap}.asset-card--list .ac-row2{flex-wrap:nowrap;overflow:hidden}.asset-card--list .ac-row2>span{white-space:nowrap}.asset-card--list .ac-row2>span:nth-of-type(1){overflow:hidden;text-overflow:ellipsis;min-width:0;flex:0 1 auto}.asset-card--list .ac-row2>.mono{flex-shrink:0}.trailer-strip{display:flex;gap:6px;overflow-x:auto;padding:4px 0}.trailer-pill{flex:0 0 auto;display: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:grab}.trailer-pill:hover{background:var(--bg-3)}.trailer-pill .mono{font-weight:600}.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}.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;bottom:0;left:0;right:60%;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(400%)}}.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:24px 1fr auto;gap:8px;padding:10px var(--pad-x);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:24px;height:24px;border-radius:6px;display:grid;place-items:center;background:var(--bg-3)}.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}.al-ack-btn{width:22px;height:22px;border-radius:5px;display:grid;place-items:center;background:var(--bg-3);color:var(--text-2)}.al-ack-btn:hover{background:var(--accent);color:#0a0d12}.al-ack{opacity:.4}.scrubber{position:absolute;left:14px;right:14px;bottom:14px;z-index:700;background:var(--bg-elev);border:1px solid var(--line-strong);border-radius:12px;padding:10px 14px;display:flex;align-items:center;gap:12px;box-shadow:0 8px 24px #0006}.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:#0a0d12;display:grid;place-items:center}.map-controls{position:absolute;top:14px;left:14px;z-index:700;display:flex;flex-direction:column;gap:8px}.map-pill{background:var(--bg-elev);border:1px solid var(--line-strong);border-radius:10px;display:flex;padding:3px;box-shadow:0 4px 20px #0006}.map-pill button{padding:5px 10px;border-radius:7px;font-size:11px;color:var(--text-2);font-weight:500;white-space:nowrap}.map-pill button:hover{color:var(--text-1)}.map-pill button.is-on{background:var(--accent);color:#0a0d12;font-weight:600}.page-head{display:flex;align-items:center;gap:10px;padding:12px 18px;background:var(--bg-1);border-bottom:1px solid var(--line);white-space:nowrap;flex-shrink:0}.page-head>*{flex-shrink:0}.crumb-link{font-size:12px;color:var(--text-3)}.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:100%;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;gap:0}.kv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0}.kv-cell{padding:12px var(--pad-x);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)}.timeline{padding:18px var(--pad-x)}.tl-row{display:grid;grid-template-columns:28px 1fr auto;gap:12px;position:relative}.tl-row:not(:last-child){padding-bottom:24px}.tl-row:not(:last-child):before{content:"";position:absolute;left:13px;top:22px;bottom:-2px;width:2px;background:var(--line-strong)}.tl-row.is-done:before{background:var(--ok)}.tl-dot{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;flex:0 0 auto;font-family:var(--font-mono);font-size:11px;font-weight:600;background:var(--bg-3);color:var(--text-2);border:2px solid var(--bg-1);position:relative;z-index:1}.tl-row.is-done .tl-dot{background:var(--ok);color:var(--text-inv)}.tl-row.is-active .tl-dot{background:var(--accent);color:#0a0d12;box-shadow:0 0 0 4px var(--accent-soft)}.tl-body{display:flex;flex-direction:column;gap:4px;min-width:0}.tl-title{font-size:13.5px;font-weight:600;color:var(--text-1);display:flex;align-items:center;gap:6px}.tl-sub{font-size:11px;color:var(--text-3);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.tl-right{font-family:var(--font-mono);font-size:11px;color:var(--text-2);text-align:right;line-height:1.4;white-space:nowrap;flex-shrink:0}.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-bottom:2px solid transparent;cursor:pointer}.tab:hover{color:var(--text-1)}.tab.is-active{color:var(--text-1);border-bottom-color:var(--accent)}.canvas{display:grid;grid-template-columns:auto 1fr 400px;height:100vh;overflow:auto;min-width:1480px;background:var(--bg-0)}.canvas--full{grid-template-columns:auto 1fr;min-width:1040px}.canvas-pwa-pane{background:var(--bg-1);border-left:1px solid var(--line);padding:18px;display:flex;flex-direction:column;gap:12px;overflow:auto;position:sticky;right:0;top:0}.canvas-pwa-pane-head{display:flex;align-items:center;justify-content:space-between}.canvas-pwa-pane-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);line-height:1.3}.canvas-main{overflow:hidden;display:flex;flex-direction:column;height:100vh}.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)}.unhitched-section{padding:6px var(--pad-x) 0}.unhitched-head{display:flex;align-items:center;justify-content:space-between;padding:6px 0}.unhitched-head h4{margin:0;font-size:10px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em}.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-langs--select{display:block;background:transparent;border:0;padding:0}.auth-lang{font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--text-3);padding:4px 8px;border-radius:5px}.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);align-self:flex-start;margin-bottom:-8px}.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,.settings-card .field-row-val input,.settings-card .field-row-val 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}.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}.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)}.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}.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}.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-card{display:flex;align-items:center;gap:12px;padding:14px;border-radius:12px;background:var(--bg-2);border:1px solid var(--line)}.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)}.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}.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}.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;flex-shrink:0}.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}.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)}.toggle-sm{width:28px;height:16px}.toggle-sm .toggle-knob{width:12px;height:12px}.toggle-sm.is-on .toggle-knob{transform:translate(12px)}.btn{padding:8px 14px;border-radius:8px;font-size:12.5px;font-weight:500;transition:background .1s;display:inline-flex;align-items:center;gap:6px}.btn-primary{background:var(--accent);color:#0a0d12;font-weight:700}.btn-primary:hover{background:var(--accent-2)}.btn-secondary{background:var(--bg-2);color:var(--text-1);border:1px solid var(--line-strong)}.btn-secondary:hover{background:var(--bg-3)}.btn-ghost{color:var(--text-2)}.btn-ghost:hover{background:var(--bg-2);color:var(--text-1)}.btn-sm{padding:4px 8px;font-size:11px}.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)}.office-row{display:flex;align-items:center;gap:10px;padding:10px 0}.office-row+.office-row{border-top:1px solid var(--line)}.settings-table{width:100%;border-collapse:collapse;font-size:12.5px}.settings-table th{text-align:left;padding:10px 18px;font-size:10.5px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--line)}.settings-table td{padding:10px 18px;border-bottom:1px solid var(--line);vertical-align:middle}.settings-table tr:last-child td{border-bottom:0}.settings-table tr:hover td{background:var(--bg-2)}.wln-unit-input{width:140px;height:30px;padding:0 10px;background:var(--bg-2);border:1px solid var(--line-strong);border-radius:7px;color:var(--text-1);font-size:12.5px;outline:none;transition:border-color .12s,box-shadow .12s}.wln-unit-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.wln-unit-input:disabled{opacity:.6}.wln-unit-error{margin-top:5px;font-size:11px;color:var(--crit);max-width:220px;line-height:1.35;white-space:normal}.notif-table td:first-child{width:50%}.settings-select{height:32px;padding:0 10px;background:var(--bg-2);border:1px solid var(--line);border-radius:7px;color:var(--text-1);font-size:12.5px}.role-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.role-card{background:var(--bg-2);border:1px solid var(--line);border-radius:10px;padding:14px}.role-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.role-perms{list-style:none;padding:0;margin:0;font-size:12px;color:var(--text-2)}.role-perms li{display:flex;align-items:center;gap:8px;padding:4px 0}.role-perms li:before{content:"✓";color:var(--ok);font-weight:700}.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)}.seg-control button.is-on{background:var(--accent);color:#0a0d12;font-weight:600}.route-row{display:flex;align-items:center;gap:8px;padding:9px 0}.route-row+.route-row{border-top:1px solid var(--line)}.speed-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.speed-cell{display:flex;align-items:center;gap:6px;padding:8px 10px;background:var(--bg-2);border:1px solid var(--line);border-radius:8px}.speed-input{width:48px;height:26px;padding:0 6px;background:var(--bg-1);border:1px solid var(--line);border-radius:5px;color:var(--text-1);font-size:12px;text-align:right}.session-row{display:flex;align-items:center;gap:12px;padding:11px 18px;border-bottom:1px solid var(--line)}.session-row:last-child{border-bottom:0}.plan-hero{display:flex;align-items:flex-end;justify-content:space-between;padding-bottom:18px;border-bottom:1px solid var(--line);margin-bottom:14px}.plan-usage{display:flex;flex-direction:column;gap:10px}.usage-row{display:grid;grid-template-columns:140px 80px 1fr;align-items:center;gap:12px;font-size:12px}.usage-bar{height:6px;background:var(--bg-3);border-radius:3px;overflow:hidden}.usage-bar>div{height:100%;background:var(--accent);border-radius:3px;transition:width .2s}.card-row{display:flex;align-items:center;gap:12px;padding:4px 0}.pwa-login-bg{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;text-align:center;background:linear-gradient(180deg,#181f2b,#0a0d12)}.navrail{width:212px;flex-shrink:0;background:var(--bg-1);border-right:1px solid var(--line);display:flex;flex-direction:column;height:100vh;position:sticky;top:0;left:0;z-index:20}[data-density=compact] .navrail{width:188px}.navrail-head{display:flex;align-items:center;gap:10px;padding:16px 16px 14px}.navrail-mark{width:30px;height:30px;border-radius:8px;flex:0 0 auto;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:grid;place-items:center;color:#0a0d12;font-weight:700;font-family:var(--font-mono);font-size:12px;letter-spacing:-.02em;box-shadow:0 4px 14px var(--accent-soft)}.navrail-title{font-weight:600;font-size:15px;letter-spacing:-.01em;line-height:1.1}.navrail-title .mono{color:var(--text-3);font-weight:400;font-size:13px}.navrail-scroll{flex:1;overflow-y:auto;padding:6px 10px 14px;display:flex;flex-direction:column;gap:2px}.navrail-divider{height:1px;background:var(--line);margin:8px 6px}.nav-item{display:flex;align-items:center;gap:12px;height:42px;padding:0 12px;border-radius:9px;color:var(--text-2);font-size:14px;font-weight:500;position:relative;width:100%;text-align:left;transition:background .12s ease,color .12s ease}[data-density=compact] .nav-item{height:36px;font-size:13px}.nav-item:hover{background:var(--bg-2);color:var(--text-1)}.nav-item-ico{display:grid;place-items:center;width:20px;color:inherit;flex:0 0 auto}.nav-item-label{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-item-badge{min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--bg-3);color:var(--text-2);font-family:var(--font-mono);font-size:10px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}.nav-item-badge.is-crit{background:#ff5c5c2e;color:var(--crit)}.nav-item.is-active{background:var(--accent-soft);color:var(--accent);font-weight:600}.nav-item.is-active:before{content:"";position:absolute;left:-10px;top:9px;bottom:9px;width:3px;border-radius:0 3px 3px 0;background:var(--accent)}.nav-item.is-active .nav-item-badge{background:#0000002e;color:var(--accent)}.navrail-foot{padding:10px;border-top:1px solid var(--line)}.navrail-user{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:9px;width:100%;text-align:left}.navrail-user:hover{background:var(--bg-2)}.navrail-user-name{font-size:12.5px;font-weight:600;color:var(--text-1);line-height:1.2}.navrail-user-role{font-size:10.5px;color:var(--text-3)}.module-page{display:flex;flex-direction:column;height:calc(100vh - 56px);overflow:hidden}.module-scroll{flex:1;overflow-y:auto;padding:20px 22px 28px;display:flex;flex-direction:column;gap:18px}[data-density=compact] .module-scroll{padding:14px 16px 20px;gap:14px}.mod-toolbar{display:flex;align-items:center;gap:14px;padding:14px 22px;background:var(--bg-1);border-bottom:1px solid var(--line);flex-shrink:0;flex-wrap:wrap}.mod-toolbar-title{display:flex;align-items:baseline;gap:9px}.mod-toolbar-title h1{font-size:19px;font-weight:600;letter-spacing:-.01em;margin:0}.mod-toolbar-title .count{font-family:var(--font-mono);font-size:13px;color:var(--text-3)}.mod-toolbar-spacer{flex:1}.filter-tabs{display:inline-flex;gap:2px;padding:3px;background:var(--bg-2);border:1px solid var(--line);border-radius:9px;flex-wrap:nowrap}.filter-tab{padding:6px 11px;border-radius:6px;font-size:12px;font-weight:500;color:var(--text-2);white-space:nowrap;display:inline-flex;align-items:center;gap:6px}.filter-tab:hover{color:var(--text-1)}.filter-tab.is-on{background:var(--accent);color:#0a0d12;font-weight:600}.filter-tab .tab-n{font-family:var(--font-mono);font-size:11px;opacity:.8}.filter-tab.is-on .tab-n{opacity:.9}.mod-search{display:flex;align-items:center;gap:8px;height:34px;padding:0 12px;border-radius:9px;background:var(--bg-2);border:1px solid var(--line);color:var(--text-2);min-width:200px}.mod-search:focus-within{border-color:var(--line-strong);background:var(--bg-3)}.mod-search input{flex:1;background:transparent;border:0;outline:0;font-size:12.5px;color:var(--text-1);min-width:0}.mod-search input::placeholder{color:var(--text-3)}.stat-tiles{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.stat-tile{background:var(--bg-1);border:1px solid var(--line);border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;gap:6px;border-left:3px solid var(--text-3)}.stat-tile.t-ok{border-left-color:var(--ok)}.stat-tile.t-warn{border-left-color:var(--warn)}.stat-tile.t-crit{border-left-color:var(--crit)}.stat-tile.t-info{border-left-color:var(--info)}.stat-tile.t-accent{border-left-color:var(--accent)}.stat-tile-label{font-size:10.5px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:6px}.stat-tile-val{font-family:var(--font-mono);font-size:26px;font-weight:600;color:var(--text-1);line-height:1;font-variant-numeric:tabular-nums}.stat-tile-val .unit{font-size:13px;color:var(--text-3);font-weight:400;margin-left:3px}.stat-tile-sub{font-size:11px;color:var(--text-3)}.data-table{width:100%;border-collapse:collapse;font-size:12.5px}.data-table thead th{text-align:left;padding:11px 16px;position:sticky;top:0;z-index:1;background:var(--bg-1);font-size:10.5px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--line);white-space:nowrap}.data-table tbody td{padding:11px 16px;border-bottom:1px solid var(--line);vertical-align:middle}.data-table tbody tr{cursor:pointer;transition:background .1s}.data-table tbody tr:hover td{background:var(--bg-2)}.data-table tbody tr:last-child td{border-bottom:0}.data-table .num{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.data-table .t-right{text-align:right}.table-card{background:var(--bg-1);border:1px solid var(--line);border-radius:12px;overflow:hidden}.table-card-scroll{overflow-x:auto}.cell-primary{font-size:13px;font-weight:600;color:var(--text-1)}.cell-sub{font-size:11px;color:var(--text-3)}.cell-stack{display:flex;flex-direction:column;gap:2px;min-width:0}.cell-flex{display:flex;align-items:center;gap:10px;min-width:0}.mini-prog{width:84px;height:5px;border-radius:999px;background:var(--bg-3);overflow:hidden;flex:0 0 auto}.mini-prog>i{display:block;height:100%;border-radius:999px;background:var(--accent)}.route-inline{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--text-2);white-space:nowrap}.mod-empty{padding:60px 20px;text-align:center;color:var(--text-3);display:flex;flex-direction:column;align-items:center;gap:10px}.mod-empty-ico{width:48px;height:48px;border-radius:12px;background:var(--bg-2);display:grid;place-items:center;color:var(--text-3)}.modal-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1400;background:#05080c8c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:20px;animation:scrimin .18s ease}.modal-card{width:440px;max-width:100%;background:var(--bg-1);border:1px solid var(--line-strong);border-radius:14px;box-shadow:var(--shadow-pop);display:flex;flex-direction:column;animation:modalin .2s cubic-bezier(.22,.61,.36,1)}@keyframes modalin{0%{transform:translateY(8px) scale(.99);opacity:0}to{transform:none;opacity:1}}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--line)}.modal-title{font-size:16px;font-weight:600;margin:0;letter-spacing:-.01em}.modal-body{padding:18px;display:flex;flex-direction:column;gap:14px}.modal-foot{padding:14px 18px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:8px}.drawer-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;background:#05080c8c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:scrimin .18s ease}@keyframes scrimin{0%{opacity:0}to{opacity:1}}.drawer{position:fixed;top:0;right:0;bottom:0;z-index:1201;width:460px;max-width:92vw;background:var(--bg-1);border-left:1px solid var(--line-strong);box-shadow:var(--shadow-pop);display:flex;flex-direction:column;animation:drawerin .22s cubic-bezier(.22,.61,.36,1)}@keyframes drawerin{0%{transform:translate(30px);opacity:.4}to{transform:translate(0);opacity:1}}.drawer-head{display:flex;align-items:flex-start;gap:12px;padding:18px 20px;border-bottom:1px solid var(--line);flex-shrink:0}.drawer-head h2{font-size:17px;font-weight:600;margin:0;letter-spacing:-.01em}.drawer-head-sub{font-size:12px;color:var(--text-3);margin-top:3px}.drawer-close{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;color:var(--text-2);flex:0 0 auto}.drawer-close:hover{background:var(--bg-2);color:var(--text-1)}.drawer-body{flex:1;overflow-y:auto;padding:18px 20px;display:flex;flex-direction:column;gap:16px}.drawer-foot{padding:14px 20px;border-top:1px solid var(--line);display:flex;gap:8px;flex-shrink:0}.drawer-hero{display:flex;align-items:center;gap:14px}.drawer-section-label{font-size:10.5px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:-4px}.kv-list{display:flex;flex-direction:column;background:var(--bg-2);border:1px solid var(--line);border-radius:10px;overflow:hidden}.kv-line{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border-bottom:1px solid var(--line);font-size:12.5px}.kv-line:last-child{border-bottom:0}.kv-line .k{color:var(--text-3)}.kv-line .v{color:var(--text-1);font-weight:500;text-align:right}.doc-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.doc-card{background:var(--bg-1);border:1px solid var(--line);border-radius:12px;overflow:hidden;cursor:pointer;transition:border-color .12s,transform .12s;display:flex;flex-direction:column}.doc-card:hover{border-color:var(--line-strong);transform:translateY(-1px)}.doc-thumb{height:116px;position:relative;display:grid;place-items:center;background:repeating-linear-gradient(45deg,var(--bg-2) 0 10px,var(--bg-3) 10px 20px);color:var(--text-3)}.doc-thumb-badge{position:absolute;top:8px;left:8px}.doc-thumb-type{position:absolute;bottom:8px;right:8px;font-family:var(--font-mono);font-size:9px;color:var(--text-3);background:var(--bg-1);padding:2px 6px;border-radius:4px;border:1px solid var(--line)}.doc-meta{padding:11px 13px;display:flex;flex-direction:column;gap:5px}.doc-meta-name{font-size:12.5px;font-weight:600;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.doc-meta-row{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-3)}.dropzone{border:1.5px dashed var(--line-strong);border-radius:12px;padding:22px;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-3);text-align:center;background:var(--bg-1)}.dropzone:hover{border-color:var(--accent);color:var(--text-2)}.inv-amount{font-family:var(--font-mono);font-weight:600;font-variant-numeric:tabular-nums}.inv-line-table{width:100%;border-collapse:collapse;font-size:12.5px}.inv-line-table td{padding:9px 0;border-bottom:1px solid var(--line)}.inv-line-table tr:last-child td{border-bottom:0}.inv-total-row{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--bg-2);border-radius:10px}.inv-total-row .lbl{font-size:12px;color:var(--text-3)}.inv-total-row .amt{font-family:var(--font-mono);font-size:22px;font-weight:700}.aging-bar{display:flex;height:10px;border-radius:999px;overflow:hidden;background:var(--bg-3)}.aging-bar>span{height:100%}.aging-legend{display:flex;gap:16px;flex-wrap:wrap;margin-top:10px}.aging-legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-2)}.aging-swatch{width:9px;height:9px;border-radius:3px;flex:0 0 auto}.perm-grid{display:grid;grid-template-columns:1fr auto auto auto;gap:0;font-size:12.5px}.perm-grid .ph{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;padding:8px 10px;text-align:center}.perm-grid .pl{padding:10px;border-top:1px solid var(--line)}.perm-grid .pc{padding:10px;border-top:1px solid var(--line);text-align:center}.navrail-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1290;background:#05080c8c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:scrimin .18s ease;display:none}.tb-menu{width:34px;height:34px;border-radius:9px;display:none;align-items:center;justify-content:center;color:var(--text-1);flex:0 0 auto}.tb-menu:hover{background:var(--bg-2)}.pwa-install-btn{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 12px;border-radius:999px;background:var(--accent);color:#0a0d12;font-size:12px;font-weight:600;white-space:nowrap;flex:0 0 auto}.pwa-install-btn:hover{background:var(--accent-2)}@media (max-width: 1180px){.canvas,.canvas--full{min-width:0}.board{grid-template-columns:280px 1fr 300px}.detail-grid{grid-template-columns:1fr 320px}.settings-main{max-width:none}.tb-search{min-width:150px}}@media (max-width: 820px){.canvas,.canvas--full{display:block;min-width:0;height:auto;overflow:visible}.canvas-main{height:auto;min-height:100dvh;overflow:visible}.navrail{position:fixed;top:0;left:0;bottom:0;height:100dvh;width:264px;max-width:84vw;transform:translate(-100%);transition:transform .26s cubic-bezier(.22,.61,.36,1);box-shadow:var(--shadow-pop);z-index:1300}.navrail.is-open{transform:translate(0)}[data-density=compact] .navrail{width:240px}.navrail.is-open~.navrail-scrim,.navrail-scrim.is-open{display:block}.topbar{position:sticky;top:0;z-index:1100;height:52px;padding:0 12px;gap:10px}.tb-menu{display:flex}.tb-sep,.tb-search,.tb-stat,.tb-live,.tb-time{display:none}.tb-page-title{font-size:15px}.tb-spacer{flex:1}.module-page{height:auto;overflow:visible}.module-scroll{overflow:visible;padding:14px 14px 96px;gap:14px}.mod-toolbar{padding:12px 14px;gap:10px}.mod-toolbar-title h1{font-size:17px}.mod-search{min-width:0;flex:1 1 140px}.filter-tabs{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch}.stat-tiles{grid-template-columns:repeat(auto-fit,minmax(128px,1fr))}.table-card-scroll{-webkit-overflow-scrolling:touch}.data-table thead th,.data-table tbody td{padding:10px 12px}.board{display:flex;flex-direction:column;height:auto;overflow:visible}.board-pane{border-right:0;border-left:0;border-bottom:1px solid var(--line)}.board-pane:last-child{border-left:0}.board-pane--map{height:56vh;min-height:300px;flex:0 0 auto}.pane-body{overflow:visible;padding-bottom:16px}.board-pane--map+.board-pane .pane-body{padding-bottom:96px}.scrubber{left:10px;right:10px;bottom:10px;padding:8px 10px;gap:8px}.scrubber-time{min-width:64px;font-size:10px}.detail-grid{grid-template-columns:1fr;height:auto;overflow:visible;padding:14px;gap:14px}.detail-main,.detail-side{overflow:visible}.kv-grid{grid-template-columns:1fr 1fr}.tabs{overflow-x:auto;padding:0 12px}.page-head{padding:10px 14px;overflow-x:auto}.drawer{width:100vw;max-width:100vw;border-left:0}.auth-shell{grid-template-columns:1fr;min-height:100dvh}.auth-brand{display:none}.auth-form-pane{padding:28px 20px 32px}.auth-langs{position:static;margin-bottom:8px}.settings-grid{grid-template-columns:1fr;overflow:visible;height:auto}.settings-nav{flex-direction:row;gap:4px;overflow-x:auto;border-right:0;border-bottom:1px solid var(--line);padding:8px 10px;-webkit-overflow-scrolling:touch}.settings-nav-item{white-space:nowrap;flex:0 0 auto}.settings-nav-divider{display:none}.settings-main{padding:18px 14px 96px;overflow:visible}.field-row,.usage-row{grid-template-columns:1fr;gap:4px}.fleet-grid,.speed-grid{grid-template-columns:repeat(2,1fr)}.role-grid,.lang-grid{grid-template-columns:1fr}.twk-panel{right:10px!important;bottom:10px!important;width:min(280px,calc(100vw - 20px))!important;max-height:70dvh}.nav-item{height:46px}.filter-tab{padding:8px 12px}.topbar .lang-select-name{display:none}.topbar .lang-select-btn{padding:0 8px;gap:5px}}@media (max-width: 480px){.kv-grid{grid-template-columns:1fr}.kv-cell:nth-child(odd){border-right:0}.fleet-grid,.speed-grid{grid-template-columns:1fr}.auth-stats{grid-template-columns:repeat(2,1fr)}}
