:root{--page: #f5f8fc;--surface: #ffffff;--surface-tint: #edf3fb;--surface-tint-strong: #e8eef7;--surface-hover: #f7faff;--border: #d5dce7;--border-soft: #e6ebf2;--border-strong: #c4ccd8;--text: #202124;--text-muted: #5f6368;--text-soft: #8a9099;--accent: #1a73e8;--accent-soft: #c9e7ff;--success: #188038;--warning: #b06000;--danger: #d93025;--on-accent: #ffffff;--shadow-soft: 0 2px 8px rgba(60, 64, 67, .08);--r-sm: 6px;--r-md: 8px;--r-lg: 12px;--r-pill: 9999px;--sp-xs: 8px;--sp-sm: 12px;--sp-md: 16px;--sp-lg: 24px;--sp-xl: 32px;font-family:Roboto,Arial,Helvetica Neue,system-ui,sans-serif;color:var(--text);background:var(--page);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*,*:before,*:after{box-sizing:border-box}body{min-width:320px;margin:0;background:var(--page)}button,input,select{font:inherit}button{color:inherit}a{color:inherit;text-decoration:none}svg{width:18px;height:18px;flex:0 0 auto}.app-shell{min-height:100vh;display:flex;flex-direction:column;background:var(--page)}.topnav{height:52px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:16px;padding:0 16px;background:var(--surface);position:relative;z-index:90}.topnav-brand{font-size:18px;font-weight:500;white-space:nowrap}.topnav-links{height:100%;display:flex;align-items:stretch;gap:2px}.topnav-links a{position:relative;display:flex;align-items:center;padding:0 12px;color:var(--text);font-size:14px;font-weight:500}.topnav-links a.active:after{position:absolute;left:16px;right:16px;bottom:0;height:2px;background:var(--accent);content:""}.topnav-right,.asset-status{display:flex;align-items:center;gap:10px}.status-badge,.status-chip,.filter-chip{display:inline-flex;align-items:center;gap:6px;min-height:28px;border-radius:var(--r-sm);font-size:14px;line-height:1;white-space:nowrap}.status-badge{padding:0 10px;border:1px solid transparent;font-weight:500}.status-badge.is-ready{color:var(--success);background:#e6f4ea}.status-badge.is-missing{color:var(--warning);background:#fef7e0}.icon-button,.row-icon{width:36px;height:36px;border:0;border-radius:var(--r-pill);display:inline-flex;align-items:center;justify-content:center;color:var(--text-muted);background:transparent;cursor:pointer}.icon-button:hover,.row-icon:hover,.toolbar-action:hover,.text-link:hover{background:#1a73e814;color:var(--accent)}button:disabled,.primary-action:disabled{cursor:not-allowed;opacity:.55}.user-dot{width:38px;height:38px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:#d2e3fc;color:#174ea6;font-weight:500}.page-canvas{width:min(100%,1344px);margin:0 auto;padding:42px 24px 88px;flex:1}.jobs-count{max-width:1280px;margin:0 auto 20px;text-align:right;font-size:22px;font-weight:400}.server-workspace{max-width:1280px;margin:0 auto}.workspace-heading{min-height:56px;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 16px;border-radius:var(--r-lg);background:var(--surface-tint);font-size:15px}.workspace-heading strong{font-weight:400}.text-link,.toolbar-action{border:0;border-radius:var(--r-pill);display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--accent);font-size:14px;font-weight:500;cursor:pointer}.text-link{padding:8px 10px}.workspace-toolbar{min-height:72px;display:flex;align-items:end;justify-content:flex-end;gap:24px;padding:0 20px 12px}.toolbar-action{min-height:36px;padding:0 10px;color:var(--text)}.entity-row{min-height:76px;display:grid;grid-template-columns:24px 146px 92px minmax(280px,1fr) 40px 40px;align-items:center;gap:12px;padding:10px 18px;border-radius:var(--r-lg);background:var(--surface-tint)}.drag-icon{color:var(--border-strong)}.entity-field,.entity-input{min-height:50px;border:1px solid var(--border-strong);border-radius:var(--r-md);background:transparent;color:var(--text)}.entity-field{display:grid;grid-template-columns:1fr auto;align-items:center;gap:4px 8px;padding:8px 12px;text-align:left}.entity-field span{grid-column:1 / -1;color:var(--text-muted);font-size:11px}.entity-field strong{font-size:14px;font-weight:400}.entity-input{display:flex;align-items:center;width:100%;padding:0 16px;text-align:left;color:var(--text-muted);cursor:pointer}.entity-input.has-file{color:var(--text);background:#ffffff57}.row-icon.muted{color:#9bb0c8}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.workspace-actions{position:relative;min-height:96px;display:flex;align-items:center;justify-content:center;padding:18px 0 28px}.outline-action,.primary-action{min-height:42px;border-radius:var(--r-pill);display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 20px;font-size:14px;font-weight:500}.outline-action{border:1px solid var(--border-strong);background:var(--surface);color:var(--text)}.outline-action:hover{border-color:var(--accent);color:var(--accent)}.workspace-actions .outline-action{position:absolute;left:0}.primary-action{border:0;background:var(--accent);color:var(--on-accent)}.primary-action:disabled{background:var(--surface-tint-strong);color:var(--text-soft)}.job-bar,.missing-panel{max-width:1280px;margin:0 auto 16px}.job-bar-inner,.missing-inner{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface)}.job-bar-inner strong{display:block;font-size:14px;font-weight:500}.job-bar-inner p{margin:4px 0 0;color:var(--text-muted);font-size:13px}.job-bar-inner.is-failed svg,.missing-inner strong{color:var(--danger)}.job-bar-inner.is-completed svg{color:var(--success)}.missing-inner{display:block;border-color:#f6d88f}.missing-inner ul{margin:8px 0 0;padding-left:18px;color:var(--warning);font-size:13px}.history-panel{max-width:1280px;margin:44px auto 0;overflow:hidden;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface)}.history-search{min-height:56px;display:flex;align-items:center;gap:18px;padding:0 16px;border-bottom:1px solid var(--border-soft);background:#f7faff}.history-search svg{color:var(--text)}.history-search input{width:100%;border:0;outline:0;background:transparent;color:var(--text);font-size:16px}.history-search input::placeholder{color:var(--text-muted)}.history-filters{display:flex;flex-wrap:wrap;gap:8px;padding:24px 16px 18px;border-bottom:1px solid var(--border-soft)}.filter-chip{border:0;padding:0 12px;background:transparent;color:var(--text);cursor:pointer}.filter-chip.is-selected{background:var(--accent-soft);color:#0b314f}.history-table-wrap{min-height:112px;overflow-x:auto}.history-empty{padding:24px 20px;color:var(--text);font-size:15px}table{width:100%;min-width:760px;border-collapse:collapse;font-size:13px}th,td{padding:12px 16px;border-bottom:1px solid var(--border-soft);text-align:left;vertical-align:middle}th{color:var(--text-muted);font-size:12px;font-weight:500}td{color:var(--text)}.history-table tbody tr{cursor:pointer}.history-table tbody tr:hover,.history-table tbody tr.is-selected{background:var(--surface-hover)}.job-id{display:inline-flex;align-items:center;gap:8px;font-variant-numeric:tabular-nums}.status-chip{width:fit-content;padding:0 10px;border:1px solid var(--border-soft);background:var(--surface-hover);color:var(--text-muted);font-size:13px}.status-chip svg{width:14px;height:14px}.status-chip.status-completed,.status-chip.is-positive{border-color:#cce8d1;background:#e6f4ea;color:var(--success)}.status-chip.status-running,.status-chip.status-queued{border-color:#d2e3fc;background:#e8f0fe;color:#174ea6}.status-chip.status-failed,.status-chip.is-negative{border-color:#fad2cf;background:#fce8e6;color:var(--danger)}.history-footer{min-height:56px;display:flex;align-items:center;justify-content:flex-end;gap:18px;padding:0 20px;color:var(--text);font-size:13px}.page-size{min-width:84px;height:42px;border:1px solid var(--border-strong);border-radius:var(--r-sm);display:inline-flex;align-items:center;justify-content:space-between;padding:0 10px 0 16px;background:var(--surface)}.pager-icons{display:inline-flex;gap:14px;color:var(--text-soft)}.result-preview,.result-placeholder{max-width:1280px;margin:24px auto 0;min-width:0}.analysis-panel{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);padding:18px;min-width:0}.result-placeholder{color:var(--text-muted);text-align:center}.overview-band{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:16px}.overview-band h2,.panel-header h3,.result-verdict h2{margin:4px 0 0;font-size:18px;font-weight:500}.overview-band p,.result-verdict p,.score-card p{margin:4px 0 0;color:var(--text-muted);font-size:13px}.panel-label{color:var(--text-muted);font-size:12px;font-weight:500}.compound-select{min-width:260px;height:42px;border:1px solid var(--border-strong);border-radius:var(--r-md);background:var(--surface);padding:0 12px;color:var(--text)}.score-grid{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr) minmax(0,1fr);gap:16px;margin-bottom:16px}.result-verdict{border-left:4px solid var(--text-muted)}.result-verdict.is-positive{border-left-color:var(--success)}.result-verdict.is-negative{border-left-color:var(--danger)}.score-line{display:flex;align-items:center;justify-content:space-between;gap:12px}.score-line span{color:var(--text-muted);font-size:14px}.score-line strong{font-size:24px;font-weight:500}.meter{height:8px;margin:14px 0 8px;overflow:hidden;border-radius:var(--r-pill);background:var(--surface-tint-strong)}.meter span{display:block;max-width:100%;height:100%;border-radius:var(--r-pill)}.meter-avg span{background:var(--accent)}.meter-sup span{background:var(--text-muted)}.dumbbell-panel{display:flex;flex-direction:column;gap:12px}.dumbbell-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.dumbbell-summary{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.direction-pill{display:inline-flex;align-items:center;min-height:28px;border-radius:var(--r-sm);padding:0 10px;font-size:12px;font-weight:500}.direction-pill.is-up{color:var(--danger);background:#fce8e6}.direction-pill.is-down{color:#1967d2;background:#e8f0fe}.compact-dumbbell{display:flex;flex-direction:column;gap:10px}.compact-summary{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.compact-rows{display:flex;flex-direction:column;gap:1px;max-height:560px;overflow-y:auto;overflow-x:hidden;padding:2px 2px 2px 0;scrollbar-width:thin}.compact-row{position:relative;min-height:18px;padding:1px 0}.compact-gene{font-size:12px;font-weight:500;color:var(--text);line-height:1.25}.compact-gene-label{position:absolute;top:50%;transform:translateY(-50%);white-space:nowrap;z-index:3;pointer-events:none}.compact-row.is-up .compact-gene-label{right:50%;text-align:right;padding-right:6px}.compact-row.is-down .compact-gene-label{left:50%;text-align:left;padding-left:6px}.compact-track{position:relative;height:14px;min-width:0}.compact-track:before{content:"";position:absolute;top:1px;bottom:1px;left:50%;width:1px;background:var(--border-soft);transform:translate(-.5px);pointer-events:none}.compact-line{position:absolute;top:50%;height:1.5px;border-radius:1px;transform:translateY(-50%)}.compact-row.is-up .compact-line{background:#d93025;opacity:.72}.compact-row.is-down .compact-line{background:#1a73e8;opacity:.72}.compact-dot{position:absolute;top:50%;width:6px;height:6px;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 1.5px var(--surface)}.compact-row.is-up .compact-dot{background:#d93025}.compact-row.is-down .compact-dot{background:#1a73e8}.dumbbell-empty{min-height:120px;display:flex;align-items:center;justify-content:center;border:1px dashed var(--border);border-radius:var(--r-md);color:var(--text-muted);font-size:13px;text-align:center}.dumbbell-viewport{max-height:520px;overflow:auto;padding-right:4px;min-width:0}.dumbbell-plot{min-width:680px}.dumbbell-axis,.dumbbell-row{display:grid;grid-template-columns:minmax(120px,160px) minmax(280px,1fr) 76px;align-items:center;column-gap:14px}.dumbbell-axis{position:sticky;top:0;z-index:2;min-height:30px;border-bottom:1px solid var(--border);background:var(--surface);color:var(--text-soft);font-size:11px;font-weight:500}.axis-track{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:10px}.axis-track span:first-child{text-align:left}.axis-track span:last-child{text-align:right}.dumbbell-row{min-height:38px;border-bottom:1px solid var(--border-soft)}.dumbbell-protein{min-width:0;display:grid;gap:2px}.dumbbell-protein strong{overflow:hidden;color:var(--text);font-size:13px;font-weight:500;text-overflow:ellipsis;white-space:nowrap}.dumbbell-protein span{overflow:hidden;color:var(--text-soft);font-size:11px;text-overflow:ellipsis;white-space:nowrap}.dumbbell-track{position:relative;height:18px}.track-line,.track-zero,.track-segment,.track-origin,.track-marker{position:absolute;top:50%;transform:translateY(-50%)}.track-line{left:4%;right:4%;height:1px;background:var(--border-soft)}.track-zero{left:50%;width:1px;height:18px;background:var(--border-strong)}.track-segment{height:5px;border-radius:var(--r-pill);opacity:.72}.track-segment.is-up{background:#d93025}.track-segment.is-down{background:#1a73e8}.track-origin,.track-marker{border-radius:50%}.track-origin{width:6px;height:6px;background:var(--surface);border:1px solid var(--border-strong);transform:translate(-50%,-50%)}.track-marker{width:12px;height:12px;transform:translate(-50%,-50%);box-shadow:0 0 0 2px var(--surface)}.track-marker.is-up{background:#d93025}.track-marker.is-down{background:#1a73e8}.dumbbell-value{justify-self:end;font-size:12px;font-variant-numeric:tabular-nums;font-weight:500}.dumbbell-value.is-up{color:var(--danger)}.dumbbell-value.is-down{color:#1967d2}.visual-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:16px;margin-bottom:16px}.visual-grid>.visual-grid-wide{grid-column:1 / -1}.interp-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-bottom:16px}.score-grid>*,.visual-grid>*,.interp-grid>*{min-width:0}.dumbbell-row.is-down{grid-template-columns:76px minmax(280px,1fr) minmax(120px,160px)}.dumbbell-row.is-down .dumbbell-protein{text-align:right;justify-items:end}.dumbbell-row.is-down .dumbbell-value{justify-self:start;text-align:left}.chart-box{width:100%;height:320px}.chart-empty{height:320px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-align:center;color:var(--text-muted);padding:24px;border:1px dashed var(--border-soft);border-radius:var(--r-md);background:var(--surface-tint-soft, transparent)}.chart-empty-title{font-size:14px;font-weight:600;color:var(--text);margin:0}.chart-empty-hint{font-size:12px;color:var(--text-muted);max-width:40ch;margin:0;line-height:1.4}.panel-header{margin-bottom:14px}.model-votes,.download-row{margin-bottom:16px}.table-wrap{width:100%;max-width:100%;overflow-x:auto}.table-wrap.compact{max-height:420px;overflow:auto}.download-row{display:flex;flex-wrap:wrap;gap:10px}.site-footer{background:var(--page);padding:16px 16px 24px}.footer-inner{max-width:1280px;margin:0 auto;display:flex;flex-wrap:wrap;align-items:center;gap:18px;color:var(--text);font-size:13px}.footer-inner strong{font-size:16px;font-weight:600;color:#4a4d52}.footer-inner a,.footer-inner span{color:var(--text);font-weight:500}.spin{animation:spin 1s linear infinite}.pulse{animation:pulse 1.2s ease-in-out infinite}.fade-in{animation:fadeUp .28s ease both}.fade-in-d1{animation-delay:.04s}.fade-in-d2{animation-delay:.08s}.fade-in-d3{animation-delay:.12s}.fade-in-d4{animation-delay:.16s}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{50%{opacity:.45}}@keyframes fadeUp{0%{opacity:0}to{opacity:1}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important}}@media(max-width:1024px){.entity-row{grid-template-columns:24px minmax(180px,1fr) minmax(120px,.6fr) 40px 40px}.entity-input{grid-column:2 / -3}.score-grid{grid-template-columns:1fr 1fr}.result-verdict{grid-column:1 / -1}}@media(max-width:840px){.topnav{min-height:64px;height:auto;grid-template-columns:1fr auto;padding:10px 16px 0}.topnav-links{grid-column:1 / -1;order:3;min-height:44px}.topnav-links a{padding:0 12px}.page-canvas{padding:28px 16px 64px}.jobs-count{text-align:left;font-size:18px}.workspace-heading,.overview-band,.dumbbell-header{align-items:flex-start;flex-direction:column}.workspace-toolbar{justify-content:flex-start;padding-left:0}.entity-row{grid-template-columns:22px 1fr 40px 40px;align-items:stretch}.entity-field,.entity-input{grid-column:2 / -1}.row-icon{align-self:center}.workspace-actions{align-items:stretch;flex-direction:column;gap:12px}.workspace-actions .outline-action{position:static}.score-grid,.visual-grid,.interp-grid{grid-template-columns:1fr}.compound-select{width:100%}.dumbbell-plot{min-width:0}.dumbbell-axis,.dumbbell-row{grid-template-columns:minmax(82px,104px) minmax(132px,1fr) 52px;column-gap:10px}.dumbbell-row.is-down{grid-template-columns:52px minmax(132px,1fr) minmax(82px,104px)}.dumbbell-protein strong{font-size:12px}.dumbbell-protein span,.dumbbell-axis{font-size:10px}.dumbbell-value{font-size:11px}.history-footer{justify-content:flex-start;flex-wrap:wrap}}@media(max-width:560px){.topnav{grid-template-columns:1fr}.topnav-right{justify-content:space-between}.topnav-brand{font-size:20px}.history-filters{padding-top:16px}}.app-shell{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}.app-layout{flex:1 1 auto;display:grid;grid-template-columns:260px 1fr;gap:0;width:100%;transition:grid-template-columns .2s ease}.app-layout:has(.app-sidebar.is-collapsed){grid-template-columns:52px 1fr}.content-pane{padding:20px 24px 56px;max-width:1320px;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:14px}@media(max-width:1024px){.app-layout{grid-template-columns:min(240px,60vw) 1fr}.app-layout:has(.app-sidebar.is-collapsed){grid-template-columns:40px 1fr}.content-pane{padding:14px 14px 48px}.topnav{height:64px;min-height:64px;gap:10px;padding:0 12px;overflow:hidden;grid-template-columns:auto 1fr auto}.topnav-brand{font-size:14px;gap:6px}.topnav-links{gap:10px;font-size:13px}.topnav-links a{padding:0 10px}.topnav-right{gap:6px}.topnav-right .status-badge{font-size:12px;padding:4px 8px}.topnav-right .icon-button{width:28px;height:28px}.topnav-right .user-dot{width:30px;height:30px;font-size:12px}}.app-sidebar{background:var(--surface);color:var(--text);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;border-right:1px solid var(--border-soft);overflow:hidden;transition:width .2s ease}@media(max-width:1024px){.app-sidebar{position:static;width:auto;height:auto;max-height:calc(100vh - 64px);border-right:1px solid var(--border-soft);border-bottom:none;overflow-y:auto;box-shadow:none}.app-sidebar.is-collapsed{height:64px;max-height:64px;align-self:start;overflow:hidden;border-bottom:1px solid var(--border-soft)}.app-sidebar.is-collapsed .sidebar-new,.app-sidebar.is-collapsed .sidebar-search,.app-sidebar.is-collapsed .sidebar-list,.app-sidebar.is-collapsed .sidebar-footer{display:none}.app-sidebar.is-collapsed .sidebar-top{justify-content:center;padding:14px 4px;border-bottom:none}}.sidebar-top{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px 12px 10px;border-bottom:1px solid var(--border-soft)}.sidebar-top-label{font-size:13px;font-weight:600;letter-spacing:.2px;color:var(--text);white-space:nowrap}.sidebar-toggle{background:transparent;border:1px solid var(--border);border-radius:var(--r-sm);padding:6px;cursor:pointer;color:var(--text-muted);display:inline-flex;align-items:center;justify-content:center;transition:background .1s ease,border-color .1s ease,color .1s ease}.sidebar-toggle:hover{background:var(--surface-tint);border-color:var(--border-strong);color:var(--text)}.app-sidebar.is-collapsed .sidebar-top{padding:14px 8px;justify-content:center}.app-sidebar.is-collapsed .sidebar-top-label,.app-sidebar.is-collapsed .sidebar-new-label,.app-sidebar.is-collapsed .sidebar-search,.app-sidebar.is-collapsed .sidebar-footer,.app-sidebar.is-collapsed .sidebar-item-row,.app-sidebar.is-collapsed .sidebar-item-name,.app-sidebar.is-collapsed .sidebar-item-stats{display:none}.app-sidebar.is-collapsed .sidebar-item{align-items:center;justify-content:center;padding:6px;min-height:32px}.app-sidebar.is-collapsed .sidebar-list{padding:4px;align-items:center}.sidebar-header{padding:24px 20px 16px;display:flex;flex-direction:column;gap:4px;border-bottom:1px solid var(--border-soft)}.sidebar-title{font-size:18px;font-weight:600;letter-spacing:.4px}.sidebar-subtitle{font-size:12px;color:var(--text-soft);text-transform:uppercase;letter-spacing:.5px}.sidebar-new{margin:12px 16px 0;display:flex;align-items:center;justify-content:center;gap:8px;background:var(--accent);color:var(--on-accent);border:none;border-radius:var(--r-md);padding:9px 12px;font-weight:600;font-size:14px;cursor:pointer;box-shadow:0 2px 8px -2px #1a73e859;transition:transform .1s ease,box-shadow .2s ease,background .1s ease}.sidebar-new:hover{background:#1668d3;transform:translateY(-1px)}.sidebar-new:active{transform:translateY(0)}.sidebar-new.is-active{outline:2px solid var(--accent-soft);outline-offset:2px}.app-sidebar.is-collapsed .sidebar-new{margin:12px 8px 0;padding:9px 6px}.sidebar-search{margin:12px 16px 8px;display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--surface-tint);border-radius:var(--r-md);border:1px solid var(--border-soft)}.sidebar-search input{background:transparent;border:none;outline:none;color:var(--text);font-size:13px;flex:1 1 auto;min-width:0}.sidebar-search input::placeholder{color:var(--text-soft)}.sidebar-section-label{font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:var(--text-soft);margin:12px 20px 6px}.sidebar-list{flex:1 1 auto;overflow-y:auto;padding:0 8px 8px;display:flex;flex-direction:column;gap:4px}.sidebar-item{border:1px solid transparent;border-radius:var(--r-md);padding:10px 12px;background:transparent;color:inherit;text-align:left;cursor:pointer;display:flex;flex-direction:column;gap:4px;transition:background .1s ease,border-color .1s ease}.sidebar-item:hover{background:var(--surface-tint);border-color:var(--border-soft)}.sidebar-item.is-active{background:var(--accent-soft);border-color:#1a73e859}.sidebar-item-row{display:flex;justify-content:space-between;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text)}.sidebar-item-name{flex:1 1 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:inline-flex;align-items:center;gap:6px;color:var(--text)}.sidebar-item-stats{font-size:11px;color:var(--text-muted);display:flex;justify-content:space-between;gap:8px}.sidebar-time{font-size:10px;color:var(--text-soft)}.sidebar-warning{font-size:10px;color:var(--warning)}.sidebar-status{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:2px 6px;border-radius:var(--r-sm);text-transform:uppercase;letter-spacing:.4px}.sidebar-status.is-completed{background:#1880381f;color:var(--success)}.sidebar-status.is-failed{background:#d930251f;color:var(--danger)}.sidebar-status.is-active{background:#1a73e81f;color:var(--accent)}.sidebar-item-dot{width:10px;height:10px;border-radius:50%;display:inline-block;flex:0 0 auto}.sidebar-item-dot.is-completed{background:var(--success)}.sidebar-item-dot.is-failed{background:var(--danger)}.sidebar-item-dot.is-active{background:var(--accent)}.sidebar-empty{padding:12px 16px;font-size:12px;color:var(--text-soft);text-align:center}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--border-soft);font-size:11px;color:var(--text-soft);display:flex;justify-content:space-between;align-items:center}.sidebar-pager{display:flex;gap:6px}.sidebar-pager button{background:transparent;border:1px solid var(--border);border-radius:var(--r-sm);padding:4px 6px;cursor:pointer;color:var(--text-muted);display:inline-flex;align-items:center}.sidebar-pager button:hover{background:var(--surface-tint);color:var(--text)}.sidebar-pager button:disabled{opacity:.4;cursor:not-allowed}.prediction-panel,.new-prediction{background:#fff;border-radius:18px;border:1px solid #e2e8f0;padding:24px;display:flex;flex-direction:column;gap:18px;box-shadow:0 4px 24px -16px #0f172a2e}.prediction-panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.prediction-panel-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.outline-action.compact{padding:6px 10px;border-radius:8px;border:1px solid #cbd5e1;background:#fff;font-size:12px;color:#1e293b;display:inline-flex;align-items:center;gap:6px;cursor:pointer}.outline-action.compact:hover{background:#f8fafc}.empty-upload{display:flex;flex-direction:column;align-items:center;text-align:center;padding:36px 20px;border:1px dashed #cbd5e1;border-radius:14px;background:#f8fafc;gap:10px;color:#475569}.empty-upload-icon{color:#6366f1}.uploaded-summary{display:flex;flex-direction:column;gap:10px;border:1px solid #e2e8f0;border-radius:14px;padding:16px 18px;background:#f8fafc}.uploaded-filename{font-weight:600;font-size:15px;display:flex;align-items:center;gap:8px}.uploaded-meta{display:flex;gap:14px;font-size:12px;color:#64748b;flex-wrap:wrap}.run-button{background:linear-gradient(135deg,#38bdf8,#6366f1);border:none;color:#fff;padding:10px 16px;border-radius:10px;display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-weight:600;box-shadow:0 6px 18px -10px #6366f1b3}.run-button:disabled{opacity:.6;cursor:not-allowed}.upload-error{border:1px solid #fecaca;background:#fef2f2;color:#b91c1c;border-radius:12px;padding:10px 14px;font-size:13px}.csv-preview{background:#fff;border:1px solid #e2e8f0;border-radius:16px;overflow:hidden;transition:box-shadow .15s ease}.csv-preview.is-open{box-shadow:0 8px 32px -22px #0f172a40}.csv-preview-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;gap:12px;flex-wrap:wrap}.csv-preview-toggle{background:transparent;border:none;display:flex;align-items:center;gap:10px;text-align:left;cursor:pointer;flex:1 1 auto;padding:0}.csv-preview-title{font-size:14px;font-weight:600;color:#0f172a}.csv-preview-note{font-size:12px;color:#64748b}.csv-preview-actions{display:flex;align-items:center;gap:8px;font-size:12px;color:#475569}.csv-preview-count{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:#94a3b8}.csv-preview-body{border-top:1px solid #e2e8f0;background:#f8fafc;max-height:360px;overflow:auto}.csv-preview-table-wrap{min-width:100%}.csv-preview-table{width:100%;border-collapse:collapse;font-size:12px}.csv-preview-table th,.csv-preview-table td{border-bottom:1px solid #e2e8f0;padding:6px 10px;text-align:left;white-space:nowrap}.csv-preview-table th{background:#eef2f7;position:sticky;top:0;z-index:1;font-weight:600;color:#334155}.csv-preview-status{padding:18px;font-size:13px;color:#475569}.chart-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;margin-bottom:16px}.chart-card-description{font-size:12px;color:#64748b;margin-top:4px;max-width:64ch}.chart-card-download{display:inline-flex;align-items:center;gap:6px;border:1px solid #cbd5e1;background:#fff;color:#0f172a;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap}.chart-card-download:hover{background:#f1f5f9}.chart-card-download:focus-visible{outline:2px solid #6366f1;outline-offset:2px}.chart-card-body{display:block}.overview-card{container-type:inline-size;container-name:overview}.overview-card .chart-card-body{display:block}@container overview (max-width: 720px){.overview-card .score-grid{grid-template-columns:1fr 1fr}.overview-card .result-verdict{grid-column:1 / -1}}.result-preview{display:flex;flex-direction:column;gap:18px}.overview-band{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.overview-band-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.compound-select{border:1px solid #cbd5e1;background:#fff;border-radius:10px;padding:8px 12px;font-size:13px;min-width:180px}.primary-action.download-all{background:#0f172a;color:#fff;border:none;border-radius:10px;padding:8px 14px;font-size:13px;display:inline-flex;align-items:center;gap:8px;cursor:pointer}.primary-action.download-all:disabled{opacity:.6;cursor:not-allowed}.placeholder-panel{background:#fff;border:1px dashed #cbd5e1;border-radius:18px;padding:32px;text-align:center;color:#475569}.result-footer{display:flex;align-items:center;gap:10px;color:#94a3b8;font-size:12px;padding:12px 4px 0;border-top:1px dashed #e2e8f0;margin-top:8px}.result-footer em{font-style:normal;font-weight:600;color:#475569}.compound-selector{display:flex;align-items:flex-end;gap:16px;flex-wrap:wrap;background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-lg);box-shadow:var(--shadow-soft);padding:14px 18px}.compound-selector-field{display:flex;flex-direction:column;gap:4px;min-width:0}.compound-selector-field:first-child{flex:1 1 320px}.compound-selector-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.compound-selector-select{font-size:14px;padding:7px 10px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);color:var(--text);cursor:pointer;min-width:220px}.compound-selector-select:hover{border-color:var(--border-strong)}.compound-selector-select:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.summary-detail{display:flex;flex-direction:column;gap:18px}.landing-shell{min-height:100vh;display:flex;flex-direction:column;background:var(--page)}.landing-topnav,.auth-topnav{border-bottom:1px solid var(--border-soft)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border-radius:var(--r-md);padding:8px 16px;font-size:14px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:background .12s ease,border-color .12s ease,color .12s ease;white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.55}.btn-primary{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}.btn-primary:hover:not(:disabled){background:#1765cc;border-color:#1765cc}.btn-ghost{background:transparent;color:var(--accent);border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--surface-tint)}.btn-lg{padding:12px 24px;font-size:15px}.user-pill{display:inline-flex;align-items:center;height:32px;padding:0 12px;border-radius:var(--r-pill);background:var(--surface-tint);color:var(--text-muted);font-size:13px;font-weight:500;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu{position:relative}.user-menu .user-dot{border:none;cursor:pointer;padding:0;font-size:15px;transition:box-shadow .12s ease,transform .12s ease}.user-menu .user-dot:hover{box-shadow:0 0 0 3px var(--surface-tint-strong)}.user-menu .user-dot:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.user-menu-popover{position:absolute;right:0;top:calc(100% + 8px);min-width:220px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-soft);padding:8px 0;z-index:200}.user-menu-id{display:flex;flex-direction:column;padding:10px 14px;border-bottom:1px solid var(--border-soft)}.user-menu-id strong{font-size:14px;color:var(--text)}.user-menu-id span{font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-item{display:block;width:100%;padding:10px 14px;background:transparent;border:none;text-align:left;font-size:14px;color:var(--text);cursor:pointer}.user-menu-item:hover{background:var(--surface-tint)}.hero{padding:80px 24px 60px;background:radial-gradient(ellipse at top,rgba(26,115,232,.1),transparent 60%),var(--page)}.hero-inner{max-width:980px;margin:0 auto;text-align:center}.hero-eyebrow{display:inline-block;padding:6px 14px;border-radius:var(--r-pill);background:var(--surface-tint);color:var(--accent);font-size:12px;font-weight:600;letter-spacing:.02em;text-transform:uppercase;margin-bottom:18px}.hero h1{font-size:44px;line-height:1.15;font-weight:500;margin:0 0 18px;color:var(--text)}.hero-accent{background:linear-gradient(120deg,var(--accent) 0%,#4a8df8 100%);-webkit-background-clip:text;background-clip:text;color:transparent}.hero-sub{max-width:720px;margin:0 auto 30px;font-size:17px;line-height:1.55;color:var(--text-muted)}.hero-cta{display:flex;justify-content:center;flex-wrap:wrap;gap:12px;margin-bottom:18px}.hero-meta{margin:12px 0 0;font-size:13px;color:var(--text-soft);display:inline-flex;align-items:center;gap:8px;justify-content:center}.dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--text-soft)}.dot-ok{background:var(--success)}.dot-warn{background:var(--warning)}.features{padding:60px 24px;background:var(--surface);border-top:1px solid var(--border-soft);border-bottom:1px solid var(--border-soft)}.features-inner{max-width:1080px;margin:0 auto}.features h2,.workflow h2,.cta-band h2{font-size:28px;font-weight:500;text-align:center;margin:0 0 32px}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}.feature-card{padding:22px 20px;border-radius:var(--r-lg);background:var(--surface-tint);display:flex;flex-direction:column;gap:8px}.feature-card h3{font-size:16px;font-weight:600;margin:0}.feature-card p{font-size:14px;line-height:1.55;color:var(--text-muted);margin:0}.feature-card code{background:var(--surface);padding:1px 5px;border-radius:4px;font-size:12px}.feature-icon{width:32px;height:32px;border-radius:50%;background:var(--accent);color:var(--on-accent);display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;margin-bottom:4px}.workflow{padding:60px 24px}.workflow-inner{max-width:760px;margin:0 auto}.workflow-steps{margin:0;padding:0;list-style:none;counter-reset:wf;display:grid;gap:14px}.workflow-steps li{position:relative;padding:16px 18px 16px 56px;background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-md);counter-increment:wf;font-size:15px;line-height:1.55;color:var(--text-muted)}.workflow-steps li:before{content:counter(wf);position:absolute;left:18px;top:16px;width:26px;height:26px;border-radius:50%;background:var(--accent);color:var(--on-accent);font-size:13px;font-weight:700;display:inline-flex;align-items:center;justify-content:center}.workflow-steps strong{color:var(--text)}.cta-band{padding:60px 24px 80px;background:linear-gradient(180deg,var(--page) 0%,var(--surface-tint) 100%);border-top:1px solid var(--border-soft)}.cta-inner{max-width:720px;margin:0 auto;text-align:center}.auth-shell{min-height:100vh;display:flex;flex-direction:column;background:var(--page)}.auth-card-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 20px 60px}.auth-card{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-lg);padding:32px 28px;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow-soft)}.auth-card h1{font-size:26px;font-weight:500;margin:0}.auth-sub{font-size:14px;color:var(--text-muted);margin:0 0 6px}.auth-label{display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--text-muted)}.auth-label input{height:38px;border:1px solid var(--border);border-radius:var(--r-md);padding:0 12px;font-size:14px;background:var(--surface);color:var(--text)}.auth-label input:focus{outline:2px solid var(--accent-soft);border-color:var(--accent)}.auth-error{background:#fdecea;color:var(--danger);border:1px solid #f6c1bd;padding:10px 12px;border-radius:var(--r-md);font-size:13px;line-height:1.45}.auth-foot{font-size:13px;color:var(--text-muted);text-align:center;margin:0}.auth-foot a{color:var(--accent);text-decoration:none}.auth-foot a:hover{text-decoration:underline}@media(max-width:720px){.hero{padding:60px 20px 40px}.hero h1{font-size:32px}.hero-sub{font-size:15px}.features,.workflow,.cta-band{padding:40px 20px}.features h2,.workflow h2,.cta-band h2{font-size:22px}.topnav{gap:12px;padding:0 14px}.topnav-links{display:none}.auth-card{padding:24px 20px}.auth-card h1{font-size:22px}.user-pill{display:none}}
