:root{--bg-page:#f9fafb;--text-main:#0f172a;--text-sub:#000;--line-soft:#dbe3f0;--brand:#1e3a8a;--brand-hover:#1e40af;--success:#10b981;--processing:#f59e0b;--danger:#b91c1c;--ink:#0f172a;--ink-mute:#000;--hairline:#dbe3f0;--hairline-cool:#e2e8f0;--canvas:#fff;--canvas-soft:#f8fafc;--accent-crimson:#b91c1c;--accent-yellow:#d97706;--radius-xs:4px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--shadow-lg:0 12px 28px #0f172a38}*{box-sizing:border-box}html,body{margin:0;padding:0}body{min-height:100vh;color:var(--text-main);background:var(--bg-page);font-family:Inter,PingFang SC,Microsoft YaHei,Arial,sans-serif}main.dashboard-layout{max-width:none;margin:0;animation:.35s ease-out pageFadeIn}main{max-width:1180px;margin:0 auto;animation:.35s ease-out pageFadeIn}.home-layout{gap:16px;width:100%;max-width:none;min-height:100vh;margin:0;padding:24px;display:flex}.home-sidebar{background:#fff;border:1px solid #dbe3f0;border-radius:12px;width:240px;min-width:240px;min-height:calc(100vh - 48px);padding:14px;position:sticky;top:24px}.home-sidebar-title{color:#0f172a;margin:0 0 12px;font-size:15px}.home-sidebar-nav{flex-direction:column;gap:8px;display:flex}.home-sidebar-subtitle{color:#000;margin-top:10px;margin-bottom:2px;font-size:13px;font-weight:700}.home-sidebar-link{color:#1e40af;background:#eff6ff;border:1px solid #dbeafe;border-radius:10px;padding:8px 10px;font-size:14px;text-decoration:none;display:block}.home-content{flex:1;min-width:0}.dashboard-layout{gap:16px;width:100%;max-width:none;height:100vh;margin:0;padding:24px;display:flex;overflow:hidden}.dashboard-sidebar{background:#fff;border:1px solid #dbe3f0;border-radius:12px;width:280px;min-width:280px;height:calc(100vh - 48px);padding:18px;position:sticky;top:24px;overflow-y:auto}.dashboard-sidebar-title{color:#0f172a;margin:0 0 12px;font-size:17px}.dashboard-sidebar-subtitle{color:#000;margin:18px 0 10px;font-size:14px}.dashboard-sidebar-group{flex-direction:column;gap:10px;display:flex}.dashboard-sidebar-link{color:#1e3a8a;background:#f8fafc;border:1px solid #dbe3f0;border-radius:10px;align-items:center;gap:8px;padding:10px 12px;font-size:14px;text-decoration:none;display:inline-flex}.dashboard-sidebar-link-active{color:#1e3a8a;background:#e9eefb;border-color:#1e3a8a;font-weight:700}.dashboard-sidebar-actions{margin-top:20px}.dashboard-logout-button{color:#b91c1c;cursor:pointer;background:#fff1f2;border:1px solid #fecaca;border-radius:10px;justify-content:center;align-items:center;gap:6px;width:100%;padding:10px 12px;font-size:15px;font-weight:700;display:inline-flex}.dashboard-content{flex:1;min-width:0;height:calc(100vh - 48px);overflow-y:auto}.glass-topbar{z-index:20;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff9e;border:1px solid #94a3b859;border-radius:12px;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;padding:10px 14px;display:flex;position:sticky;top:12px;box-shadow:0 6px 18px #0f172a0f}.glass-topbar-title{color:#1e3a8a;font-size:14px;font-weight:700}.glass-topbar-meta{color:#000;font-size:12px}.mobile-hamburger,.sidebar-close-btn,.sidebar-overlay{display:none}@media (max-width:900px){.home-layout{flex-direction:column}.home-sidebar{width:100%;min-width:0;position:static}.dashboard-layout{flex-direction:column;gap:0;padding:0}.dashboard-content{height:100dvh}.glass-topbar{border-radius:0;margin-bottom:8px;padding:10px 12px;top:0}.mobile-hamburger{cursor:pointer;background:0 0;border:none;flex-direction:column;gap:4px;padding:4px;display:inline-flex}.hamburger-line{background:#1e3a8a;border-radius:2px;width:20px;height:2px;display:block}.dashboard-sidebar{z-index:100;border-radius:0;width:280px;max-width:85vw;height:100dvh;padding-top:50px;transition:transform .25s;position:fixed;top:0;left:0;transform:translate(-100%)}.dashboard-sidebar.open{transform:translate(0)}.sidebar-close-btn{color:#374151;cursor:pointer;z-index:101;background:0 0;border:1px solid #d1d5db;border-radius:6px;width:32px;height:32px;font-size:16px;display:block;position:absolute;top:10px;right:12px}.sidebar-overlay{z-index:99;background:#0006;display:none;position:fixed;inset:0}.sidebar-overlay.open{display:block}table{white-space:nowrap;-webkit-overflow-scrolling:touch;max-width:100%;font-size:12px;display:block;overflow-x:auto}thead,tbody,tr,th,td{white-space:nowrap}.dashboard-content>*{padding-left:0;padding-right:0}.dashboard-panel,.dashboard-grid-2{grid-template-columns:1fr;gap:8px;padding:10px}.order-fields,.prealert-fields{grid-template-columns:1fr;gap:6px}.order-summary-row{grid-template-columns:repeat(2,1fr);gap:4px;font-size:12px}button{touch-action:manipulation;min-height:36px}input,select,textarea{font-size:16px}.glass-topbar-title{font-size:13px}.hide-on-mobile{display:none}}header{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);box-shadow:0 8px 24px #0f172a0f;border:1px solid var(--line-soft)!important}section{background:#fff;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 12px #0f172a08;border:1px solid var(--line-soft)!important}section:hover{transform:translateY(-1px);box-shadow:0 12px 24px #0f172a14}input,textarea,select{background:#fff;transition:border-color .18s,box-shadow .18s;border:1px solid #cbd5e1!important}input:focus,textarea:focus,select:focus{outline:none;box-shadow:0 0 0 3px #1d4ed826;border-color:var(--brand)!important}button{isolation:isolate;border-radius:10px;transition:transform .14s,box-shadow .14s,background-color .14s;position:relative;overflow:hidden;box-shadow:0 4px 10px #0f172a14}button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 20px #0f172a1f}button:active:not(:disabled){transform:translateY(0)scale(.98)}button:after{content:"";opacity:0;pointer-events:none;background:#ffffff73;border-radius:999px;width:12px;height:12px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(0)}button:active:not(:disabled):after{animation:.45s ease-out buttonRipple}button:disabled{opacity:.72;cursor:not-allowed!important}button:not([style*="background: #fff"]):not([style*="background:#fff"]):not([style*="background: transparent"]):not([style*=background\:transparent]){color:#fff;background:linear-gradient(145deg,#4f46e5,#1e3a8a)}a{transition:color .15s,opacity .15s}a:hover{opacity:.9;color:var(--brand-hover)!important}pre{overflow-x:auto}.biz-title{letter-spacing:.2px}.biz-subtitle{color:var(--text-sub)}.badge-line{color:#1e3a8a;background:#eff6ff;border:1px solid #dbeafe;border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;display:inline-flex}.step-guide{flex-wrap:wrap;gap:8px;margin-bottom:10px;display:flex}.step-item{color:#1e3a8a;background:#eff6ff;border:1px dashed #bfdbfe;border-radius:999px;align-items:center;gap:6px;padding:6px 10px;font-size:12px;display:inline-flex}.step-item-done{color:#166534;background:#ecfdf5;border-style:solid;border-color:#86efac}.step-item-done .step-index{background:#16a34a}.step-check{color:#16a34a;font-weight:700}.step-index{color:#fff;background:var(--brand);border-radius:999px;justify-content:center;align-items:center;width:18px;height:18px;font-weight:700;display:inline-flex}.kpi-card{border:1px solid #e5e7eb;border-radius:10px;padding:10px}.dashboard-grid-2{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:12px;display:grid}.dashboard-panel{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:12px;transition:transform .2s,box-shadow .2s;box-shadow:0 1px 2px #0f172a0f}.dashboard-panel:hover{transform:translateY(-2px);box-shadow:0 8px 20px #0f172a14}.dashboard-panel-title{color:#1e3a8a;margin-bottom:8px;font-size:13px;font-weight:700}.route-map-wrap{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:12px;min-height:136px;padding:12px;position:relative}.route-point{color:#fff;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:600;position:absolute}.route-point-cn{background:#1e3a8a;top:18px;left:12px}.route-point-th{background:#10b981;bottom:18px;right:12px}.route-line{height:2px;position:absolute;left:84px;right:84px}.route-line-sea{background:#1e3a8a;top:42px}.route-line-land{background:#f59e0b;bottom:42px}.route-counter{color:#0f172a;background:#fff;border:1px solid #dbe3f0;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.kpi-flash{animation:.55s ease-out kpiFlash}.typing-dots{align-items:center;gap:3px;display:inline-flex}.typing-dots>span{opacity:.35;background:#000;border-radius:999px;width:6px;height:6px;animation:1s infinite typingDot}.typing-dots>span:nth-child(2){animation-delay:.15s}.typing-dots>span:nth-child(3){animation-delay:.3s}.shell-skeleton{gap:12px;display:grid}.skeleton{background:linear-gradient(90deg,#e2e8f0 20%,#f1f5f9 45%,#e2e8f0 80%) 0 0/220% 100%;border-radius:10px;animation:1.2s linear infinite skeletonShimmer}.skeleton-title{width:220px;height:28px}.skeleton-subtitle{width:360px;max-width:90%;height:14px}.skeleton-line{width:100%;height:14px}.empty-card{text-align:center;background:#f8fbff;border:1px dashed #bfdbfe;border-radius:12px;padding:16px}.empty-ill{background:#eff6ff;border:1px solid #dbeafe;border-radius:10px;width:170px;margin:0 auto 10px;padding:10px}.empty-truck{width:92px;height:34px;margin:0 auto 10px;position:relative}.empty-truck-cabin{background:#1e3a8a;border-radius:5px;width:24px;height:16px;position:absolute;top:8px;left:0}.empty-truck-body{background:#3b82f6;border-radius:6px;width:60px;height:20px;position:absolute;top:4px;left:20px}.empty-truck-wheel{background:#1e293b;border-radius:999px;width:10px;height:10px;position:absolute;bottom:0}.empty-truck-wheel-left{left:20px}.empty-truck-wheel-right{right:10px}.empty-route{background:#bfdbfe;border-radius:999px;width:120px;height:4px;margin:0 auto 8px}.empty-line{background:#bfdbfe;border-radius:999px;height:8px;margin:6px 0 0}.empty-line.short{width:70%;margin-left:auto;margin-right:auto}.empty-title{color:#1e3a8a;font-weight:600}.empty-desc{color:#000;margin-top:4px;font-size:13px}.biz-toast{z-index:200;color:#fff;border-radius:10px;min-width:220px;max-width:360px;padding:10px 12px;animation:.22s ease-out toastSlide;position:fixed;top:18px;right:18px;box-shadow:0 12px 28px #0f172a38}.biz-toast-success{background:#10b981}.biz-toast-error{background:#dc2626}.order-card{background:#fff;border:1px solid #dbe3f0;border-radius:12px;margin-bottom:12px;padding:12px;transition:transform .16s,box-shadow .16s,border-color .16s}.order-card:hover{border-color:#93c5fd;transform:translateY(-2px);box-shadow:0 10px 24px #1e40af1f}.order-head{justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;display:flex}.order-title{color:#0f172a;font-weight:700}.order-badges{flex-wrap:wrap;gap:6px;display:inline-flex}.order-badge{color:#1e3a8a;background:#eff6ff;border:1px solid #dbeafe;border-radius:999px;align-items:center;padding:3px 10px;font-size:12px;display:inline-flex}.order-badge-sea{color:#92400e;background:#fffbeb;border-color:#fcd34d}.order-badge-land{color:#065f46;background:#ecfdf5;border-color:#a7f3d0}.order-badge-amount{color:#9a3412;background:#fff7ed;border-color:#fed7aa}.order-badge-unpaid{color:#991b1b;background:#fef2f2;border-color:#fecaca}.order-badge-paid{color:#166534;background:#f0fdf4;border-color:#bbf7d0}.order-fields{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px;display:grid}.order-field{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:8px 10px;transition:border-color .16s,background-color .16s}.order-field:hover{background:#f0f7ff;border-color:#bfdbfe}.order-field-label{color:#000;margin-bottom:2px;font-size:12px}.order-field-value{color:#0f172a;word-break:break-word;font-size:13px;font-weight:600}.order-summary-row{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px;margin-top:8px;margin-bottom:10px;display:grid}.order-summary-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;gap:2px;padding:8px 10px;display:grid}.order-summary-label{color:#000;font-size:11px}.order-summary-value{color:#0f172a;font-size:13px;font-weight:700}.order-detail-toggle{color:#1e3a8a;background:#fff;border:1px solid #1e3a8a;border-radius:10px;padding:8px 12px;font-size:12px;font-weight:700}.order-stepper{grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:8px;display:grid}.order-stepper-node{background:#fff;border:1px solid #e2e8f0;border-radius:999px;align-items:center;gap:6px;padding:6px 8px;display:inline-flex}.order-step-icon{background:0 0;border:2px solid #94a3b8;border-radius:999px;width:10px;height:10px;display:inline-block}.order-step-done{background:#1e3a8a;border-color:#1e3a8a}.order-step-active{background:#f59e0b;border-color:#f59e0b;animation:1.4s ease-out infinite stepPulse;box-shadow:0 0 #f59e0b73}.order-step-pending{background:0 0;border-color:#cbd5e1}.order-step-label{color:#000;font-size:12px}.prealert-card{background:#fffef7;border:1px solid #fcd34d;border-radius:10px;padding:10px}.prealert-head{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.prealert-title{color:#92400e;font-weight:700}.prealert-badge{color:#92400e;background:#fef3c7;border:1px solid #fcd34d;border-radius:999px;padding:2px 10px;font-size:12px}.prealert-fields{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:8px;display:grid}.prealert-field{background:#fff;border:1px solid #fde68a;border-radius:8px;padding:7px 9px}.prealert-label{color:#92400e;margin-bottom:2px;font-size:12px}.prealert-value{color:#451a03;word-break:break-word;font-size:13px;font-weight:600}.client-main-section{background:#fff;border-radius:14px;margin-bottom:8px;padding:16px;position:relative;overflow:hidden;box-shadow:0 6px 14px #0f172a0a;border:1px solid #cbd5e1!important}.client-main-section:before{content:"";background:#1e3a8a;width:100%;height:5px;position:absolute;top:0;left:0}.client-secondary-section{background:#fff;border-radius:12px;padding:14px;position:relative;overflow:hidden;box-shadow:0 6px 14px #0f172a0a;border:1px solid #cbd5e1!important}.client-query-section{background:#fff;border-radius:13px;padding:15px;position:relative;overflow:hidden;box-shadow:0 6px 14px #0f172a0a;border:1px solid #cbd5e1!important}.client-query-section:before,.client-secondary-section:before{content:"";width:100%;height:5px;position:absolute;top:0;left:0}.client-query-section:before{background:#f59e0b}.client-secondary-section:before{background:#1e3a8a}.section-divider{background:#e5e7eb;border-radius:999px;height:12px;margin:14px 0 16px}.section-label{letter-spacing:.2px;border-radius:999px;align-items:center;margin-bottom:10px;padding:4px 10px;font-size:12px;font-weight:700;display:inline-flex}.section-label-primary{color:#1e3a8a;background:#e9eefb;border:1px solid #1e3a8a}.section-label-secondary{color:#000;background:#f1f5f9;border:1px solid #cbd5e1}.section-label-query{color:#92400e;background:#fffbeb;border:1px solid #fcd34d}@keyframes buttonRipple{0%{opacity:.5;transform:translate(-50%,-50%)scale(0)}to{opacity:0;transform:translate(-50%,-50%)scale(26)}}@keyframes toastSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes kpiFlash{0%{background:#bfdbfeb3;box-shadow:0 0 #3b82f638}to{background:0 0;box-shadow:0 0 0 10px #3b82f600}}@keyframes typingDot{0%,80%,to{opacity:.35;transform:translateY(0)}40%{opacity:1;transform:translateY(-3px)}}@keyframes stepPulse{0%{box-shadow:0 0 #f59e0b73}70%{box-shadow:0 0 0 8px #f59e0b00}to{box-shadow:0 0 #f59e0b00}}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes skeletonShimmer{0%{background-position:200% 0}to{background-position:-100% 0}}.client-arrived-date-input::-webkit-calendar-picker-indicator{-webkit-appearance:none;display:none}.client-arrived-date-input{appearance:none}.staff-arrived-date-input::-webkit-calendar-picker-indicator{-webkit-appearance:none;display:none}.staff-shipment-date-input::-webkit-calendar-picker-indicator{-webkit-appearance:none;display:none}.staff-arrived-date-input,.staff-shipment-date-input{appearance:none}
