body{margin:0;padding:0;background-color:#fff;overflow:hidden;height:100vh;width:100vw;font-family:Roboto,sans-serif}#canvas1{position:absolute;top:0;left:0;width:100%;height:100%;display:block}.content{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;pointer-events:auto;z-index:10;color:#0f172a}h1{font-size:4rem;font-weight:900;margin:0;letter-spacing:-2px}p{font-size:1.2rem;font-weight:300}.brand-logo{width:min(70vw,520px);height:auto;filter:drop-shadow(0 8px 24px rgba(0,0,0,.12));transition:transform .2s ease}.brand-logo-button{border:0;padding:0;background:transparent;cursor:pointer}.brand-logo-button:disabled{cursor:not-allowed;opacity:.85}.brand-logo-button:focus-visible{outline:3px solid #2563eb;outline-offset:6px;border-radius:10px}.brand-logo-button:hover .brand-logo{transform:translateY(-2px) scale(1.015)}.home-actions{margin-top:18px;display:flex;justify-content:center;gap:12px;flex-wrap:wrap}.home-action-button{border:0;border-radius:10px;padding:10px 16px;font-size:14px;font-weight:600;color:#fff;background:#0f172a;cursor:pointer}.home-action-button:hover{background:#1e293b}.home-action-button-alt{color:#0f172a;border:1px solid #cbd5e1;background:#f8fafc}.home-action-button-alt:hover{background:#e2e8f0}.home-action-button:disabled{opacity:.55;cursor:not-allowed}.tagline{margin:16px auto 0;max-width:720px;line-height:1.5;color:#334155}.viewer-page{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;background:radial-gradient(circle at top,#f8fafc,#e2e8f0)}.viewer-help{position:absolute;top:16px;left:16px;z-index:20;border:1px solid rgba(148,163,184,.45);border-radius:12px;padding:10px 12px;background:#f8fafce6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#0f172a;box-shadow:0 8px 20px #0f172a14}.viewer-model-panel{position:absolute;top:16px;right:16px;z-index:20;display:flex;flex-direction:column;gap:8px;max-width:min(42vw,360px);border:1px solid rgba(148,163,184,.45);border-radius:12px;padding:10px 12px;background:#f8fafce6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 8px 20px #0f172a14}.viewer-file-input{display:none}.viewer-model-status{font-size:12px;line-height:1.35;color:#334155}.viewer-model-status-loading{color:#0f172a}.viewer-model-status-ready{color:#0369a1}.viewer-model-status-error{color:#b91c1c}.viewer-help-title{font-size:13px;font-weight:700;margin-bottom:4px}.viewer-help-text{font-size:12px;line-height:1.35}.viewer-stage{flex:1;min-height:0}.viewer-stage canvas{display:block;width:100%;height:100%}.viewer-controls{display:flex;align-items:center;gap:16px;padding:14px 20px;border-top:1px solid #cbd5e1;background:#f8fafcf0;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.viewer-button{border:0;border-radius:10px;padding:10px 18px;font-size:14px;font-weight:600;color:#fff;background:#0f172a;cursor:pointer}.viewer-button:hover{background:#1e293b}.viewer-button:disabled{opacity:.55;cursor:not-allowed}.viewer-slider{flex:1;cursor:pointer}.viewer-animation-picker{display:flex;flex-direction:column;gap:4px;min-width:180px}.viewer-animation-label{font-size:11px;font-weight:600;color:#334155}.viewer-animation-select{height:36px;border:1px solid #cbd5e1;border-radius:10px;padding:0 10px;background:#f8fafc;color:#0f172a;font-size:13px}.viewer-animation-select:disabled{opacity:.6;cursor:not-allowed}.viewer-animation-empty{font-size:11px;color:#64748b}.viewer-camera-buttons{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.viewer-button-light{padding:8px 12px;border:1px solid #cbd5e1;color:#0f172a;background:#f8fafc}.viewer-button-light:hover{background:#e2e8f0}.viewer-button-light.active{background:#e2e8f0;border-color:#94a3b8;color:#2563eb}.viewer-camera-separator{width:1px;height:24px;background:#cbd5e1;margin:0 4px}.viewer-time{min-width:126px;text-align:right;color:#0f172a;font-size:13px;font-weight:500;font-variant-numeric:tabular-nums}.capture-page{overflow:hidden}.capture-stage{flex:1;min-height:0}.capture-stage canvas{display:block;width:100%;height:100%}.capture-preview-panel{position:absolute;top:16px;right:16px;z-index:20;border:1px solid rgba(148,163,184,.45);border-radius:12px;padding:8px;background:#f8fafce6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 8px 20px #0f172a14}.mocap-source-panel{width:min(340px,calc(100vw - 32px));display:grid;gap:8px}.mocap-source-title{font-size:13px;font-weight:700;color:#0f172a}.mocap-source-row{font-size:12px;line-height:1.4;color:#334155}.mocap-source-badge{display:inline-flex;width:fit-content;align-items:center;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:700;background:#e2e8f0;color:#0f172a}.mocap-source-badge.is-live{background:#d1fae5;color:#065f46}.mocap-source-warning{border:1px solid rgba(245,158,11,.3);border-radius:10px;padding:8px 10px;background:#fffbebf0;color:#92400e;font-size:12px;line-height:1.45}.capture-preview-stream{position:relative;width:clamp(240px,24vw,320px);aspect-ratio:16 / 9;margin:0;padding:0;border:0;border-radius:10px;overflow:hidden;background:#0f172a}.capture-preview-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;margin:0;padding:0;border:0;display:block;z-index:2}.capture-preview-video-source{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;margin:0;padding:0;border:0;object-fit:cover;transform-origin:50% 50%;z-index:1;opacity:0;pointer-events:none}.capture-controls{justify-content:flex-start}.capture-status{display:flex;align-items:center;gap:10px;color:#0f172a;font-size:12px;font-weight:600;font-variant-numeric:tabular-nums}.capture-latency-panel{margin-left:auto;display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:6px 8px;border:1px solid #cbd5e1;border-radius:10px;background:#f8fafc;color:#0f172a;font-size:12px;font-weight:600;font-variant-numeric:tabular-nums}.capture-latency-item{white-space:nowrap}.capture-error{position:absolute;left:16px;bottom:84px;z-index:30;max-width:min(620px,calc(100vw - 32px));border:1px solid rgba(185,28,28,.28);border-radius:10px;padding:10px 12px;background:#fef2f2eb;color:#991b1b;font-size:13px;line-height:1.4}.mocap-debug-popup-page{min-height:100vh;display:grid;align-content:start;gap:16px;padding:18px;background:radial-gradient(circle at top left,rgba(125,211,252,.18),transparent 40%),linear-gradient(180deg,#f8fafc,#eef2ff)}.mocap-debug-popup-header{display:grid;gap:6px}.mocap-debug-popup-title{font-size:18px;font-weight:700;color:#0f172a}.mocap-debug-popup-text{max-width:680px;font-size:13px;line-height:1.5;color:#475569}.mocap-debug-panel{position:relative;width:100%;max-width:none;display:grid;gap:10px;border:1px solid rgba(148,163,184,.55);border-radius:12px;padding:12px;background:#f8fafcf2;box-shadow:0 12px 30px #0f172a24;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.mocap-debug-title{font-size:13px;font-weight:700;color:#0f172a}.mocap-debug-row{display:flex;flex-wrap:wrap;gap:8px}.mocap-debug-meta{display:grid;gap:4px;font-size:12px;line-height:1.4;color:#334155}.mocap-debug-output{min-height:240px;resize:vertical;border:1px solid #cbd5e1;border-radius:10px;padding:10px;background:#e2e8f0;color:#0f172a;font-size:12px;line-height:1.45;font-family:Consolas,Courier New,monospace}.mocap-settings-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:160;display:flex;align-items:center;justify-content:center;padding:20px;background:#0f172a59;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.mocap-settings-modal{width:min(760px,calc(100vw - 40px));display:grid;gap:16px;border:1px solid rgba(148,163,184,.45);border-radius:18px;padding:20px;background:#f8fafcfa;box-shadow:0 24px 48px #0f172a29}.mocap-settings-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.mocap-utility-row{display:grid;grid-template-columns:minmax(0,auto) minmax(0,1fr);gap:10px;align-items:center}.mocap-utility-status{font-size:12px;line-height:1.4;color:#334155}.mocap-utility-status.is-error{color:#b91c1c}.mocap-utility-status.is-running{color:#0369a1}@media (max-width: 700px){.viewer-help{top:10px;left:10px;right:10px}.viewer-model-panel{top:104px;left:10px;right:10px;max-width:none}.viewer-controls{flex-wrap:wrap;gap:10px}.viewer-slider{order:3;width:100%;flex-basis:100%}.viewer-animation-picker{order:4;width:100%;min-width:0}.viewer-camera-buttons{order:5}.viewer-time{width:100%;min-width:0;text-align:left}.capture-preview-panel{top:104px;left:10px;right:auto}.mocap-source-panel{width:min(72vw,320px)}.capture-preview-stream{width:min(58vw,260px)}.capture-status{justify-content:flex-start;flex-wrap:wrap}.capture-latency-panel{width:100%;margin-left:0;justify-content:flex-start}.capture-error{left:10px;right:10px;bottom:78px;max-width:none}.mocap-settings-modal{width:calc(100vw - 20px);padding:16px}.mocap-debug-popup-page{padding:14px}.mocap-settings-header,.mocap-utility-row{grid-template-columns:1fr}}.app-boot,.login-page{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at top,#f8fafc,#e2e8f0);overflow:hidden}.login-background-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:block;pointer-events:none;z-index:0}.login-panel{position:relative;z-index:1;width:min(480px,calc(100vw - 32px));border:1px solid rgba(148,163,184,.45);border-radius:18px;padding:28px;background:#f8fafcf5;box-shadow:0 18px 40px #0f172a1f;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.login-brand{font-size:32px;font-weight:900;letter-spacing:-.06em;color:#0f172a}.login-title{margin-top:10px;font-size:24px;font-weight:700;color:#0f172a}.login-subtitle{margin-top:10px;font-size:14px;line-height:1.5;color:#475569}.login-form{margin-top:18px;display:grid;gap:12px}.login-submit{width:100%}.login-error{margin-top:14px}.app-field{display:grid;gap:6px}.app-toolbar .app-field{flex:1 1 220px}.app-field-label{font-size:12px;font-weight:600;color:#334155}.app-shell{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;grid-template-columns:264px minmax(0,1fr);background:radial-gradient(circle at top,#f8fafc,#e2e8f0)}.app-sidebar{display:flex;flex-direction:column;gap:18px;padding:20px 16px;border-right:1px solid rgba(148,163,184,.35);background:#f8fafcd1;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.app-sidebar-brand{font-size:28px;font-weight:900;letter-spacing:-.06em;color:#0f172a}.app-sidebar-group{display:grid;gap:8px}.app-sidebar-link{border:1px solid rgba(203,213,225,.85);border-radius:12px;padding:12px 14px;text-align:left;font-size:14px;font-weight:600;color:#0f172a;background:#f8fafc;cursor:pointer}.app-sidebar-link:hover,.app-sidebar-link.active{background:#e2e8f0;border-color:#94a3b8}.app-sidebar-footer{margin-top:auto;display:grid;gap:6px;font-size:12px;color:#475569}.app-sidebar-status,.app-sidebar-user{padding:8px 10px;border:1px solid rgba(203,213,225,.75);border-radius:10px;background:#ffffffb3}.app-sidebar-logout{width:100%}.app-content{min-width:0;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 24px 14px;border-bottom:1px solid rgba(203,213,225,.85);background:#f8fafce6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.app-header-title{font-size:22px;font-weight:700;color:#0f172a}.app-header-subtitle,.app-header-meta{font-size:13px;color:#64748b}.app-header-meta{display:flex;align-items:center;gap:10px}.app-content-scroll{flex:1;min-height:0;overflow:auto;padding:22px 24px 28px}.app-page-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:18px}.app-page-grid-wide{grid-template-columns:.9fr 1.1fr 1.2fr}.app-page-stack{display:grid;gap:14px}.app-surface{border:1px solid rgba(148,163,184,.45);border-radius:16px;background:#f8fafceb;box-shadow:0 12px 28px #0f172a14;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.app-surface-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:18px 18px 0}.app-surface-title{margin:0;font-size:18px;font-weight:700;color:#0f172a}.app-surface-subtitle{margin:6px 0 0;font-size:13px;line-height:1.5;color:#64748b}.app-surface-body{padding:18px;display:grid;gap:16px}.app-toolbar,.app-inline-actions,.app-inline-actions-wrap{display:flex;align-items:center;gap:10px}.app-section-tabs{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.app-inline-actions-wrap{flex-wrap:wrap}.app-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.app-span-full{grid-column:1 / -1}.app-input,.app-select,.app-textarea{width:100%;min-width:0;border:1px solid #cbd5e1;border-radius:10px;padding:10px 12px;background:#f8fafc;color:#0f172a;font-size:14px;box-sizing:border-box}.app-textarea{resize:vertical;min-height:88px;font-family:inherit}.app-select-multi{min-height:88px}.app-subheading{margin:0;font-size:14px;font-weight:700;color:#0f172a}.app-list{display:grid;gap:10px}.app-list-compact{gap:8px}.app-list-item,.app-list-item-link{width:100%;border:1px solid rgba(203,213,225,.85);border-radius:12px;padding:12px 14px;text-align:left;background:#fff;cursor:pointer;box-sizing:border-box}.app-list-item:hover,.app-list-item.active,.app-list-item-link:hover{border-color:#94a3b8;background:#f8fafc}.app-list-item-card{display:grid;gap:10px}.app-list-item-title{font-size:14px;font-weight:700;color:#0f172a}.app-list-item-meta{margin-top:4px;font-size:12px;color:#64748b}.app-admin-table{display:grid;gap:8px}.app-admin-table-row{display:grid;grid-template-columns:minmax(140px,1fr) minmax(160px,1fr) minmax(160px,1fr) minmax(110px,.65fr) minmax(110px,.65fr) minmax(260px,1.4fr);gap:10px;align-items:center;border:1px solid rgba(203,213,225,.85);border-radius:12px;padding:10px 12px;background:#fff;color:#0f172a;font-size:13px}.app-admin-table-head{background:#f8fafc;color:#64748b;font-size:11px;font-weight:700;text-transform:uppercase}.app-key-value-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.app-key-value-item{border:1px solid rgba(203,213,225,.85);border-radius:12px;padding:10px 12px;background:#fff}.app-key-value-label{font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em}.app-key-value-value{margin-top:6px;font-size:14px;color:#0f172a;word-break:break-word}.app-empty-state,.app-loading-state,.app-error-state,.app-info-banner{border:1px solid rgba(203,213,225,.85);border-radius:12px;padding:14px;background:#fff}.app-empty-title{font-size:14px;font-weight:700;color:#0f172a}.app-empty-description{font-size:13px;line-height:1.5;color:#64748b}.app-loading-state{color:#334155}.app-error-state{display:flex;align-items:center;justify-content:space-between;gap:12px;border-color:#b91c1c47;background:#fef2f2eb;color:#991b1b}.app-info-banner{color:#0f172a}.app-copy-block,.app-json-block{border:1px solid rgba(203,213,225,.85);border-radius:12px;padding:12px;background:#fff;font-family:Consolas,Courier New,monospace;font-size:12px;white-space:pre-wrap;word-break:break-word}.app-system-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.app-system-item{border:1px solid rgba(203,213,225,.85);border-radius:12px;padding:12px;background:#fff;color:#0f172a}.app-system-label{font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase}.app-badge{display:inline-flex;align-items:center;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:700;background:#e2e8f0;color:#0f172a}.motion-page{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100}.motion-overlay-card{position:absolute;left:16px;top:16px;z-index:130;max-width:min(420px,calc(100vw - 32px));display:grid;gap:8px;border:1px solid rgba(148,163,184,.45);border-radius:14px;padding:12px 14px;background:#f8fafcf0;box-shadow:0 8px 24px #0f172a1f;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.motion-overlay-card-wide{max-width:min(460px,calc(100vw - 32px))}.motion-overlay-title{font-size:14px;font-weight:700;color:#0f172a}.motion-overlay-text,.motion-overlay-list-item{font-size:12px;line-height:1.45;color:#334155}.motion-overlay-error{font-size:12px;color:#b91c1c}.motion-overlay-actions{display:flex;flex-wrap:wrap;gap:8px}.motion-overlay-list{display:grid;gap:4px}.motion-overlay-list-title{font-size:11px;font-weight:700;text-transform:uppercase;color:#64748b}.motion-overlay-link{border:0;padding:0;text-align:left;background:transparent;color:#0369a1;cursor:pointer}.viewer-model-source{font-size:12px;color:#334155}@media (max-width: 1100px){.app-shell{grid-template-columns:220px minmax(0,1fr)}.app-page-grid,.app-page-grid-wide{grid-template-columns:1fr}}@media (max-width: 820px){.app-shell{grid-template-columns:1fr}.app-sidebar{border-right:0;border-bottom:1px solid rgba(148,163,184,.35)}.app-content-scroll{padding:16px}.app-header{padding:14px 16px;flex-direction:column;align-items:flex-start}.app-form-grid,.app-system-grid,.app-key-value-grid,.app-admin-table-row{grid-template-columns:1fr}.motion-overlay-card{left:10px;right:10px;max-width:none}}
