.sidebar[data-v-05a762da]{width:var(--sidebar-width);background:#f1f5f9;border-right:1px solid rgba(12,74,110,.08);padding:36px 24px;display:flex;flex-direction:column;gap:48px}.brand[data-v-05a762da]{display:flex;flex-direction:row;align-items:center;gap:16px}.brand-logo[data-v-05a762da]{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:700;letter-spacing:.6px;color:var(--color-primary);white-space:nowrap}.brand-logo span[data-v-05a762da]{width:44px;height:44px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0c4a6ee6,#166534cc);color:#f9fafb;font-size:18px;font-weight:600}.brand-tagline[data-v-05a762da]{font-size:12px;color:#4b5563;letter-spacing:.3px;white-space:nowrap}.nav[data-v-05a762da]{display:flex;flex-direction:column;gap:10px}.nav-header[data-v-05a762da]{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;padding-right:16px}.nav h2[data-v-05a762da]{margin:0 0 0 12px;font-size:12px;letter-spacing:.4px;color:#94a3b8}.manual-link[data-v-05a762da]{font-size:12px;color:var(--color-primary);text-decoration:none;transition:opacity .2s ease;font-weight:500}.manual-link[data-v-05a762da]:hover{opacity:.8;text-decoration:underline}.nav-link[data-v-05a762da]{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:14px;color:#334155;font-size:15px;font-weight:500;letter-spacing:.2px;transition:background .2s ease,color .2s ease;cursor:pointer;text-decoration:none}.nav-link .dot[data-v-05a762da]{width:10px;height:10px;border-radius:50%;background:#0c4a6e29}.nav-link.router-link-active[data-v-05a762da]{background:var(--color-primary-light);color:var(--color-primary)}.nav-link.router-link-active .dot[data-v-05a762da]{background:var(--color-primary);box-shadow:0 0 0 6px #0c4a6e24}.user-section[data-v-05a762da]{margin-top:auto;display:flex;flex-direction:column;gap:12px;padding-bottom:12px;border-bottom:1px solid rgba(12,74,110,.08)}.user-info[data-v-05a762da]{display:flex;align-items:center;gap:12px;padding:8px}.user-avatar[data-v-05a762da]{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#0c4a6ee6,#166534cc);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600}.user-details[data-v-05a762da]{flex:1;display:flex;flex-direction:column;gap:2px;overflow:hidden}.user-name[data-v-05a762da]{font-size:14px;font-weight:600;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email[data-v-05a762da]{font-size:12px;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logout-button[data-v-05a762da]{width:100%;padding:10px 16px;border:1px solid rgba(239,68,68,.3);border-radius:10px;background:transparent;color:#ef4444;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s ease,border-color .2s ease}.logout-button[data-v-05a762da]:hover{background:#ef44440d;border-color:#ef4444}.nav-secondary[data-v-05a762da]{padding-top:12px;display:flex;flex-direction:column;gap:6px;font-size:12px;color:#94a3b8}.nav-secondary a[data-v-05a762da]{color:inherit;text-decoration:none}.nav-secondary a[data-v-05a762da]:hover{color:var(--color-primary)}.toast[data-v-a2f427c8]{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;min-width:260px;max-width:360px;padding:12px 16px;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);background:var(--color-surface);font-size:var(--text-sm);line-height:1.4;color:var(--color-text);border:1px solid rgba(12,74,110,.1)}.toast-icon[data-v-a2f427c8]{font-size:18px}.toast-message[data-v-a2f427c8]{word-break:break-word}.toast-close[data-v-a2f427c8]{border:none;background:transparent;color:inherit;font-size:18px;cursor:pointer;line-height:1}.toast-success[data-v-a2f427c8]{border-color:#16a34a33;background:#16a34a14}.toast-error[data-v-a2f427c8]{border-color:#dc262633;background:#dc262614}.toast-info[data-v-a2f427c8]{border-color:#2563eb33;background:#2563eb14}.toast-warning[data-v-a2f427c8]{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-8198dc7c]{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-8198dc7c]{display:flex;flex-direction:column;align-items:center;gap:16px;padding:24px 32px;border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow-md);min-width:200px}.spinner[data-v-8198dc7c]{width:32px;height:32px;border-radius:50%;border:4px solid rgba(12,74,110,.2);border-top-color:var(--color-primary);animation:spin-8198dc7c .8s linear infinite}.loading-text[data-v-8198dc7c]{font-size:var(--text-sm);color:var(--color-text)}@keyframes spin-8198dc7c{to{transform:rotate(360deg)}}.loading-fade-enter-active[data-v-8198dc7c],.loading-fade-leave-active[data-v-8198dc7c]{transition:opacity .2s ease}.loading-fade-enter-from[data-v-8198dc7c],.loading-fade-leave-to[data-v-8198dc7c]{opacity:0}.fatigue-monitor-widget[data-v-31766620]{position:fixed;background:#fff;border-radius:12px;box-shadow:0 8px 30px #0000001f;border:1px solid rgba(255,255,255,.8);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:9999;min-width:384px;max-width:480px;transition:all .3s cubic-bezier(.4,0,.2,1)}.widget-content[data-v-31766620]{padding:10px 10px 16px}.fatigue-monitor-widget.minimized[data-v-31766620]{min-width:200px}.fatigue-monitor-widget.dragging[data-v-31766620]{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-31766620]{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-31766620]{display:flex;align-items:center;gap:10px;flex:1;padding-right:60px}.status-indicator-inline[data-v-31766620]{display:flex;align-items:center;gap:6px;margin-left:12px;padding-left:12px;border-left:1px solid #e5e7eb}.status-dot[data-v-31766620]{width:6px;height:6px;border-radius:50%;animation:pulse-31766620 2s infinite}.status-text[data-v-31766620]{font-size:12px;color:#6b7280;font-weight:400}.header-icon[data-v-31766620]{color:#667eea;font-size:18px;filter:drop-shadow(0 2px 4px rgba(102,126,234,.2))}.header-title[data-v-31766620]{font-weight:600;color:#1f2937;font-size:15px;letter-spacing:.3px}.header-controls[data-v-31766620]{position:absolute;right:16px;top:50%;transform:translateY(-50%);display:flex;gap:6px;z-index:10}.header-controls[data-v-31766620] .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-31766620] .ant-btn:hover{background:#0000000a;color:#4b5563}.header-controls[data-v-31766620] .ant-btn:active{background:#00000014}.monitor-display-area[data-v-31766620]{display:grid;grid-template-columns:3fr 2fr;gap:12px;margin-bottom:14px;align-items:stretch}@media (max-width: 760px){.monitor-display-area[data-v-31766620]{grid-template-columns:1fr}}.left-column[data-v-31766620]{display:flex;flex-direction:column;gap:8px;height:100%}.visual-area[data-v-31766620]{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-31766620]{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-31766620]{box-shadow:inset 0 0 0 1px #ffffff14}.video-container.hero[data-v-31766620]{height:160px}.charts-stack[data-v-31766620]{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-31766620]{opacity:.7}.chart-card[data-v-31766620]{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-31766620]{flex:1}.chart-header[data-v-31766620]{padding:10px 12px;background:#f9fafb;border-bottom:1px solid #e5e7eb}.chart-title[data-v-31766620]{font-size:12px;font-weight:700;color:#111827}.chart-canvas-wrap[data-v-31766620]{flex:1;min-height:80px;background:#fff}.chart-canvas-wrap canvas[data-v-31766620]{width:100%!important;height:100%!important}.camera-feed[data-v-31766620]{width:100%;height:100%;object-fit:contain}.camera-feed.inactive[data-v-31766620]{display:none}.video-placeholder[data-v-31766620]{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-31766620]{font-size:24px;margin-bottom:8px}.video-placeholder p[data-v-31766620]{margin:0;font-size:12px;text-align:center}.fatigue-level-section[data-v-31766620]{margin-bottom:12px}.fatigue-level-section.tight[data-v-31766620]{margin:6px 0}.fatigue-level-display[data-v-31766620]{padding:10px;border-radius:10px;text-align:center;color:#fff;box-shadow:0 8px 20px #22c55e40}.level-content h4[data-v-31766620]{margin:0 0 4px;font-size:16px;font-weight:600}.level-description[data-v-31766620]{margin:0;font-size:12px;opacity:.9}.metrics-section[data-v-31766620]{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-31766620]{display:grid;grid-template-columns:1fr 1fr;gap:10px 14px;width:100%}.metric-item[data-v-31766620]{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-31766620]{font-size:11px;color:#6b7280;margin-bottom:2px}.metric-value[data-v-31766620]{font-size:15px;font-weight:600;color:#374151}.attention-good[data-v-31766620]{color:#10b981!important}.attention-poor[data-v-31766620]{color:#ef4444!important}.controls-section[data-v-31766620],.statistics-section[data-v-31766620]{display:none}.stats-item[data-v-31766620]{display:flex;justify-content:space-between;margin-bottom:8px;padding:4px 0}.stats-item[data-v-31766620]:last-child{margin-bottom:0}.stats-label[data-v-31766620]{font-size:12px;color:#6b7280}.stats-value[data-v-31766620]{font-size:12px;font-weight:500;color:#374151}.sensor-stack[data-v-31766620]{position:absolute;top:12px;right:12px;display:flex;flex-direction:column;gap:8px;align-items:stretch;z-index:2}.sensor-card[data-v-31766620]{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-31766620]{font-size:10px;color:#6b7280;margin-bottom:2px;line-height:1.2}.sensor-value[data-v-31766620]{font-size:14px;font-weight:700;color:#111827;line-height:1.1}.sensor-status[data-v-31766620]{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-31766620]{background:#10b981f2}.charts-panel[data-v-31766620]{margin-top:8px;display:grid;grid-template-columns:1fr;gap:6px}.chart-wrap[data-v-31766620]{height:60px;background:#fffc;border:1px solid rgba(0,0,0,.05);border-radius:6px;overflow:hidden}@keyframes pulse-31766620{0%,to{opacity:1}50%{opacity:.5}}@media (prefers-color-scheme: dark){.fatigue-monitor-widget[data-v-31766620]{background:#1f2937;border-color:#374151}.widget-header[data-v-31766620]{background:#111827;border-bottom-color:#374151}.header-title[data-v-31766620]{color:#f9fafb}.video-placeholder[data-v-31766620]{background:#000}.metrics-grid .metric-item[data-v-31766620]{background:#374151}.metric-value[data-v-31766620]{color:#f9fafb}.statistics-section[data-v-31766620]{border-top-color:#374151}.stats-value[data-v-31766620]{color:#f9fafb}.physiological-section[data-v-31766620]{background:#1f2937;border-top-color:#374151}.section-title[data-v-31766620]{color:#f9fafb}}.physiological-section[data-v-31766620]{margin-top:16px;padding:12px 16px;border-top:1px solid #e5e7eb;background:#fafbfc}.section-title[data-v-31766620]{font-size:13px;font-weight:600;color:#374151;margin-bottom:8px}.serial-port-controls[data-v-31766620]{display:flex;align-items:center;gap:8px}.device-info[data-v-31766620]{margin-top:12px;padding:8px 12px;background:#f6f9fc;border-radius:4px;border:1px solid #e1e8f0}.info-item[data-v-31766620]{display:flex;align-items:center;padding:4px 0;font-size:12px}.info-label[data-v-31766620]{color:#6b7280;margin-right:8px;min-width:70px}.info-value[data-v-31766620]{color:#374151;font-weight:500}.info-value.connected[data-v-31766620]{color:#10b981}:root{--color-primary: #0c4a6e;--color-primary-light: #e6f1f7;--color-secondary: #166534;--color-accent: #ea580c;--color-surface: #ffffff;--color-border: #e5e7eb;--color-bg: #f5f7fa;--color-text: #1f2937;--color-muted: #6b7280;--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: 20px;--radius-full: 999px;--shadow-sm: 0 2px 8px rgba(12, 74, 110, .08);--shadow-md: 0 8px 16px rgba(12, 74, 110, .12);--shadow-lg: 0 16px 32px rgba(12, 74, 110, .16);--shadow-soft: 0 14px 30px rgba(12, 74, 110, .08);--font-sans: "Inter", "Noto Sans SC", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;--font-mono: "Menlo", "Fira Code", "JetBrains Mono", 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: 240px}*{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)}.btn-primary{padding:10px 24px;border-radius:var(--radius-full);border:none;background:linear-gradient(120deg,var(--color-primary),#145369);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(12,74,110,.18);background:#0c4a6e14;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 #0c4a6e26}#app{display:flex;height:100vh;width:100%;overflow:hidden}.main-content{flex:1;min-width:0;display:flex;flex-direction:column;height:100%;overflow-y:auto;overflow-x:hidden}html,body{width:100%;height:100%}input::-ms-clear,input::-ms-reveal{display:none}*,*:before,*:after{box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:rgba(0,0,0,0)}@-ms-viewport{width:device-width}body{margin:0}[tabindex="-1"]:focus{outline:none}hr{box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5em;font-weight:500}p{margin-top:0;margin-bottom:1em}abbr[title],abbr[data-original-title]{-webkit-text-decoration:underline dotted;text-decoration:underline;text-decoration:underline dotted;border-bottom:0;cursor:help}address{margin-bottom:1em;font-style:normal;line-height:inherit}input[type=text],input[type=password],input[type=number],textarea{-webkit-appearance:none}ol,ul,dl{margin-top:0;margin-bottom:1em}ol ol,ul ul,ol ul,ul ol{margin-bottom:0}dt{font-weight:500}dd{margin-bottom:.5em;margin-left:0}blockquote{margin:0 0 1em}dfn{font-style:italic}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}pre,code,kbd,samp{font-size:1em;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace}pre{margin-top:0;margin-bottom:1em;overflow:auto}figure{margin:0 0 1em}img{vertical-align:middle;border-style:none}a,area,button,[role=button],input:not([type=range]),label,select,summary,textarea{touch-action:manipulation}table{border-collapse:collapse}caption{padding-top:.75em;padding-bottom:.3em;text-align:left;caption-side:bottom}input,button,select,optgroup,textarea{margin:0;color:inherit;font-size:inherit;font-family:inherit;line-height:inherit}button,input{overflow:visible}button,select{text-transform:none}button,html [type=button],[type=reset],[type=submit]{-webkit-appearance:button}button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner{padding:0;border-style:none}input[type=radio],input[type=checkbox]{box-sizing:border-box;padding:0}input[type=date],input[type=time],input[type=datetime-local],input[type=month]{-webkit-appearance:listbox}textarea{overflow:auto;resize:vertical}fieldset{min-width:0;margin:0;padding:0;border:0}legend{display:block;width:100%;max-width:100%;margin-bottom:.5em;padding:0;color:inherit;font-size:1.5em;line-height:inherit;white-space:normal}progress{vertical-align:baseline}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:none}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{display:list-item}template{display:none}[hidden]{display:none!important}mark{padding:.2em;background-color:#feffe6}*{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}
