.app-sider[data-v-a2fe958d]{border-right:1px solid #f0f0f0;position:fixed;left:0;top:0;bottom:0;z-index:10;display:flex;flex-direction:column;overflow-y:auto}.app-sider[data-v-a2fe958d] .ant-layout-sider-children{display:flex;flex-direction:column}.sider-logo[data-v-a2fe958d]{height:56px;display:flex;align-items:center;padding:0 20px;gap:10px;cursor:pointer;border-bottom:1px solid #f0f0f0}.logo-text[data-v-a2fe958d]{font-size:16px;font-weight:700;color:#0f172a;white-space:nowrap}.logo-text-short[data-v-a2fe958d]{font-size:16px;font-weight:700;color:#0f172a}.sider-menu[data-v-a2fe958d]{flex:1;border-right:none!important;padding:8px}.sider-menu[data-v-a2fe958d] .ant-menu-item{border-radius:8px;margin-bottom:2px}.sider-menu[data-v-a2fe958d] .ant-menu-item-selected{background:#dbeafe;color:#2563eb;font-weight:500}.sider-footer[data-v-a2fe958d]{padding:12px 16px;border-top:1px solid #f0f0f0;display:flex;align-items:center;justify-content:space-between;gap:10px}.sider-footer-name[data-v-a2fe958d]{font-size:13px;font-weight:500;color:#0f172a}.sider-footer-role[data-v-a2fe958d]{font-size:11px;color:#64748b}.logout-link[data-v-a2fe958d]{font-size:13px;color:#ef4444;cursor:pointer}.logout-link[data-v-a2fe958d]:hover{text-decoration:underline}.toast[data-v-cce16ebb]{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;min-width:260px;max-width:360px;padding:12px 16px;border-radius:14px;box-shadow:0 4px 12px #0000000f;background:#fff;font-size:var(--text-sm);line-height:1.4;color:#0f172a;border:1px solid rgba(12,74,110,.1)}.toast-icon[data-v-cce16ebb]{font-size:18px}.toast-message[data-v-cce16ebb]{word-break:break-word}.toast-close[data-v-cce16ebb]{border:none;background:transparent;color:inherit;font-size:18px;cursor:pointer;line-height:1}.toast-success[data-v-cce16ebb]{border-color:#16a34a33;background:#16a34a14}.toast-error[data-v-cce16ebb]{border-color:#dc262633;background:#dc262614}.toast-info[data-v-cce16ebb]{border-color:#2563eb33;background:#2563eb14}.toast-warning[data-v-cce16ebb]{border-color:#eab30833;background:#eab3081f}.toast-container[data-v-97330f13]{position:fixed;top:24px;right:24px;display:flex;flex-direction:column;gap:12px;z-index:9999}.toast-enter-active[data-v-97330f13],.toast-leave-active[data-v-97330f13]{transition:all .2s ease}.toast-enter-from[data-v-97330f13],.toast-leave-to[data-v-97330f13]{opacity:0;transform:translate(16px)}.loading-overlay[data-v-81ed2f6f]{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a59;display:flex;align-items:center;justify-content:center;z-index:9998}.loading-content[data-v-81ed2f6f]{display:flex;flex-direction:column;align-items:center;gap:16px;padding:24px 32px;border-radius:14px;background:#fff;box-shadow:0 4px 12px #0000000f;min-width:200px}.spinner[data-v-81ed2f6f]{width:32px;height:32px;border-radius:50%;border:4px solid rgba(12,74,110,.2);border-top-color:#2563eb;animation:spin-81ed2f6f .8s linear infinite}.loading-text[data-v-81ed2f6f]{font-size:var(--text-sm);color:#0f172a}@keyframes spin-81ed2f6f{to{transform:rotate(360deg)}}.loading-fade-enter-active[data-v-81ed2f6f],.loading-fade-leave-active[data-v-81ed2f6f]{transition:opacity .2s ease}.loading-fade-enter-from[data-v-81ed2f6f],.loading-fade-leave-to[data-v-81ed2f6f]{opacity:0}.fatigue-monitor-widget[data-v-1548ac49]{position:fixed;background:#fff;border-radius:12px;box-shadow:0 8px 30px #0000001f;border:1px solid rgba(255,255,255,.8);z-index:9999;min-width:384px;max-width:480px;transition:all .3s cubic-bezier(.4,0,.2,1)}.widget-content[data-v-1548ac49]{padding:10px 10px 16px}.fatigue-monitor-widget.minimized[data-v-1548ac49]{min-width:200px}.fatigue-monitor-widget.dragging[data-v-1548ac49]{cursor:move;-webkit-user-select:none;user-select:none;opacity:.95;transform:scale(1.02);box-shadow:0 12px 40px #0003}.widget-header[data-v-1548ac49]{position:relative;display:flex;align-items:center;padding:12px 16px;border-bottom:1px solid rgba(0,0,0,.04);background:linear-gradient(to bottom,#fff,#fcfcfd);border-radius:12px 12px 0 0;cursor:move;-webkit-user-select:none;user-select:none}.header-left[data-v-1548ac49]{display:flex;align-items:center;gap:10px;flex:1;padding-right:60px}.status-indicator-inline[data-v-1548ac49]{display:flex;align-items:center;gap:6px;margin-left:12px;padding-left:12px;border-left:1px solid #e5e7eb}.status-dot[data-v-1548ac49]{width:6px;height:6px;border-radius:50%;animation:pulse-1548ac49 2s infinite}.status-text[data-v-1548ac49]{font-size:12px;color:#6b7280;font-weight:400}.header-icon[data-v-1548ac49]{color:#667eea;font-size:18px;filter:drop-shadow(0 2px 4px rgba(102,126,234,.2))}.header-title[data-v-1548ac49]{font-weight:600;color:#1f2937;font-size:15px;letter-spacing:.3px}.header-controls[data-v-1548ac49]{position:absolute;right:16px;top:50%;transform:translateY(-50%);display:flex;gap:6px;z-index:10}.header-controls[data-v-1548ac49] .ant-btn{color:#9ca3af;transition:all .2s;border-radius:6px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent}.header-controls[data-v-1548ac49] .ant-btn:hover{background:#0000000a;color:#4b5563}.header-controls[data-v-1548ac49] .ant-btn:active{background:#00000014}.monitor-display-area[data-v-1548ac49]{display:grid;grid-template-columns:3fr 2fr;gap:12px;margin-bottom:14px;align-items:stretch}@media (max-width: 760px){.monitor-display-area[data-v-1548ac49]{grid-template-columns:1fr}}.left-column[data-v-1548ac49]{display:flex;flex-direction:column;gap:8px;height:100%}.visual-area[data-v-1548ac49]{position:relative;background:linear-gradient(180deg,#f8fafc,#f3f4f6);border-radius:14px;overflow:hidden;box-shadow:0 10px 30px #0f172a14;border:1px solid #e5e7eb}.video-container[data-v-1548ac49]{position:relative;width:100%;height:160px;background:#000;border-radius:6px;overflow:hidden;display:flex;align-items:center;justify-content:center}.video-container.compact[data-v-1548ac49]{box-shadow:inset 0 0 0 1px #ffffff14}.video-container.hero[data-v-1548ac49]{height:160px}.charts-stack[data-v-1548ac49]{display:flex;flex-direction:column;gap:8px;height:100%;background:#f8fafc;border-radius:14px;padding:6px;border:1px solid #e5e7eb;box-shadow:inset 0 1px #fffc}.charts-stack.charts-loading[data-v-1548ac49]{opacity:.7}.chart-card[data-v-1548ac49]{background:#fff;border-radius:12px;border:1px solid #e5e7eb;box-shadow:0 8px 20px #0000000f;overflow:hidden;display:flex;flex-direction:column;min-height:120px}.chart-card.flex-item[data-v-1548ac49]{flex:1}.chart-header[data-v-1548ac49]{padding:10px 12px;background:#f9fafb;border-bottom:1px solid #e5e7eb}.chart-title[data-v-1548ac49]{font-size:12px;font-weight:700;color:#111827}.chart-canvas-wrap[data-v-1548ac49]{flex:1;min-height:80px;background:#fff}.chart-canvas-wrap canvas[data-v-1548ac49]{width:100%!important;height:100%!important}.camera-feed[data-v-1548ac49]{width:100%;height:100%;object-fit:contain}.camera-feed.inactive[data-v-1548ac49]{display:none}.video-placeholder[data-v-1548ac49]{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#9ca3af;background:#1f2937}.placeholder-icon[data-v-1548ac49]{font-size:24px;margin-bottom:8px}.video-placeholder p[data-v-1548ac49]{margin:0;font-size:12px;text-align:center}.fatigue-level-section[data-v-1548ac49]{margin-bottom:12px}.fatigue-level-section.tight[data-v-1548ac49]{margin:6px 0}.fatigue-level-display[data-v-1548ac49]{padding:10px;border-radius:10px;text-align:center;color:#fff;box-shadow:0 8px 20px #22c55e40}.level-content h4[data-v-1548ac49]{margin:0 0 4px;font-size:16px;font-weight:600}.level-description[data-v-1548ac49]{margin:0;font-size:12px;opacity:.9}.metrics-section[data-v-1548ac49]{margin:8px 0 0;padding:10px 6px;background:#f8fafc;border-radius:12px;border:1px solid #e5e7eb;min-height:120px;display:flex;align-items:center;box-shadow:0 4px 12px #00000008;flex:1;width:100%}.metrics-grid[data-v-1548ac49]{display:grid;grid-template-columns:1fr 1fr;gap:10px 14px;width:100%}.metric-item[data-v-1548ac49]{display:flex;flex-direction:column;align-items:center;padding:6px 4px;background:#fff;border-radius:8px;border:1px solid #e5e7eb;box-shadow:0 4px 10px #0000000a}.metric-label[data-v-1548ac49]{font-size:11px;color:#6b7280;margin-bottom:2px}.metric-value[data-v-1548ac49]{font-size:15px;font-weight:600;color:#374151}.attention-good[data-v-1548ac49]{color:#10b981!important}.attention-poor[data-v-1548ac49]{color:#ef4444!important}.controls-section[data-v-1548ac49],.statistics-section[data-v-1548ac49]{display:none}.stats-item[data-v-1548ac49]{display:flex;justify-content:space-between;margin-bottom:8px;padding:4px 0}.stats-item[data-v-1548ac49]:last-child{margin-bottom:0}.stats-label[data-v-1548ac49]{font-size:12px;color:#6b7280}.stats-value[data-v-1548ac49]{font-size:12px;font-weight:500;color:#374151}.sensor-stack[data-v-1548ac49]{position:absolute;top:12px;right:12px;display:flex;flex-direction:column;gap:8px;align-items:stretch;z-index:2}.sensor-card[data-v-1548ac49]{min-width:84px;padding:8px 10px;border-radius:8px;background:#ffffffe6;box-shadow:0 4px 10px #0000001f;border:1px solid rgba(255,255,255,.6)}.sensor-label[data-v-1548ac49]{font-size:10px;color:#6b7280;margin-bottom:2px;line-height:1.2}.sensor-value[data-v-1548ac49]{font-size:14px;font-weight:700;color:#111827;line-height:1.1}.sensor-status[data-v-1548ac49]{text-align:center;font-size:11px;padding:6px 8px;border-radius:999px;background:#6b7280e6;color:#fff;font-weight:600;border:1px solid rgba(255,255,255,.6)}.sensor-status.connected[data-v-1548ac49]{background:#10b981f2}.charts-panel[data-v-1548ac49]{margin-top:8px;display:grid;grid-template-columns:1fr;gap:6px}.chart-wrap[data-v-1548ac49]{height:60px;background:#fffc;border:1px solid rgba(0,0,0,.05);border-radius:6px;overflow:hidden}@keyframes pulse-1548ac49{0%,to{opacity:1}50%{opacity:.5}}@media (prefers-color-scheme: dark){.fatigue-monitor-widget[data-v-1548ac49]{background:#1f2937;border-color:#374151}.widget-header[data-v-1548ac49]{background:#111827;border-bottom-color:#374151}.header-title[data-v-1548ac49]{color:#f9fafb}.video-placeholder[data-v-1548ac49]{background:#000}.metrics-grid .metric-item[data-v-1548ac49]{background:#374151}.metric-value[data-v-1548ac49]{color:#f9fafb}.statistics-section[data-v-1548ac49]{border-top-color:#374151}.stats-value[data-v-1548ac49]{color:#f9fafb}.physiological-section[data-v-1548ac49]{background:#1f2937;border-top-color:#374151}.section-title[data-v-1548ac49]{color:#f9fafb}}.physiological-section[data-v-1548ac49]{margin-top:16px;padding:12px 16px;border-top:1px solid #e5e7eb;background:#fafbfc}.section-title[data-v-1548ac49]{font-size:13px;font-weight:600;color:#374151;margin-bottom:8px}.serial-port-controls[data-v-1548ac49]{display:flex;align-items:center;gap:8px}.device-info[data-v-1548ac49]{margin-top:12px;padding:8px 12px;background:#f6f9fc;border-radius:4px;border:1px solid #e1e8f0}.info-item[data-v-1548ac49]{display:flex;align-items:center;padding:4px 0;font-size:12px}.info-label[data-v-1548ac49]{color:#6b7280;margin-right:8px;min-width:70px}.info-value[data-v-1548ac49]{color:#374151;font-weight:500}.info-value.connected[data-v-1548ac49]{color:#10b981}:root{--color-primary: #111111;--color-primary-light: #F5F5F5;--color-secondary: #404040;--color-accent: #6366F1;--color-surface: #ffffff;--color-border: #E5E5E5;--color-bg: #FAFAFA;--color-text: #111111;--color-muted: #8A8A8A;--color-morandi-red: #EF4444;--color-morandi-red-light: #FEF2F2;--color-morandi-green: #10B981;--color-morandi-green-light: #ECFDF5;--color-morandi-yellow: #F59E0B;--color-morandi-yellow-light: #FFFBEB;--color-morandi-blue: #3B82F6;--color-morandi-blue-light: #EFF6FF;--color-morandi-purple: #8B5CF6;--color-morandi-purple-light: #F5F3FF;--glass-bg: #ffffff;--glass-bg-strong: #ffffff;--glass-bg-hover: #ffffff;--glass-border: 1px solid #E5E5E5;--glass-shadow: 0 1px 2px rgba(0, 0, 0, .04);--glass-shadow-hover: 0 4px 12px rgba(0, 0, 0, .08);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 24px;--spacing-2xl: 32px;--spacing-3xl: 48px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 2px 8px rgba(0, 0, 0, .06);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .1);--shadow-soft: 0 4px 16px rgba(0, 0, 0, .05);--font-sans: "Inter", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Menlo", monospace;--text-xs: 12px;--text-sm: 13px;--text-base: 14px;--text-lg: 16px;--text-xl: 18px;--text-2xl: 20px;--text-3xl: 24px;--text-4xl: 28px;--sidebar-width: 170px}*{box-sizing:border-box}body{margin:0;font-family:var(--font-sans);color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.flex{display:flex}.flex-col{flex-direction:column}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.grid{display:grid}.gap-1{gap:var(--spacing-xs)}.gap-2{gap:var(--spacing-sm)}.gap-3{gap:var(--spacing-md)}.gap-4{gap:var(--spacing-lg)}.gap-6{gap:var(--spacing-xl)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-primary{color:var(--color-primary)}.text-muted{color:var(--color-muted)}.font-semibold{font-weight:600}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-full{border-radius:var(--radius-full)}.glass-panel{background:#fff;border:1px solid #f0f0f0;box-shadow:0 1px 3px #0000000a;border-radius:14px;transition:all .3s ease}.glass-panel:hover{box-shadow:0 8px 24px #00000014}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#2c3e5026;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#2c3e504d}::selection{background:#2c3e5026;color:var(--color-text)}::-moz-selection{background:#2c3e5026;color:var(--color-text)}.btn-primary{padding:10px 24px;border-radius:var(--radius-full);border:none;background:linear-gradient(120deg,var(--color-primary),#1a252f);color:#f9fafb;font-size:14px;font-weight:600;cursor:pointer;box-shadow:var(--shadow-lg);transition:transform .2s ease}.btn-primary:hover{transform:translateY(-1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{padding:10px 20px;border-radius:var(--radius-full);border:1px solid rgba(44,62,80,.18);background:#2c3e5014;color:var(--color-primary);font-size:13px;font-weight:600;cursor:pointer}.input-field{border-radius:var(--radius-md);border:1px solid var(--color-border);padding:var(--spacing-md) var(--spacing-lg);font-size:var(--text-base);transition:border-color .2s ease}.input-field:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px #2c3e5026}.app-root{min-height:100vh}.main-content{padding:24px;background:#f8fafc;min-height:100vh;transition:margin-left .2s;overflow-y:auto;overflow-x:hidden}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji"}#app{min-height:100vh}
