:root{--primary: #4f6ef7;--primary-dark: #3b54c9;--primary-light: #eef2ff;--primary-gradient: linear-gradient(135deg, #5b73f7 0%, #3a56d4 100%);--success: #34d399;--success-bg: #ecfdf5;--warning: #fbbf24;--warning-bg: #fffbeb;--danger: #f87171;--danger-bg: #fef2f2;--bg: #f5f6fa;--card: #ffffff;--text: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--border: #eef0f4;--border-light: #f1f3f7;--shadow-sm: 0 1px 3px rgba(0,0,0,.04), 0 1px 2px rgba(0,0,0,.02);--shadow-md: 0 4px 12px rgba(0,0,0,.06), 0 1px 3px rgba(0,0,0,.04);--shadow-lg: 0 10px 30px rgba(0,0,0,.08);--radius-sm: 10px;--radius-md: 14px;--radius-lg: 18px;--radius-xl: 22px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,Roboto,PingFang SC,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{max-width:430px;margin:0 auto;min-height:100vh;position:relative;background:var(--bg)}.top-bar{background:var(--primary-gradient);color:#fff;padding:16px 20px;padding-top:max(16px,env(safe-area-inset-top));font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.top-bar .greeting{font-size:13px;opacity:.85;font-weight:500;display:flex;align-items:center;gap:5px}.page{padding:18px 18px 100px}.page-title{font-size:17px;font-weight:700;margin-bottom:14px;color:var(--text);letter-spacing:-.01em}.quick-stats{display:flex;gap:10px;margin-bottom:18px}.quick-stat{flex:1;background:var(--card);border-radius:var(--radius-md);padding:16px 12px;text-align:center;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.quick-stat:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--primary-gradient);border-radius:var(--radius-md) var(--radius-md) 0 0}.quick-stat .val{font-size:26px;font-weight:800;color:var(--primary);line-height:1.2}.quick-stat .lbl{font-size:12px;color:var(--text-muted);margin-top:4px;font-weight:500}.action-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.action-card{background:var(--card);border-radius:var(--radius-lg);padding:24px 16px;text-align:center;box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s;border:1.5px solid transparent;position:relative;overflow:hidden}.action-card:hover{border-color:#4f6ef726}.action-card:active{transform:scale(.96)}.action-card.disabled{opacity:.42;pointer-events:none}.action-card .icon-wrap{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;font-size:26px}.action-card:nth-child(1) .icon-wrap{background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.action-card:nth-child(2) .icon-wrap{background:linear-gradient(135deg,#dcfce7,#bbf7d0)}.action-card:nth-child(3) .icon-wrap{background:linear-gradient(135deg,#fef3c7,#fde68a)}.action-card:nth-child(4) .icon-wrap{background:linear-gradient(135deg,#fce7f3,#fbcfe8)}.action-card .label{font-size:15px;font-weight:700;color:var(--text);margin-bottom:3px}.action-card .desc{font-size:12px;color:var(--text-muted)}.action-card .badge{display:inline-block;background:var(--warning-bg);color:#d97706;font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;margin-top:6px}.stepper{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:20px;padding:0 8px}.step-item{display:flex;align-items:center;gap:6px;cursor:pointer;position:relative;-webkit-user-select:none;user-select:none}.step-dot{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;transition:all .3s ease;border:2.5px solid var(--border);background:var(--card);color:var(--text-muted)}.step-label{font-size:12px;font-weight:500;color:var(--text-muted);white-space:nowrap;transition:color .3s;max-width:60px;overflow:hidden;text-overflow:ellipsis}.step-line{width:28px;height:2.5px;background:var(--border);border-radius:2px;margin:0 4px;flex-shrink:0;transition:background .3s}.step-item.active .step-dot{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 0 0 4px #4f6ef726}.step-item.active .step-label{color:var(--primary);font-weight:700}.step-item.done .step-dot{background:var(--success);border-color:var(--success);color:#fff;font-size:13px}.step-item.done .step-label{color:var(--success)}.step-line.done{background:var(--success)}.step-container{min-height:calc(100vh - 240px)}.step-fade-enter-active{animation:stepFadeIn .25s ease-out}@keyframes stepFadeIn{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.step-nav{display:flex;gap:10px;margin-top:20px;padding-bottom:4px}.step-nav button{flex:1;padding:13px;border-radius:var(--radius-md);font-size:15px;font-weight:600;border:none;cursor:pointer;transition:all .2s}.btn-next{background:var(--primary-gradient);color:#fff;box-shadow:0 4px 14px #4f6ef759}.btn-next:active{opacity:.85;transform:scale(.98)}.btn-prev{background:var(--card);color:var(--text-secondary);border:1.5px solid var(--border)!important;box-shadow:none}.btn-prev:active{background:var(--bg)}.form-section{background:var(--card);border-radius:var(--radius-md);padding:18px;margin-bottom:14px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.form-section .section-title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:14px;padding-bottom:10px;border-bottom:1.5px solid var(--border-light);display:flex;align-items:center;gap:8px;letter-spacing:-.01em}.form-group{margin-bottom:14px}.form-group:last-child{margin-bottom:0}.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.form-group label .req{color:var(--danger);margin-left:2px}.form-group input,.form-group textarea,.form-group select{width:100%;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;font-size:15px;outline:none;transition:all .2s;background:#fafbfc;color:var(--text);line-height:1.4}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--primary);background:var(--card);box-shadow:0 0 0 3px #4f6ef714}.form-group textarea{min-height:72px;resize:vertical}.form-group select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 8L1 3h10z' fill='%2394a3b8'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:34px}.form-row{display:flex;gap:10px}.form-row .form-group{flex:1;min-width:0}.form-hint{font-size:12px;color:var(--text-muted);margin-top:4px}.photo-area{display:flex;gap:10px;flex-wrap:wrap}.photo-slot{width:78px;height:78px;border:2px dashed #d4dae6;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:28px;color:#c0cad8;cursor:pointer;position:relative;overflow:hidden;background:#fafbfc;flex-shrink:0;transition:border-color .2s}.photo-slot:hover{border-color:var(--primary)}.photo-slot img{width:100%;height:100%;object-fit:cover}.photo-slot .del{position:absolute;top:0;right:0;background:#ef4444d9;color:#fff;width:22px;height:22px;border-radius:0 8px;display:flex;align-items:center;justify-content:center;font-size:13px;cursor:pointer;line-height:1}.btn-primary{width:100%;background:var(--primary-gradient);color:#fff;border:none;border-radius:var(--radius-md);padding:15px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s;margin-top:8px;box-shadow:0 4px 14px #4f6ef74d;letter-spacing:.02em}.btn-primary:active{opacity:.88;transform:translateY(1px);box-shadow:0 2px 8px #4f6ef740}.btn-primary:disabled{opacity:.48;cursor:not-allowed;box-shadow:none}.btn-secondary{width:100%;background:var(--card);color:var(--primary);border:1.5px solid var(--primary);border-radius:var(--radius-md);padding:13px;font-size:15px;font-weight:600;cursor:pointer;margin-top:8px}.btn-danger{width:100%;background:var(--card);color:var(--danger);border:1.5px solid var(--danger);border-radius:var(--radius-md);padding:13px;font-size:15px;font-weight:600;cursor:pointer;margin-top:8px}.trip-select-item{background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:14px 16px;margin-bottom:10px;cursor:pointer;transition:all .15s;box-shadow:var(--shadow-sm)}.trip-select-item:active{border-color:var(--primary);background:var(--primary-light)}.trip-select-item .ts-plate{font-size:17px;font-weight:800;color:var(--text)}.trip-select-item .ts-meta{font-size:13px;color:var(--text-secondary);margin-top:5px;display:flex;gap:12px;flex-wrap:wrap}.supplement-section{border:2px dashed #fcd34d}.supplement-section .section-title{cursor:pointer;-webkit-user-select:none;user-select:none}.history-item{background:var(--card);border-radius:var(--radius-md);padding:14px 16px;margin-bottom:10px;box-shadow:var(--shadow-sm)}.history-item .hi-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.history-item .hi-plate{font-size:16px;font-weight:700}.history-item .hi-status{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}.hi-departing{background:var(--primary-light);color:var(--primary)}.hi-returned{background:var(--success-bg);color:#059669}.history-item .hi-row{font-size:13px;color:var(--text-secondary);margin-top:3px;display:flex;gap:10px;flex-wrap:wrap}.history-item .hi-customer{color:var(--text);font-weight:600}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:430px;background:#ffffffeb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(0,0,0,.05);display:flex;z-index:100;box-shadow:0 -4px 20px #0000000a;padding-bottom:env(safe-area-inset-bottom)}.bottom-nav .nav-item{flex:1;text-align:center;padding:8px 0 6px;font-size:11px;color:var(--text-muted);cursor:pointer;transition:color .2s;position:relative}.bottom-nav .nav-item.active{color:var(--primary);font-weight:600}.bottom-nav .nav-item .nav-icon{width:26px;height:26px;margin:0 auto 2px;display:flex;align-items:center;justify-content:center}.bottom-nav .nav-item .nav-icon svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:all .2s}.bottom-nav .nav-item.active .nav-icon svg{stroke-width:2.2}.profile-card{background:var(--card);border-radius:var(--radius-lg);padding:28px 20px;text-align:center;box-shadow:var(--shadow-sm);margin-bottom:14px}.profile-avatar{width:68px;height:68px;border-radius:50%;background:var(--primary-gradient);color:#fff;font-size:28px;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;box-shadow:0 4px 14px #4f6ef74d}.profile-name{font-size:19px;font-weight:800}.profile-no{font-size:13px;color:var(--text-muted);margin-top:4px}.profile-stats{display:flex;gap:24px;margin-top:20px;justify-content:center}.profile-stat{text-align:center}.profile-stat .ps-val{font-size:22px;font-weight:800;color:var(--primary)}.profile-stat .ps-lbl{font-size:11px;color:var(--text-muted);margin-top:2px}.toast-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999;display:flex;align-items:center;justify-content:center;pointer-events:none}.toast-box{background:#0f172ad9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;padding:13px 26px;border-radius:var(--radius-md);font-size:14px;font-weight:500;max-width:80%;text-align:center;box-shadow:var(--shadow-lg)}.loading-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#ffffff8c;z-index:998;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.spinner{width:32px;height:32px;border:3.5px solid #e2e8f0;border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:40px 32px}.login-logo{font-size:56px;margin-bottom:18px;filter:drop-shadow(0 4px 12px rgba(79,110,247,.25))}.login-title{font-size:23px;font-weight:800;color:var(--text);margin-bottom:4px}.login-desc{font-size:14px;color:var(--text-muted);margin-bottom:28px}.login-form{width:100%;max-width:280px}.login-form .form-group{margin-bottom:14px}.login-form .form-group input{padding:13px 15px}.login-divider{width:100%;max-width:280px;display:flex;align-items:center;gap:12px;margin:18px 0;color:var(--text-muted);font-size:13px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border)}.login-btn-wecom{width:100%;max-width:280px;background:#07c160;color:#fff;border:none;border-radius:var(--radius-md);padding:14px;font-size:16px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #07c1604d}.login-btn-wecom:active{opacity:.85}.login-tip{font-size:12px;color:var(--text-muted);margin-top:8px}.empty-state{text-align:center;color:var(--text-muted);padding:50px 0}.empty-state .icon{font-size:48px;margin-bottom:10px;opacity:.5}.draft-bar{background:#fef9c3;border:1.5px solid #facc15;border-radius:var(--radius-md);padding:12px 16px;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:13px;box-shadow:var(--shadow-sm)}.draft-bar .draft-msg{color:#854d0e;flex:1;font-weight:500}.draft-bar .draft-actions{display:flex;gap:6px;flex-shrink:0}.draft-bar button{border:none;border-radius:8px;padding:6px 14px;font-size:13px;font-weight:600;cursor:pointer}.draft-bar .btn-restore{background:#facc15;color:#713f12}.draft-bar .btn-dismiss{background:var(--bg);color:var(--text-muted)}.vehicle-confirm{background:var(--primary-light);border:1.5px solid #bfdbfe}.vehicle-confirm .section-title{color:#1d4ed8;border-bottom-color:#bfdbfe}.vehicle-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 14px}.vi-item{padding:4px 0}.vi-label{font-size:12px;color:var(--text-muted)}.vi-value{font-size:14px;font-weight:600;color:var(--text)}.vi-ok{color:#059669!important}.vi-out{color:#d97706!important}.vi-loading{font-size:13px;color:var(--primary);display:flex;align-items:center;gap:6px;margin-top:8px}.vi-loading .dot-pulse{display:inline-flex;gap:3px}.vi-loading .dot-pulse span{width:5px;height:5px;border-radius:50%;background:var(--primary);animation:dotBounce 1.2s infinite}.vi-loading .dot-pulse span:nth-child(2){animation-delay:.2s}.vi-loading .dot-pulse span:nth-child(3){animation-delay:.4s}@keyframes dotBounce{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.new-vehicle{background:#fffbeb;border:1.5px solid #fcd34d}.new-vehicle .section-title{color:#b45309}.new-vehicle .form-hint{margin-top:8px;color:#d97706}.filter-btn{padding:7px 16px;border-radius:20px;border:1.5px solid;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.filter-btn.active{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}.filter-btn.inactive{border-color:var(--border);background:var(--card);color:var(--text-muted)}
