:root{--bg: #f3f6fb;--panel: #ffffff;--text: #18202a;--muted: #738091;--primary: #165dff;--primary-soft: rgba(22, 93, 255, .1);--danger: #d9485f;--line: rgba(115, 128, 145, .14);--shadow: 0 24px 60px rgba(24, 32, 42, .08);--radius: 24px}*{box-sizing:border-box}html,body{margin:0;min-height:100%;font-family:PingFang SC,Microsoft YaHei,sans-serif;background:radial-gradient(circle at top left,rgba(22,93,255,.1),transparent 28%),linear-gradient(180deg,#f9fbff 0%,var(--bg) 100%);color:var(--text)}body{min-width:1200px}button,input{font:inherit}.app-shell{min-height:100vh}.login-layout{min-height:100vh;max-width:1280px;margin:0 auto;padding:72px 32px;display:grid;grid-template-columns:1.2fr .8fr;gap:40px;align-items:center}.hero-title{margin:0 0 16px;max-width:680px;font-size:64px;line-height:1.08;font-weight:800}.hero-kicker{display:inline-block;margin-bottom:20px;color:var(--primary);font-size:14px;letter-spacing:.18em;font-weight:700;text-transform:uppercase}.panel{background:#ffffffeb;border-radius:28px;box-shadow:var(--shadow)}.login-panel{padding:32px}.panel-title{margin:0 0 28px;font-size:32px;font-weight:800}.field{margin-bottom:20px}.field label{display:block;margin-bottom:10px;color:var(--muted);font-size:14px}.field input{width:100%;height:52px;border:none;border-radius:16px;padding:0 16px;background:#eef3f8;color:var(--text);outline:none}.btn{border:none;border-radius:16px;cursor:pointer}.btn-primary{width:100%;height:54px;background:linear-gradient(135deg,#165dff,#2f7bff);color:#fff;font-weight:700}.btn-primary:disabled{opacity:.7;cursor:wait}.error-box{margin-bottom:18px;padding:14px 16px;border-radius:14px;background:#d9485f14;color:var(--danger);font-size:14px}.dashboard-layout{min-height:100vh;width:100%;max-width:none;margin:0;padding:28px 24px 40px 16px}.workspace{display:grid;grid-template-columns:240px minmax(0,1fr);gap:22px;align-items:start}.sidebar{padding:22px;align-self:start;position:sticky;top:28px}.workspace main{min-width:0}.sidebar-title{margin-bottom:14px;font-size:14px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}.sidebar-nav{display:flex;flex-direction:column;gap:18px}.sidebar-group{display:flex;flex-direction:column;gap:8px}.sidebar-group+.sidebar-group{padding-top:16px;border-top:1px solid var(--line)}.sidebar-group-title{padding:0 10px;color:var(--muted);font-size:12px;font-weight:700;letter-spacing:.06em}.sidebar-item{height:46px;text-align:left;padding:0 14px;border:none;border-radius:14px;background:transparent;color:var(--text);cursor:pointer}.sidebar-item.active{background:var(--primary-soft);color:var(--primary);font-weight:700}.topbar{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px}.topbar h1{margin:0;font-size:40px}.topbar p{margin:8px 0 0;color:var(--muted)}.topbar-actions{display:flex;align-items:center;gap:14px}.role-tag{padding:10px 16px;border-radius:999px;background:var(--primary-soft);color:var(--primary);font-size:13px;font-weight:700}.btn-ghost{height:40px;padding:0 16px;background:#eaf1ff;color:var(--primary)}.stats{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:18px;margin-bottom:22px}.stat-card{padding:22px}.stat-label{color:var(--muted);font-size:14px}.stat-value{margin-top:12px;font-size:36px;font-weight:800}.stat-value.danger{color:var(--danger)}.dashboard-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:22px}.content-stack{display:flex;flex-direction:column;gap:22px}.section-panel{padding:24px}.table-panel{padding:24px;overflow:hidden}.section-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:18px}.section-head h2{margin:0;font-size:24px}.section-head span{color:var(--muted);font-size:13px}.list{display:flex;flex-direction:column}.list-item{display:grid;grid-template-columns:1fr auto;gap:18px;padding:18px 0;border-bottom:1px solid var(--line)}.list-item:last-child{border-bottom:none;padding-bottom:0}.item-title{margin:0 0 8px;font-size:16px;font-weight:700}.item-desc{margin:0;color:var(--muted);font-size:14px;line-height:1.7}.item-side{text-align:right}.item-status{display:inline-block;padding:8px 12px;border-radius:999px;background:var(--primary-soft);color:var(--primary);font-size:12px;font-weight:700}.item-status.danger{background:#d9485f14;color:var(--danger)}.item-status.success{background:#1c7d541a;color:#1c7d54}.item-time{margin-top:10px;color:var(--muted);font-size:12px}.loading,.empty{padding:48px 16px;text-align:center;color:var(--muted)}.table{width:100%;min-width:1520px;border-collapse:collapse}.log-table{min-width:1280px}.user-table{min-width:1080px}.exception-table{min-width:1360px}.warehouse-print-table{min-width:1380px}.child-order-table{min-width:980px}.table-title{font-weight:700}.table-subtitle{margin-top:6px;color:var(--muted);font-size:12px}.table-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.print-goods-cell{max-width:360px;line-height:1.6}.table-scroll{width:100%;overflow-x:auto;overflow-y:hidden;padding-bottom:8px}.modal-table-scroll{margin-top:14px}.print-child-add-row{display:grid;grid-template-columns:minmax(0,1fr) 150px;gap:12px;margin-top:14px}.print-child-add-row input{width:100%;height:46px;border:none;border-radius:14px;padding:0 14px;background:#eef3f8;outline:none}.print-child-add-btn{height:46px}.table th,.table td{padding:16px 12px;text-align:left;border-bottom:1px solid var(--line);font-size:14px}.table th{color:var(--muted);font-weight:600}.table tr:last-child td{border-bottom:none}.exception-order-cell{min-width:190px}.exception-order-cell strong,.exception-order-cell span{display:block;white-space:nowrap}.exception-order-cell span{margin-top:4px;color:var(--muted);font-size:12px}.exception-content{min-width:240px;max-width:360px;white-space:normal;line-height:1.6}.empty-cell{padding:48px 16px!important;text-align:center!important;color:var(--muted)}.account-panel{padding:28px}.account-header{display:flex;align-items:center;gap:18px;margin-bottom:24px}.account-header h2{margin:0;font-size:28px}.account-header p{margin:8px 0 0;color:var(--muted)}.account-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#165dff,#2f7bff);color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700}.meta-section+.meta-section{margin-top:22px}.meta-label{margin-bottom:10px;color:var(--muted);font-size:14px}.meta-value{font-size:18px;font-weight:700}.meta-chips{display:flex;flex-wrap:wrap;gap:10px}.meta-chip{padding:10px 14px;border-radius:999px;background:var(--primary-soft);color:var(--primary);font-size:13px;font-weight:700}.create-user-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.create-user-grid input{width:100%;height:48px;border:none;border-radius:14px;padding:0 16px;background:#eef3f8;outline:none}.warehouse-address-field{display:flex;align-items:center;gap:10px;min-width:0}.create-user-grid .warehouse-address-field,.create-user-grid .warehouse-coordinate-note{grid-column:1 / -1}.warehouse-address-field input{flex:1;min-width:0}.warehouse-map-btn{flex:0 0 auto;height:48px;white-space:nowrap}.warehouse-coordinate-note{margin-top:-4px;color:var(--muted);font-size:12px}.search-row{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:18px}.search-row .btn{width:auto;min-width:128px;height:44px;padding:0 18px;border-radius:14px;flex:0 0 auto}.search-input{flex:1;height:44px;border:none;border-radius:14px;padding:0 16px;background:#eef3f8;outline:none}.search-input-compact{flex:0 0 150px}.search-select{min-width:168px;height:44px;border:none;border-radius:14px;padding:0 14px;background:#eef3f8;color:var(--text);outline:none}.warehouse-edit-select{width:100%;height:46px;border:none;border-radius:14px;padding:0 14px;background:#eef3f8;color:var(--text);outline:none}.list-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}.section-head-compact{margin-bottom:0}.toolbar-btn{width:auto;min-width:120px;padding:0 20px}.role-picker{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.role-picker-tight{margin-top:0}.role-picker-chip,.status-toggle{border:none;border-radius:999px;padding:10px 14px;background:#eef3f8;color:#51606f;cursor:pointer;font-size:13px;font-weight:700}.role-picker-chip.active{background:var(--primary-soft);color:var(--primary)}.user-create-btn{margin-top:18px;max-width:220px}.user-card{padding:24px}.user-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.user-card-head-actions{display:flex;align-items:center;gap:10px}.user-card-head h3{margin:0;font-size:20px}.user-card-head p{margin:8px 0 0;color:var(--muted);font-size:13px}.user-role-summary{display:flex;flex-wrap:wrap;gap:10px}.auth-editor{margin-top:18px;padding-top:18px;border-top:1px solid var(--line)}.auth-editor-head{margin-bottom:12px;font-size:14px;color:var(--muted)}.detail-grid{display:grid;grid-template-columns:1fr 180px;gap:16px;margin-bottom:18px}.detail-grid-single{grid-template-columns:1fr 1fr}.detail-field label{display:block;margin-bottom:10px;color:var(--muted);font-size:13px}.detail-field input{width:100%;height:46px;border:none;border-radius:14px;padding:0 14px;background:#eef3f8;outline:none}.detail-field-full{grid-column:1 / -1}.detail-static{min-height:46px;display:flex;align-items:center;padding:0 14px;border-radius:14px;background:#eef3f8;color:var(--text);font-weight:600}.detail-static-multiline{align-items:flex-start;padding-top:12px;padding-bottom:12px;line-height:1.7}.modal-card-compact{max-width:640px}.modal-card.modal-card-wide{width:min(920px,100%);max-height:calc(100vh - 48px);overflow-y:auto}.map-picker-toolbar{display:flex;gap:12px;margin-bottom:14px}.map-picker-toolbar input{flex:1;min-width:0;height:44px;border:none;border-radius:14px;padding:0 14px;background:#eef3f8;outline:none}.map-picker-toolbar .btn{width:auto;min-width:96px;height:44px}.map-picker-canvas{position:relative;height:420px;border-radius:16px;overflow:hidden;background:#eef3f8;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none}.map-picker-dragging{cursor:grabbing}.map-picker-fallback{display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:14px;font-weight:700;cursor:default}.map-picker-image{width:100%;height:100%;display:block;object-fit:cover;will-change:transform;pointer-events:none;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.map-picker-marker{position:absolute;left:50%;top:50%;width:22px;height:22px;border:3px solid #fff;border-radius:50% 50% 50% 0;background:var(--primary);box-shadow:0 8px 18px #18202a4d;transform:translate(-50%,-100%) rotate(-45deg);pointer-events:none}.map-picker-marker:after{content:"";position:absolute;top:5px;right:5px;bottom:5px;left:5px;border-radius:50%;background:#fff}.map-picker-hint{position:absolute;left:14px;top:14px;padding:9px 12px;border-radius:12px;background:#fffffff0;color:var(--text);box-shadow:0 8px 18px #18202a1f;font-size:12px;font-weight:800;pointer-events:none}.map-picker-zoom{position:absolute;right:14px;top:14px;display:grid;gap:8px}.map-picker-zoom button{width:38px;height:38px;border:none;border-radius:12px;background:#fffffff2;color:var(--text);box-shadow:0 8px 18px #18202a29;cursor:pointer;font-size:20px;font-weight:900}.map-picker-result{display:grid;grid-template-columns:1fr 180px 220px;gap:12px;margin-top:14px}.map-picker-result div{min-width:0;padding:12px 14px;border-radius:14px;background:#f7f9fc}.map-picker-result span{display:block;margin-bottom:6px;color:var(--muted);font-size:12px}.map-picker-result strong{display:block;overflow-wrap:anywhere;color:var(--text);font-size:14px}.flow-section{margin-top:8px;padding-top:18px;border-top:1px solid var(--line)}.flow-list{display:grid;gap:12px}.photo-section{margin-top:8px;padding-top:18px;border-top:1px solid var(--line)}.photo-list{display:grid;gap:16px}.photo-group-title{margin-bottom:10px;color:var(--text);font-size:14px;font-weight:800}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(118px,1fr));gap:10px}.photo-thumb{display:block;aspect-ratio:1;overflow:hidden;border-radius:12px;background:#eef3f8;border:1px solid var(--line);padding:0;cursor:pointer}.photo-thumb img{width:100%;height:100%;display:block;object-fit:cover}.photo-preview-mask{z-index:1150;background:#0a1018c7}.photo-preview-card{width:min(960px,100%)}.photo-preview-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;color:#fff;font-size:14px;font-weight:700}.photo-preview-body{position:relative;height:min(72vh,680px);display:flex;align-items:center;justify-content:center}.photo-preview-body img{max-width:100%;max-height:100%;display:block;border-radius:12px;object-fit:contain;box-shadow:0 24px 80px #00000047}.photo-preview-nav{position:absolute;top:50%;width:46px;height:46px;border:none;border-radius:50%;background:#ffffffeb;color:var(--text);font-size:32px;line-height:1;cursor:pointer;transform:translateY(-50%)}.photo-preview-nav:disabled{opacity:.45;cursor:default}.photo-preview-prev{left:12px}.photo-preview-next{right:12px}.flow-step{display:grid;grid-template-columns:14px 1fr;gap:12px;align-items:start}.flow-dot{width:12px;height:12px;margin-top:6px;border-radius:50%;background:#c9d3df}.flow-step.done .flow-dot{background:#1c7d54}.flow-step.current .flow-dot{background:var(--primary)}.flow-step.fail .flow-dot{background:var(--danger)}.flow-body{padding-bottom:12px;border-bottom:1px solid var(--line)}.flow-step:last-child .flow-body{border-bottom:none}.flow-title-row{display:flex;justify-content:space-between;gap:12px}.flow-title{font-weight:700}.flow-time,.flow-desc,.log-message,.log-url{color:var(--muted);font-size:13px}.flow-desc{margin-top:6px;line-height:1.6}.log-message,.log-url{max-width:260px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.payload-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.payload-grid label{display:block;margin-bottom:10px;color:var(--muted);font-size:13px}.payload-box{min-height:180px;max-height:320px;margin:0;overflow:auto;padding:14px;border-radius:14px;background:#eef3f8;color:var(--text);font-family:Consolas,Monaco,monospace;font-size:12px;line-height:1.6;white-space:pre-wrap;word-break:break-word}.auth-status-row{margin-top:14px}.auth-actions{display:flex;gap:12px;margin-top:16px}.auth-save-btn{width:auto;min-width:120px;padding:0 18px}.empty-inline{color:var(--muted);font-size:13px}.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#18202a57;display:flex;align-items:center;justify-content:center;padding:24px;z-index:1000}.modal-mask-soft{background:#18202a33;z-index:1100}.modal-card{width:min(680px,100%);background:#fffffffa;border-radius:24px;box-shadow:0 30px 80px #18202a33;padding:24px}.notice-banner{position:fixed;top:12px;left:50%;z-index:1200;display:flex;align-items:center;gap:10px;width:min(380px,calc(100vw - 32px));min-height:48px;padding:0 20px;border:1px solid #ffd0d0;border-radius:4px;background:#fff0f0;color:#ff4d4f;font-size:14px;transform:translate(-50%)}.notice-success{border-color:#c7f0d7;background:#f0fff6;color:#1f9d55}.notice-icon{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:currentColor;color:#fff;font-size:12px;line-height:1}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.modal-head h3{margin:0;font-size:22px}.modal-close{width:40px;height:40px;border:none;border-radius:50%;background:#eef3f8;color:var(--muted);font-size:24px;cursor:pointer}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:20px}.status-toggle{background:#165dff1a;color:var(--primary)}.status-toggle.danger{background:#d9485f14;color:var(--danger)}.pager{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:18px}.btn-page{height:42px;padding:0 18px;background:#eef3f8;color:var(--text)}.btn-danger{background:#d9485f14;color:var(--danger)}.btn-page:disabled{opacity:.5;cursor:not-allowed}.pager-text{color:var(--muted);font-size:13px}
