:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--background:#f3f6fb;--surface:#fff;--surface-soft:#f8fbff;--foreground:#0f172a;--muted:#66748a;--subtle:#94a3b8;--border:#dbe5f2;--border-strong:#c8d5e6;--blue:#2563eb;--blue-soft:#eaf2ff;--cyan:#0891b2;--green:#16a34a;--amber:#f59e0b;--red:#ef4444;--red-soft:#fff0ed;--shadow:0 18px 48px #0f172a14}*{box-sizing:border-box}html,body{height:100%;overflow:hidden}body{background:radial-gradient(circle at 20% -10%, #2563eb1f, transparent 34%), linear-gradient(180deg, #f8fbff 0%, var(--background) 100%);color:var(--foreground);margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,textarea{font:inherit}button{cursor:pointer}h1,h2,p{margin:0}.control-shell{grid-template-rows:auto auto minmax(0,1fr);width:100%;height:100dvh;min-height:0;padding:18px 22px 22px;display:grid;position:fixed;inset:0;overflow:hidden}.topbar{justify-content:space-between;align-items:center;gap:24px;margin-bottom:14px;display:flex}.brand-lockup{align-items:center;gap:0;display:flex}.eyebrow{color:var(--blue);letter-spacing:0;text-transform:uppercase;margin:0 0 4px;font-size:12px;font-weight:900}h1{font-size:28px;line-height:1.12}h2{font-size:17px;line-height:1.25}.top-actions{align-items:center;gap:12px;display:flex}.top-icon,.avatar{border-radius:999px;place-items:center;font-weight:800;display:grid}.top-icon{border:1px solid var(--border);background:var(--surface);color:#475569;width:34px;height:34px}.avatar{background:var(--blue);color:#fff;width:40px;height:40px}.filter-bar{flex-wrap:wrap;flex:none;gap:12px;margin-bottom:14px;display:flex}.filter-pill,.incident-pill{border:1px solid var(--border);background:#ffffffdb;border-radius:8px;align-items:center;min-height:46px;display:inline-flex;box-shadow:0 8px 28px #0f172a0a}.filter-pill{color:var(--foreground);gap:22px;padding:0 16px}.date-filter{min-width:210px;position:relative}.date-filter select{min-width:104px;color:var(--foreground);font:inherit;background:0 0;border:0;outline:none;font-size:14px;font-weight:800}.static-filter{cursor:default;min-width:250px}.filter-pill span{color:var(--muted);font-size:13px;font-weight:800}.filter-pill strong{min-width:96px;font-size:14px;font-weight:800}.filter-pill i{color:var(--muted);font-style:normal}.incident-pill{color:#1e293b;cursor:default;gap:9px;padding:0 18px;font-size:14px;font-weight:900}.incident-pill span{background:var(--red);color:#fff;border-radius:999px;place-items:center;width:22px;height:22px;display:grid}.dashboard-grid{grid-template-columns:minmax(340px,.98fr) minmax(560px,1.28fr) minmax(390px,.92fr);gap:14px;min-height:0;display:grid;overflow:hidden}.left-rail,.main-stage,.agent-panel{border:1px solid var(--border);min-width:0;min-height:0;box-shadow:var(--shadow);background:#ffffffe6;border-radius:8px}.left-rail,.main-stage{overscroll-behavior:contain;height:100%;padding:16px;overflow:auto}.section-title{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.section-title span{color:var(--muted);align-items:center;gap:6px;font-size:12px;font-weight:800;display:inline-flex}.section-title>span:before{background:var(--green);content:"";border-radius:999px;width:8px;height:8px}.metric-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-bottom:16px;display:grid}.metric{border:1px solid var(--border);background:linear-gradient(#fff 0%,#f8fbff 100%);border-radius:8px;min-height:104px;padding:15px 14px;box-shadow:0 10px 28px #0f172a0a}.metric i{background:var(--blue-soft);width:24px;height:24px;color:var(--blue);border-radius:6px;place-items:center;margin-bottom:12px;font-size:12px;font-style:normal;font-weight:900;display:grid}.metric span,.info-block span{color:var(--muted);font-size:12px;font-weight:800;display:block}.metric strong{color:#0b1328;margin-top:7px;font-size:24px;line-height:1.1;display:block}.metric.danger strong{color:var(--red)}.metric.warning strong{color:#a16207}.work-section{padding:0}.route-list{gap:8px;display:grid}.route-row{border:1px solid var(--border);width:100%;min-height:74px;color:inherit;text-align:left;background:#fff;border-radius:8px;grid-template-columns:28px minmax(0,1fr) auto auto;align-items:center;gap:10px;padding:12px;display:grid;box-shadow:0 10px 24px #0f172a09}.route-row.selected{box-shadow:inset 3px 0 0 var(--blue), 0 12px 26px #2563eb14;background:#f1f6ff;border-color:#7aa7ff}.route-icon{width:24px;height:24px;display:block;position:relative}.route-icon:before,.route-icon:after{content:"";background:#64748b;border-radius:999px;width:14px;height:2px;position:absolute;left:6px}.route-icon:before{top:8px;transform:rotate(-38deg)}.route-icon:after{top:15px;transform:rotate(32deg)}.route-icon i{z-index:2;background:#fff;border:2px solid #64748b;border-radius:999px;width:6px;height:6px;position:absolute}.route-icon i:first-child{top:13px;left:2px}.route-icon i:nth-child(2){top:5px;left:10px}.route-icon i:nth-child(3){bottom:2px;right:1px}.route-row.selected .route-icon:before,.route-row.selected .route-icon:after{background:var(--blue)}.route-row.selected .route-icon i{border-color:var(--blue)}.route-copy{min-width:0}.route-copy strong,.route-copy small{display:block}.route-copy strong{text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:900;overflow:hidden}.route-copy small{color:var(--muted);margin-top:5px;font-size:12px;font-weight:700}.route-metric{color:#334155;white-space:nowrap;font-size:13px;font-weight:800}.risk-badge{border-radius:7px;flex:none;justify-content:center;align-items:center;min-width:56px;min-height:30px;padding:0 10px;font-size:12px;font-weight:900;display:inline-flex}.risk-badge.high{color:#dc2626;background:#ffe1dc}.risk-badge.medium{color:#b45309;background:#fff2cc}.risk-badge.low{color:#15803d;background:#e7f8ed}.map-legend{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.map-legend span{color:var(--muted);align-items:center;gap:5px;font-size:11px;font-weight:800;display:inline-flex}.dot{flex:none;place-items:center;display:inline-grid;position:relative}.dot.high{background:var(--red);border-radius:999px;width:18px;height:4px}.dot.medium{background:var(--amber);border-radius:999px;width:18px;height:4px}.dot.low{background:var(--blue);border-radius:999px;width:18px;height:4px}.dot.vehicle{background:var(--green);border-radius:999px;width:15px;height:15px}.dot.vehicle:after{color:#fff;content:"车";font-size:8px;font-weight:900;line-height:1}.dot.warehouse{background:#8b5cf6;border-radius:4px;width:15px;height:15px}.dot.warehouse:after{color:#fff;content:"仓";font-size:8px;font-weight:900;line-height:1}.dot.region{background:#fff;border:1px solid #94a3b8;border-radius:3px;width:15px;height:11px}.route-map{border:1px solid var(--border);background:#f8fbff;border-radius:8px;height:clamp(220px,32vh,395px);min-height:220px;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #ffffff8c}.map-visual{background:url(/assets/transport-map-panel.svg?v=2) 50%/contain no-repeat;width:100%;height:100%;position:absolute;inset:0}.detail-grid{grid-template-rows:repeat(2,70px);grid-template-columns:minmax(190px,1.55fr) repeat(4,minmax(92px,1fr));gap:8px;margin-top:10px;display:grid}.info-block{border:1px solid var(--border);background:linear-gradient(#fff,#f9fbff);border-radius:8px;height:100%;min-height:0;padding:10px 12px;box-shadow:0 10px 24px #0f172a09}.info-block.route-main{grid-row:1/span 2}.info-block strong{margin-top:5px;font-size:17px;line-height:1.25;display:block}.info-block:not(.route-main) strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.info-block.route-main strong{white-space:normal;font-size:18px}.info-block small{color:var(--muted);margin-top:8px;font-size:13px;font-weight:800;display:block}.risk-summary-strip{background:linear-gradient(90deg,#fff8f6,#fff);border:1px solid #ffc7bd;border-radius:8px;align-items:center;gap:22px;min-height:60px;margin-top:12px;padding:12px 16px;display:flex}.risk-summary-strip span{color:#334155;font-size:14px;font-weight:900}.risk-summary-strip strong{color:#0f172a;align-items:baseline;gap:8px;font-size:15px;display:inline-flex}.risk-summary-strip em{color:var(--red);font-size:20px;font-style:normal}.late-customer-table{background:linear-gradient(#fff0ed94,#fffffffa 42%),#fff;border:1px solid #ffd5cf;border-radius:8px;margin-top:10px;overflow:hidden;box-shadow:0 14px 30px #ef444412}.late-table-head{border-bottom:1px solid #ffe1dc;justify-content:space-between;align-items:center;min-height:34px;padding:7px 14px;display:flex}.late-table-head span{color:var(--red);font-size:12px;font-weight:900;display:block}.late-customer-table table{border-collapse:collapse;width:100%;font-size:13px}.late-customer-table th,.late-customer-table td{text-align:left;padding:10px 14px}.late-customer-table th{color:#5f6f86;background:#f8fbff;border-bottom:1px solid #dbe5f2;font-size:12px;font-weight:900}.late-customer-table td{color:#0f172a;background:#ffffffd1;border-bottom:1px solid #edf2f8;font-weight:800}.late-customer-table tbody tr:last-child td{border-bottom:0}.late-customer-table tr:nth-child(2n) td{background:#f8fbffe0}.late-customer-table tbody tr:hover td{background:#fff7f5}.time-diff{color:#dc2626;background:#ffe1dc;border-radius:999px;justify-content:center;align-items:center;min-width:42px;min-height:24px;padding:0 8px;font-size:12px;font-weight:900;display:inline-flex}.agent-panel{flex-direction:column;height:100%;max-height:100%;padding:16px;display:flex;overflow:hidden}.chat-log{overscroll-behavior:contain;border:1px solid var(--border);background:repeating-linear-gradient(90deg,#0000 0 12px,#2563eb06 12px 13px),#f8fbff;border-radius:8px;flex-direction:column;flex:1 1 0;gap:10px;min-height:0;padding:12px;display:flex;overflow:hidden auto}.message{white-space:pre-wrap;border-radius:8px;max-width:92%;padding:11px 12px;font-size:13px;line-height:1.65}.message.assistant{background:0 0;border:0;align-self:flex-start;width:min(100%,720px);max-width:100%;padding:0}.message.user{color:#102a55;background:#dcecff;align-self:flex-end;padding:11px 12px}.message.pending{color:#42526a}.loading-message{background:linear-gradient(#fff 0%,#f3f8ff 100%);border-color:#bfd6ff;padding:11px 12px}.loading-title{color:#173f8a;font-size:14px;font-weight:900}.loading-subtitle{color:var(--muted);margin-top:4px;font-size:12px}.loading-bar{background:#dceaff;border-radius:999px;height:4px;margin-top:10px;position:relative;overflow:hidden}.loading-bar span{border-radius:inherit;background:linear-gradient(90deg,#2563eb,#0891b2);width:42%;animation:1.2s ease-in-out infinite loading-sweep;position:absolute;inset:0 auto 0 0}.loading-dots{align-items:center;gap:5px;margin-top:8px;display:inline-flex}.loading-dots span{background:var(--blue);border-radius:999px;width:7px;height:7px;animation:1s ease-in-out infinite pulse-dot}.loading-dots span:nth-child(2){animation-delay:.14s}.loading-dots span:nth-child(3){animation-delay:.28s}@keyframes pulse-dot{0%,80%,to{opacity:.35;transform:translateY(0)}40%{opacity:1;transform:translateY(-4px)}}@keyframes loading-sweep{0%{transform:translate(-110%)}55%{transform:translate(80%)}to{transform:translate(250%)}}.insight-card{white-space:normal;background:#f7fbff;border:1px solid #d7e4f5;border-radius:8px;padding:12px}.insight-head{justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px;display:flex}.insight-head span{color:#1746a2;font-size:13px;font-weight:900}.insight-summary{color:#1f2937;margin-bottom:10px;font-size:13px;font-weight:800;line-height:1.55}.insight-grid{gap:8px;display:grid}.insight-block{background:var(--surface);border:1px solid #e1e9f4;border-radius:6px;padding:10px}.insight-block h3{color:var(--muted);margin:0 0 7px;font-size:12px;line-height:1.3}.insight-block ul{gap:6px;margin:0;padding-left:16px;display:grid}.insight-block li{overflow-wrap:anywhere;color:#263244;font-size:13px;line-height:1.55}.chat-form{flex-direction:column;flex:none;gap:9px;margin-top:12px;display:flex}.quick-prompt-tray{gap:7px;display:grid}.quick-prompt-tray>span{color:var(--muted);font-size:12px;font-weight:900}.quick-prompt-list{flex-wrap:wrap;gap:7px;display:flex}.quick-prompt-list button{color:#1746a2;text-align:center;background:#f1f6ff;border:1px solid #cfe0ff;border-radius:999px;min-height:30px;padding:0 10px;font-size:12px;font-weight:900;line-height:1.2}.quick-prompt-list button:disabled{cursor:not-allowed;opacity:.55}.chat-input-row{grid-template-columns:minmax(0,1fr) 72px;gap:8px;display:grid}.chat-input-row input,.chat-input-row button{border-radius:8px;min-height:42px}.chat-input-row input{border:1px solid var(--border);min-width:0;padding:0 12px}.chat-input-row input:disabled{color:#94a3b8;background:#f4f7fb}.chat-input-row button{background:var(--blue);color:#fff;border:0;font-weight:900}.chat-input-row button:disabled{cursor:not-allowed;opacity:.55}@media (max-width:1400px){.dashboard-grid{grid-template-columns:minmax(320px,.9fr) minmax(520px,1.2fr) minmax(360px,.9fr)}.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.route-row{grid-template-columns:24px minmax(0,1fr) auto}.route-metric{grid-column:2/3}.route-row .risk-badge{grid-area:1/3/span 2/4}}@media (max-width:1180px){html,body{overflow:auto}.control-shell{height:auto;min-height:100vh;position:static;overflow:visible}.dashboard-grid{grid-template-columns:1fr;overflow:visible}.left-rail,.main-stage{overflow:visible}.agent-panel{height:660px;max-height:660px}}@media (max-width:760px){.control-shell{padding:14px}.topbar{flex-direction:column;align-items:flex-start}.metric-grid,.detail-grid{grid-template-columns:1fr}.info-block:first-child{grid-column:auto}.route-map{height:320px}.quick-prompt-list{flex-wrap:nowrap;padding-bottom:2px;overflow-x:auto}.quick-prompt-list button{flex:none}}
