:root{--primary-color: #0a59f7;--primary-weak: #eaf2ff;--bg-color: #f8f9fa;--surface-color: #ffffff;--border-color: #d7dee8;--text-main: #1d1d1f;--text-muted: #657386;--error-color: #b42318;--safe-bottom: env(safe-area-inset-bottom, 0px);color:var(--text-main);background:var(--bg-color);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5}*{box-sizing:border-box}body{margin:0;min-height:100dvh;background:var(--bg-color)}button,input,select,textarea{font:inherit}button,a{-webkit-tap-highlight-color:transparent}button{min-height:44px;border:1px solid #b9c3d0;border-radius:8px;background:var(--surface-color);color:var(--text-main);padding:0 14px;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.52}h1,h2,h3,p{margin-top:0}h1{margin-bottom:2px;font-size:18px;line-height:1.25}h2{font-size:18px;margin-bottom:12px}h3{font-size:15px}.muted{color:var(--text-muted)}.mobile-shell{width:100%;max-width:768px;min-height:100dvh;margin:0 auto;background:var(--bg-color);display:flex;flex-direction:column;overflow-x:hidden}.mobile-header{position:sticky;top:0;z-index:10;min-height:58px;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px 16px;background:#fffffff5;border-bottom:1px solid var(--border-color);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.mobile-header-copy{min-width:0}.mobile-header-copy h1{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-header-copy p{margin-bottom:0;color:var(--text-muted);font-size:12px}.back-button{min-height:38px;padding:0 10px;border-color:transparent}.status-badge,.task-status{display:inline-flex;align-items:center;justify-content:center;min-height:26px;border-radius:999px;padding:3px 8px;font-size:12px;font-weight:700;white-space:nowrap}.status-badge.local,.task-status.local{color:#087443;background:#e8f8ef;border:1px solid #bfe8cf}.status-badge.backend,.task-status.backend{color:#174f9f;background:var(--primary-weak);border:1px solid #c8ddfb}.status-badge.neutral,.task-status.neutral{color:#475569;background:#eef2f7;border:1px solid #d7dee8}.status-badge.error{color:var(--error-color);background:#fff1f0;border:1px solid #ffccc7}.mobile-header .status-badge{justify-self:end;max-width:86px;overflow:hidden;text-overflow:ellipsis}.mobile-content{flex:1;min-height:0;padding:14px 14px calc(86px + var(--safe-bottom))}.workflow .mobile-content{padding-bottom:calc(96px + var(--safe-bottom))}.bottom-nav{position:sticky;bottom:0;z-index:12;display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:8px 14px calc(8px + var(--safe-bottom));background:#fffffff5;border-top:1px solid var(--border-color);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.bottom-nav button{border-color:transparent;color:var(--text-muted);font-weight:700}.bottom-nav .active{color:#fff;background:var(--primary-color);border-color:var(--primary-color)}.panel,.workflow-panel{width:100%;max-width:100%;margin:0 auto;background:var(--surface-color);border:1px solid var(--border-color);border-radius:8px;padding:14px}.workflow-panel{display:grid;gap:12px}.task-grid,.method-grid,.record-list{display:grid;gap:10px;margin-bottom:18px}.task-card,.method-card,.record-card,.form-section{border:1px solid var(--border-color);border-radius:8px;background:var(--surface-color);padding:12px}.task-card{display:grid;gap:8px;min-height:112px;text-align:left}.task-card:disabled{cursor:default;filter:grayscale(1);opacity:.52}.task-card strong{font-size:16px}.task-card span:last-child,.method-card p{color:var(--text-muted);font-size:13px}.method-card h3{margin-bottom:6px}.chips{display:flex;flex-wrap:wrap;gap:6px}.chips span{background:var(--primary-weak);color:#174f9f;border:1px solid #c8ddfb;border-radius:999px;padding:2px 8px;font-size:12px}.workflow-card{align-content:start}.workflow-steps{display:grid;gap:4px;margin:0;padding-left:18px;color:var(--text-muted);font-size:13px}.offline-capability{display:grid;gap:4px;margin-bottom:14px;border:1px solid #bfe8cf;border-radius:8px;background:#f0fbf5;padding:10px 12px;color:#075f38}.offline-capability p{margin-bottom:0;color:#23714d;font-size:13px}.workflow-action{justify-self:start;min-height:32px;border-radius:6px;padding:6px 10px;background:var(--primary-color);color:#fff;font-size:13px;font-weight:800}.task-card:disabled .workflow-action{background:#d7dee8;color:#475569}.disabled-reason{color:#6b4f00;background:#fff8db;border:1px solid #f1df9a;border-radius:6px;padding:8px;font-size:13px}.hint-strip{display:grid;gap:4px;border:1px solid #c8ddfb;border-radius:8px;background:var(--primary-weak);padding:10px 12px;color:#174f9f;font-size:13px}.hint-strip span{color:#3a4656}.upload-panel{position:relative;display:grid;place-items:center;min-height:148px;border:1.5px dashed #9db4d5;border-radius:8px;background:#f6f9fd;text-align:center;cursor:pointer}.upload-input{position:absolute;inset:0;opacity:0;cursor:pointer}.upload-panel.disabled{cursor:not-allowed;filter:grayscale(1);opacity:.52}.upload-panel.disabled .upload-input{cursor:not-allowed}.upload-title{font-size:16px;font-weight:800}.upload-description{color:var(--text-muted);font-size:13px}.video-source-grid{display:grid;gap:10px}.usage-steps{display:grid;gap:6px;margin:0;padding-left:20px;color:#3a4656;font-size:13px}.advanced-settings{border:1px solid var(--border-color);border-radius:8px;background:#fbfcfe;padding:0 10px}.advanced-settings summary{min-height:44px;display:flex;align-items:center;color:#3a4656;font-size:14px;font-weight:800;cursor:pointer}.advanced-settings-body{display:grid;gap:10px;padding-bottom:12px}.advanced-settings-body h3,.advanced-settings-body p{margin-bottom:0}.plate-preview{width:100%;max-height:280px;object-fit:contain;background:#f8f9fa}.plate-preview-wrap{position:relative;overflow:hidden;border:1px solid var(--border-color);border-radius:8px;background:#f8f9fa}.plate-grid-overlay{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}.plate-well{fill:#64748b1f;stroke:#475569e6;stroke-width:1.5}.plate-well.active{fill:#0a59f72e;stroke:#0a59f7f2}.step-progress{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:0;padding:10px;list-style:none;border:1px solid var(--border-color);border-radius:8px;background:#f4f7fb}.step-progress li{display:grid;justify-items:center;gap:4px;color:var(--text-muted);font-size:12px;font-weight:700}.step-progress span{width:22px;height:22px;display:grid;place-items:center;border-radius:50%;background:#dce5f1;color:#536276;font-variant-numeric:tabular-nums}.step-progress .complete span,.step-progress .current span{background:var(--primary-color);color:#fff}.step-progress .current{color:var(--primary-color)}.roi-canvas{display:block;width:100%;max-width:720px;aspect-ratio:16 / 9;border:1px solid #b9c3d0;border-radius:8px;background:#f5f7fb;margin:0;touch-action:none;-webkit-user-select:none;user-select:none}.roi-readout{border:1px solid #d7dee8;border-radius:8px;background:#fbfcfe;padding:8px 10px;color:#3a4656;font-family:SF Mono,Menlo,Monaco,Consolas,monospace;font-size:12px}.inline-actions,.actions{display:flex;flex-wrap:wrap;gap:10px}.actions{margin-top:4px}.actions a,.data-table a{color:var(--primary-color);margin-right:10px}.compact-actions{margin-top:0}.sticky-actions{position:sticky;bottom:0;z-index:9;margin:4px -14px -14px;padding:10px 14px calc(10px + var(--safe-bottom));background:#fffffff5;border-top:1px solid var(--border-color);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.primary-action{width:100%;min-height:50px;background:var(--primary-color);border-color:var(--primary-color);color:#fff;font-weight:800}.metric-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.metric-card{border:1px solid var(--border-color);border-radius:8px;padding:10px;background:#fbfcfe}.metric-card span{display:block;color:var(--text-muted);font-size:12px}.metric-card strong{display:block;margin-top:4px;font-family:SF Mono,Menlo,Monaco,Consolas,monospace;font-size:18px;line-height:1.2}.metric-card.red{border-color:#fecaca}.metric-card.green{border-color:#bbf7d0}.metric-card.blue{border-color:#bfdbfe}.form-section{display:grid;gap:10px}.form-section h2{margin-bottom:0}.section-title-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:space-between}.input-row{display:grid;grid-template-columns:70px minmax(0,1fr) minmax(0,1fr) auto;gap:8px;align-items:end}.compact-row{grid-template-columns:82px minmax(0,1fr) auto}.colorimetry-input-row{grid-template-columns:70px minmax(0,1fr) minmax(0,1fr) minmax(128px,auto)}.compact-row.colorimetry-input-row{grid-template-columns:82px minmax(0,1fr) minmax(148px,auto)}.input-row>span,.input-row label,.form-section label{color:#3a4656;font-size:12px}.input-row label,.form-section label{display:grid;gap:4px}.checkbox-row{display:flex!important;align-items:center;gap:8px;min-height:44px;font-size:14px!important}.checkbox-row input{width:18px;height:18px}.input-row input,.form-section select{width:100%;min-height:42px;border:1px solid #b9c3d0;border-radius:8px;padding:8px;background:#fff}.row-actions{display:flex;flex-wrap:wrap;gap:6px}.compact-button{min-height:40px;padding:0 10px}.signal-source{grid-column:2 / -1;justify-self:start;border:1px solid #bfe8cf;border-radius:999px;background:#f0fbf5;color:#075f38!important;padding:3px 8px;font-family:SF Mono,Menlo,Monaco,Consolas,monospace;font-size:12px}.capture-backdrop{position:fixed;inset:0;z-index:40;display:grid;align-items:end;padding:14px;background:#0f172a6b}.capture-sheet{width:min(100%,760px);max-height:calc(100dvh - 28px);margin:0 auto;overflow:auto;display:grid;gap:12px;border:1px solid var(--border-color);border-radius:8px;background:#fff;padding:14px}.capture-header{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:start}.capture-header h2,.capture-header p{margin-bottom:0}.selected-signal{border:1px solid #bfe8cf;border-radius:8px;background:#f0fbf5;color:#075f38;padding:10px 12px;font-family:SF Mono,Menlo,Monaco,Consolas,monospace;font-size:13px}.capture-actions{position:sticky;bottom:0;display:grid;grid-template-columns:minmax(96px,auto) minmax(0,1fr);gap:8px;padding-top:8px;background:#fff}.record-card{display:grid;gap:10px}.records-toolbar{display:grid;gap:8px;margin-bottom:12px}.records-toolbar label{display:grid;gap:4px;color:#3a4656;font-size:12px}.records-toolbar input{width:100%;min-height:42px;border:1px solid #b9c3d0;border-radius:8px;padding:8px 10px;background:#fff}.records-toolbar p{margin-bottom:0;font-size:13px}.wide-secondary-action{width:100%}.result-detail-panel{display:grid;gap:12px;margin-top:12px;border:1px solid var(--border-color);border-radius:8px;background:#fbfcfe;padding:12px}.detail-header{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:start}.detail-meta{display:grid;gap:4px;color:var(--text-muted);font-family:SF Mono,Menlo,Monaco,Consolas,monospace;font-size:12px}.detail-json{max-height:220px;overflow:auto;margin:0 0 12px;border:1px solid #e4e9f0;border-radius:8px;background:#fff;padding:10px;color:#3a4656;font-family:SF Mono,Menlo,Monaco,Consolas,monospace;font-size:12px;white-space:pre-wrap;word-break:break-word}.record-type{margin-bottom:4px;color:var(--primary-color);font-size:12px;font-weight:800}.record-card h3{margin-bottom:4px}.chart-wrap{margin-top:12px}.chart-wrap svg{width:100%;max-height:300px;border:1px solid var(--border-color);border-radius:8px}.legend{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}.legend span{display:inline-flex;align-items:center;gap:6px}.legend i{display:inline-block;width:12px;height:12px}.loading-modal{position:fixed;inset:0;z-index:30;display:grid;place-items:center;padding:24px;background:#0f172a61}.loading-modal>div{width:min(360px,100%);border-radius:8px;background:#fff;padding:18px;border:1px solid var(--border-color)}.error{color:var(--error-color);background:#fff1f0;border:1px solid #ffccc7;border-radius:8px;padding:8px 10px}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{border-bottom:1px solid #e4e9f0;padding:8px;text-align:left}@media(max-width:520px){.mobile-shell{max-width:none}.mobile-header{grid-template-columns:auto minmax(0,1fr)}.mobile-header .status-badge{grid-column:1 / -1;justify-self:start;max-width:100%}.input-row,.compact-row{grid-template-columns:1fr}.input-row button{width:100%}.signal-source{grid-column:1;max-width:100%;white-space:normal}.capture-backdrop{padding:8px}.capture-sheet{max-height:calc(100dvh - 16px);padding-bottom:calc(14px + var(--safe-bottom))}.capture-actions{grid-template-columns:1fr}}@media(min-width:769px){.mobile-shell{box-shadow:0 0 24px #0f172a14}.task-grid,.method-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}}
