:root{font-family:PingFang SC,Microsoft YaHei,sans-serif;color:#24324a;background:#f3f6fb;line-height:1.5;font-weight:400;--primary-color: #2f6fed;--primary-soft: #e8f0ff;--success-color: #19a46d;--warning-color: #ef9b28;--danger-color: #d94c45;--border-color: #dfe6f2;--card-bg: #ffffff;--text-light: #6e7b91}*{box-sizing:border-box}body{margin:0;min-width:320px;color:#24324a;background:radial-gradient(circle at top left,rgba(47,111,237,.12),transparent 26%),linear-gradient(180deg,#f6f9ff,#eef3fb)}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}#app{min-height:100vh}.app-shell{width:100%;margin:0 auto;padding:20px 16px 40px}.mobile-page{max-width:480px}.desktop-page{max-width:1200px}.page-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:16px;padding:20px;box-shadow:0 10px 24px #1f37580f}.page-card+.page-card{margin-top:16px}.page-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.page-header h1,.page-card h2,.page-card h3,.page-card p{margin-top:0}.page-header__terminal{margin-bottom:6px;color:var(--text-light);font-size:14px}.page-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:20px}.page-actions>*{flex:1 1 0}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:0 18px;border-radius:999px;border:1px solid transparent;background:var(--primary-color);color:#fff;cursor:pointer}.btn-secondary{border-color:var(--border-color);background:#fff;color:#24324a}.status-tag{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;background:#eef3ff;color:var(--primary-color);font-size:13px;font-weight:600}.status-pending_confirm,.status-confirmed,.status-pending_assign{background:#eef3ff;color:#335fd1}.status-assigned,.status-worker_departed,.status-arrived,.status-in_service{background:#e8faf2;color:var(--success-color)}.status-pending_review,.status-aftersale{background:#fff4e5;color:var(--warning-color)}.status-completed{background:#e7f8ef;color:#12865a}.status-cancelled{background:#fdecec;color:var(--danger-color)}.empty-state{text-align:center;color:var(--text-light)}.field-group{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.field-group label{font-size:14px;font-weight:600}.field-group input,.field-group textarea,.field-group select{width:100%;padding:12px 14px;border:1px solid var(--border-color);border-radius:12px;background:#fff}.field-group textarea{min-height:96px;resize:vertical}.info-list{display:flex;flex-direction:column;gap:12px}.info-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;color:var(--text-light);font-size:14px}.info-row strong{color:#24324a;text-align:right}.tag-list{display:flex;flex-wrap:wrap;gap:8px}.soft-tag{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:var(--primary-soft);color:var(--primary-color);font-size:13px}.customer-page{min-height:100vh;background:radial-gradient(circle at top,rgba(255,236,220,.9),transparent 30%),linear-gradient(180deg,#fffaf6,#f7f9fd)}.customer-page__inner{max-width:480px;margin:0 auto;padding:18px 14px 92px}.customer-page__header{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px}.customer-page__back{min-width:68px}.customer-page__subtitle{margin:0 0 4px;color:var(--text-light);font-size:13px}.customer-page__title{margin:0;font-size:24px}.customer-tabbar{position:fixed;left:50%;bottom:0;z-index:20;display:grid;grid-template-columns:repeat(4,1fr);width:min(480px,100%);transform:translate(-50%);padding:10px 12px calc(10px + env(safe-area-inset-bottom));border-top:1px solid var(--border-color);background:#fffffff2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.customer-tabbar__item{display:flex;justify-content:center;padding:10px 0;border-radius:12px;color:var(--text-light);font-size:14px}.customer-tabbar__item.is-active{background:var(--primary-soft);color:var(--primary-color);font-weight:600}.hero-card{background:linear-gradient(135deg,#fff7f0,#fff 56%,#eef5ff)}.brand-mark{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:#fff;color:#cf7a32;font-size:13px;font-weight:700}.stats-grid,.two-col-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.stats-grid .page-card,.two-col-grid .page-card{padding:16px}.service-card{display:block}.service-card__top,.order-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.service-card__category,.order-card__time,.muted-text{color:var(--text-light);font-size:13px}.service-card__badge{display:inline-flex;padding:6px 10px;border-radius:999px;background:#fff3e7;color:#d07d2c;font-size:12px}.service-card__desc{color:#556176;margin:12px 0}.service-card__meta{display:flex;justify-content:space-between;gap:12px;margin-bottom:14px}.service-card__action{margin-top:16px;color:var(--primary-color);font-weight:600}.trust-badge{text-align:left}.trust-badge h3,.trust-badge p,.service-card h3,.order-card__service{margin:0}.trust-badge p{margin-top:8px;color:var(--text-light)}.section-title{margin:0 0 12px;font-size:18px}.timeline{display:flex;flex-direction:column;gap:12px}.timeline-item{display:flex;gap:12px}.timeline-item__dot{width:12px;height:12px;margin-top:4px;border-radius:50%;background:var(--primary-color);flex-shrink:0}.timeline-item__content p{margin:0}.fixed-action-bar{position:sticky;bottom:78px;margin-top:16px}.plain-list{margin:0;padding-left:18px;color:#556176}.menu-list{display:flex;flex-direction:column;gap:10px}.menu-item{display:flex;align-items:center;justify-content:space-between;gap:12px}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip{padding:8px 12px;border:1px solid var(--border-color);border-radius:999px;background:#fff;color:#556176}.chip.is-active{border-color:var(--primary-color);background:var(--primary-soft);color:var(--primary-color)}.cover-avatar{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#ffcf9b,#ffc29f);color:#7f4308;font-size:24px;font-weight:700}.split-header{display:flex;align-items:center;gap:14px}.top-gap{margin-top:16px}.dispatcher-layout{display:grid;grid-template-columns:240px minmax(0,1fr);min-height:100vh;background:#f4f7fb}.dispatcher-sidebar{position:sticky;top:0;height:100vh;padding:24px 18px;background:linear-gradient(180deg,#24324a,#2e4261);color:#fff}.dispatcher-sidebar__brand{display:flex;flex-direction:column;gap:6px;margin-bottom:28px}.dispatcher-sidebar__brand span{color:#ffffffb3;font-size:13px}.dispatcher-sidebar__nav{display:flex;flex-direction:column;gap:8px}.dispatcher-sidebar__item{display:flex;align-items:center;min-height:42px;padding:0 14px;border-radius:12px;color:#ffffffd1}.dispatcher-sidebar__item.is-active{background:#ffffff24;color:#fff;font-weight:600}.dispatcher-layout__main{padding:22px}.dispatcher-layout__header{display:flex;align-items:flex-start;justify-content:space-between;gap:20px}.dispatcher-layout__header h1{margin:0}.dispatcher-layout__meta{margin:0 0 4px;color:var(--text-light);font-size:13px}.dispatcher-layout__user{display:flex;align-items:center;gap:12px}.dispatcher-layout__avatar{width:48px;height:48px;font-size:18px}.dispatcher-layout__content{display:flex;flex-direction:column;gap:16px;margin-top:16px}.dispatcher-grid-2,.dispatcher-grid-3,.dispatcher-grid-4{display:grid;gap:16px}.dispatcher-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.dispatcher-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.dispatcher-grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.dispatcher-stat-card__title{margin:0;color:var(--text-light);font-size:13px}.dispatcher-stat-card h3{margin:8px 0 4px;font-size:28px}.dispatcher-table__rows{display:flex;flex-direction:column;gap:14px}.dispatcher-table__head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.dispatcher-table__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px 16px;margin-top:16px}.dispatcher-section__header{display:flex;align-items:center;justify-content:space-between;gap:12px}.dispatcher-record{padding:14px 0;border-bottom:1px solid var(--border-color)}.dispatcher-record:last-child{border-bottom:0}.dispatcher-check-item{display:flex;align-items:center;gap:10px}.dispatcher-progress-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}.dispatcher-progress-actions .btn,.dispatcher-progress-actions .chip{flex:0 0 auto}.admin-layout{display:grid;grid-template-columns:240px minmax(0,1fr);min-height:100vh;background:#f5f7fb}.admin-sidebar{position:sticky;top:0;height:100vh;padding:24px 18px;background:linear-gradient(180deg,#1f2d44,#2c3f5d);color:#fff}.admin-sidebar__brand{display:flex;flex-direction:column;gap:6px;margin-bottom:26px}.admin-sidebar__brand span{color:#ffffffb3;font-size:13px}.admin-sidebar__nav{display:flex;flex-direction:column;gap:8px}.admin-sidebar__item{display:flex;align-items:center;min-height:42px;padding:0 14px;border-radius:12px;color:#ffffffd1}.admin-sidebar__item.is-active{background:#ffffff24;color:#fff;font-weight:600}.admin-layout__main{padding:22px}.admin-layout__content{display:flex;flex-direction:column;gap:16px;margin-top:16px}.admin-layout__header h1{margin:0}.admin-grid-2,.admin-grid-3,.admin-grid-4{display:grid;gap:16px}.admin-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.admin-grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.admin-stat-card__title{margin:0;color:var(--text-light);font-size:13px}.admin-stat-card h3{margin:8px 0 4px;font-size:28px}.admin-section__header{display:flex;align-items:center;justify-content:space-between;gap:12px}.admin-table{overflow:auto}.admin-table table{width:100%;border-collapse:collapse}.admin-table th,.admin-table td{padding:12px 10px;border-bottom:1px solid var(--border-color);text-align:left;vertical-align:top;font-size:14px}.admin-table th{color:var(--text-light);font-weight:600}.admin-drawer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40}.admin-drawer__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#151f2f59}.admin-drawer__panel{position:absolute;top:0;right:0;width:min(520px,100%);height:100%;overflow:auto;padding:20px;background:#fff;box-shadow:-8px 0 24px #1828401f}.bar-list{display:flex;flex-direction:column;gap:10px}.bar-item{display:grid;grid-template-columns:120px 1fr 56px;align-items:center;gap:12px}.bar-item__header{display:contents}.bar-track{height:10px;border-radius:999px;background:#ecf1f9;overflow:hidden}.bar-fill{height:100%;background:linear-gradient(90deg,#5d85f6,#79b5ff)}.table-actions{display:flex;flex-wrap:wrap;gap:8px}.wrap-actions{margin-bottom:8px}.select-input{min-height:40px;padding:0 12px;border:1px solid var(--border-color);border-radius:12px;background:#fff;color:#24324a}.detail-stack{display:flex;flex-direction:column;gap:16px}.info-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px 16px}.simple-list{display:flex;flex-direction:column;gap:8px;margin:0;padding-left:18px}.compact-list{display:flex;flex-direction:column;gap:6px}.compact-tip{margin:8px 0 0}.worker-page{min-height:100vh;background:linear-gradient(180deg,#f6f8fc,#eef3f8)}.worker-page__inner{max-width:480px;margin:0 auto;padding:18px 14px 92px}.worker-page__header{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px}.worker-page__title{margin:0;font-size:24px}.worker-page__subtitle{margin:0 0 4px;color:var(--text-light);font-size:14px}.worker-page__back{min-width:68px}.worker-tabbar{position:fixed;left:50%;bottom:0;z-index:20;display:grid;grid-template-columns:repeat(2,1fr);width:min(480px,100%);transform:translate(-50%);padding:10px 12px calc(10px + env(safe-area-inset-bottom));border-top:1px solid var(--border-color);background:#fffffff7}.worker-tabbar__item{display:flex;justify-content:center;padding:12px 0;border-radius:12px;color:var(--text-light);font-size:15px}.worker-tabbar__item.is-active{background:#eaf1ff;color:var(--primary-color);font-weight:700}.worker-task-card__head,.worker-upload{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.worker-primary-btn{min-height:48px;font-size:16px;font-weight:700}.worker-check-item{display:flex;align-items:center;gap:10px;font-size:15px}.worker-login-card h3,.worker-task-card h3{margin:0}.worker-login-card .page-actions,.worker-task-card .page-actions{margin-top:16px}.worker-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}@media (max-width: 768px){.worker-upload{flex-direction:column}}@media (max-width: 1200px){.dispatcher-grid-4,.dispatcher-grid-3,.admin-grid-4,.admin-grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 900px){.dispatcher-layout,.admin-layout{grid-template-columns:1fr}.dispatcher-sidebar,.admin-sidebar{position:static;height:auto}.dispatcher-grid-2,.dispatcher-grid-3,.dispatcher-grid-4,.dispatcher-table__grid,.admin-grid-2,.admin-grid-3,.admin-grid-4,.info-grid{grid-template-columns:1fr}.dispatcher-layout__header{flex-direction:column}}@media (max-width: 768px){.page-header{flex-direction:column;align-items:flex-start}}
