:root{--bg:#f5f8fb;--card:#fff;--primary:#176b8f;--primary-dark:#123e59;--text:#183142;--muted:#6b7c88;--teal:#2ca6a4;--teal-soft:#e9f6f6;--route:#f1a45b;--success:#2ead75;--warning:#f59e0b;--danger:#d64545;--line:#d9e4ea;color:var(--text);background:var(--bg);font-family:Microsoft YaHei,PingFang SC,Noto Sans CJK SC,system-ui,sans-serif}*{box-sizing:border-box}body{background:radial-gradient(circle at top left, #2ca6a421, transparent 28rem), linear-gradient(180deg, #fff 0%, var(--bg) 42%);min-width:320px;min-height:100vh;margin:0}button,input,select,textarea{font:inherit}button{border:0}a{color:inherit;text-decoration:none}.app-shell{max-width:1440px;margin:0 auto;padding:28px}.topbar{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffd1;border:1px solid #176b8f1a;border-radius:24px;justify-content:space-between;align-items:center;gap:18px;padding:20px 24px;display:flex;box-shadow:0 18px 40px #18314214}.topbar h1,.card h2{margin:0}.topbar h1{color:var(--primary-dark);font-size:clamp(24px,3vw,34px)}.eyebrow{color:var(--teal);letter-spacing:.08em;text-transform:uppercase;margin:0 0 6px;font-size:13px;font-weight:700}.muted{color:var(--muted);line-height:1.7}.role-nav{border:1px solid var(--line);background:#ffffffc2;border-radius:16px;gap:10px;width:fit-content;margin:18px 0 24px;padding:8px;display:flex}.role-nav a{color:var(--muted);border-radius:12px;padding:10px 18px;font-weight:700}.role-nav a.active,.role-nav a:focus-visible,.role-nav a:hover{color:#fff;background:var(--primary);outline:none}.layout{grid-template-columns:minmax(280px,.9fr) minmax(360px,1.3fr);gap:22px;display:grid}.page-host{min-height:60vh}.card{border:1px solid var(--line);background:var(--card);border-radius:22px;padding:20px;box-shadow:0 16px 38px #18314214}.card-header{justify-content:space-between;gap:16px;margin-bottom:16px;display:flex}.card h2{color:var(--primary-dark);font-size:21px}.card-actions{align-items:center;gap:8px;display:flex}.badge{white-space:nowrap;border-radius:999px;justify-content:center;align-items:center;min-height:28px;padding:5px 10px;font-size:13px;font-weight:700;display:inline-flex}.badge-neutral{color:var(--muted);background:#eef3f6}.badge-info{color:var(--primary);background:#e7f1f6}.badge-success{color:#0c7a4c;background:#e7f7ef}.badge-warning{color:#9a5b00;background:#fff3d8}.badge-danger{color:#a52727;background:#fdeaea}.error-banner{color:#9f2525;background:#fff0f0;border:1px solid #d6454538;border-radius:14px;gap:4px;margin:12px 0;padding:12px 14px;display:grid}.quick-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:18px;display:grid}.quick-grid span{color:var(--primary);background:var(--teal-soft);text-align:center;border-radius:14px;padding:14px;font-weight:700}.abstract-map{background-color:#0000;background-image:linear-gradient(90deg,#d9e4ea8c 1px,#0000 1px),linear-gradient(0deg,#d9e4ea8c 1px,#0000 1px),linear-gradient(135deg,#fff,#eff8f8);background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:42px 42px;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;border-radius:18px;min-height:360px;position:relative;overflow:hidden}.map-grid{border:1px dashed #176b8f38;border-radius:22px;position:absolute;inset:24px}.route-ribbon{background:var(--route);opacity:.82;transform-origin:0;border-radius:999px;height:12px;position:absolute}.route-ribbon-a{width:62%;top:48%;left:11%;transform:rotate(-13deg)}.route-ribbon-b{width:46%;top:58%;left:28%;transform:rotate(28deg)}.map-point,.vehicle-dot{color:#fff;background:var(--teal);border:3px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:800;display:inline-flex;position:absolute;box-shadow:0 8px 20px #18314229}.vehicle-dot-info{background:var(--primary)}.vehicle-dot-success{background:var(--success)}.vehicle-dot-warning{background:var(--warning)}.vehicle-dot-danger{background:var(--danger)}.map-caption{color:var(--muted);background:#ffffffd1;border:1px solid #d9e4eacc;border-radius:14px;justify-content:space-between;gap:12px;padding:12px 14px;display:flex;position:absolute;bottom:18px;left:18px;right:18px}.map-caption strong{color:var(--primary)}.mobile-stage{gap:18px;max-width:430px;margin:0 auto;display:grid}.driver-stage{grid-template-columns:minmax(300px,.9fr) minmax(360px,1.1fr);gap:18px;display:grid}.dispatch-stage{grid-template-columns:repeat(3,minmax(280px,1fr));gap:18px;display:grid}.dispatch-stage .card:first-child,.dispatch-stage .card:nth-child(2),.dispatch-stage .card:nth-child(3),.dispatch-stage .card:last-child{grid-column:span 3}.mobile-card{width:100%}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:18px 0;display:grid}.form-grid label,.stacked-form label{color:var(--muted);gap:6px;font-size:13px;font-weight:700;display:grid}.form-grid input,.form-grid select,.stacked-form input,.stacked-form select,.stacked-form textarea{border:1px solid var(--line);width:100%;min-height:42px;color:var(--text);background:#fbfdfe;border-radius:11px;padding:9px 11px}.form-grid input:focus,.form-grid select:focus,.stacked-form input:focus,.stacked-form select:focus,.stacked-form textarea:focus{border-color:var(--teal);outline:3px solid #2ca6a424}.span-2{grid-column:span 2}.button-row{flex-wrap:wrap;gap:10px;margin-top:14px;display:flex}.primary-button,.secondary-button,.danger-button{cursor:pointer;border-radius:12px;min-height:44px;padding:10px 15px;font-weight:800}.primary-button{color:#fff;background:var(--primary)}.secondary-button{color:var(--primary);background:#e9f2f6}.danger-button{color:#fff;background:var(--danger)}.primary-button:disabled,.secondary-button:disabled,.danger-button:disabled{cursor:not-allowed;opacity:.55}.success-message{color:#0c7a4c;margin:12px 0 0;font-weight:700}.point-list,.detail-list{gap:12px;display:grid}.point-row{border:1px solid var(--line);background:#fbfdfe;border-radius:14px;justify-content:space-between;align-items:center;gap:12px;padding:12px;display:flex}.point-row div,.detail-list div{gap:4px;display:grid}.point-row span,.detail-list dt{color:var(--muted);font-size:13px}.detail-list{grid-template-columns:repeat(2,minmax(0,1fr));margin:0}.detail-list dt,.detail-list dd{margin:0}.detail-list dd{font-weight:800}.task-list,.stop-list{gap:10px;display:grid}.task-item{border:1px solid var(--line);width:100%;color:var(--text);cursor:pointer;text-align:left;background:#fbfdfe;border-radius:14px;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:10px;padding:13px;display:grid}.task-item.active{background:var(--teal-soft);border-color:#2ca6a473}.task-item span{color:var(--muted)}.next-stop{color:var(--primary-dark);background:var(--teal-soft);border-radius:14px;margin:16px 0;padding:14px;font-size:18px;font-weight:900}.stop-row{border:1px solid var(--line);background:#fbfdfe;border-radius:14px;grid-template-columns:34px minmax(0,1fr) auto;align-items:center;gap:10px;padding:11px 12px;display:grid}.stop-row.current{background:#e7f1f6;border-color:#176b8f52}.stop-row span{color:#fff;background:var(--primary);border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-weight:800;display:inline-flex}.stop-row small{color:var(--muted);font-weight:700}.action-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:16px;display:grid}.readiness-list,.data-table{gap:10px;display:grid}.readiness-item{border:1px solid var(--line);background:#fbfdfe;border-radius:14px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:12px;padding:12px;display:grid}.readiness-item div{gap:3px;display:grid}.readiness-item span{color:var(--muted);font-size:13px}.kpi-grid{grid-template-columns:repeat(9,minmax(100px,1fr));gap:10px;display:grid}.kpi-card{border:1px solid var(--line);background:linear-gradient(#fff,#f5fbfb);border-radius:16px;gap:6px;padding:14px;display:grid}.kpi-card span{color:var(--muted);font-size:13px;font-weight:700}.kpi-card strong{color:var(--primary-dark);font-size:24px}.data-table button{border:1px solid var(--line);width:100%;color:var(--text);cursor:pointer;text-align:left;background:#fbfdfe;border-radius:14px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:5px 10px;padding:12px;display:grid}.data-table button:hover,.data-table button:focus-visible{border-color:#176b8f5c;outline:none}.data-table small{color:var(--muted);grid-column:1/-1}@media (width<=900px){.app-shell{padding:16px}.topbar,.map-caption{flex-direction:column;align-items:flex-start}.role-nav{width:100%}.role-nav a{text-align:center;flex:1}.layout,.driver-stage,.dispatch-stage,.quick-grid,.form-grid,.detail-list,.kpi-grid,.action-grid{grid-template-columns:1fr}.dispatch-stage .card:first-child,.dispatch-stage .card:nth-child(2),.dispatch-stage .card:nth-child(3),.dispatch-stage .card:last-child,.span-2{grid-column:span 1}}
