:root{color:#17201a;font-synthesis:none;text-rendering:optimizelegibility;background:#f7f4ed;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button{font:inherit}button:disabled{cursor:not-allowed;opacity:.62}.app{background:linear-gradient(135deg,#ffffffad,#fff0),#f7f4ed;min-height:100vh}.topbar{border-bottom:1px solid #d8d3c8;justify-content:space-between;align-items:center;min-height:64px;padding:0 28px;display:flex}.brand{align-items:center;gap:12px;display:flex}.brand-mark{color:#f7f4ed;background:#17201a;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;display:inline-flex}.brand h1{margin:0;font-size:18px;line-height:1.1}.brand span{color:#6d6b64;margin-top:2px;font-size:13px;display:block}.status-pill{color:#4d4a43;border:1px solid #c8c1b4;border-radius:999px;align-items:center;gap:8px;min-height:34px;padding:0 12px;font-size:13px;display:inline-flex}.status-dot{background:#9c8f7d;border-radius:999px;width:8px;height:8px}.status-dot.ok{background:#2f8b57}.status-dot.error{background:#b4443f}.main{grid-template-columns:minmax(0,1.25fr) minmax(280px,.75fr);gap:24px;max-width:1180px;margin:0 auto;padding:48px 28px;display:grid}.panel{background:#fffdf8;border:1px solid #ddd6ca;border-radius:8px;padding:24px}.panel h2{margin:0 0 8px;font-size:24px;line-height:1.2}.panel p{color:#5d5a52;margin:0;line-height:1.6}.section-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.flow{gap:12px;margin-top:24px;display:grid}.flow-step{border:1px solid #e3ded4;border-radius:8px;grid-template-columns:40px minmax(0,1fr);align-items:center;gap:14px;min-height:68px;padding:12px;display:grid}.flow-step svg{color:#2b6f70}.flow-step strong{margin-bottom:3px;font-size:15px;display:block}.flow-step span{color:#6d6b64;font-size:13px;display:block}.metric-grid{gap:12px;margin-top:20px;display:grid}.photo-search{gap:8px;margin-top:20px;display:grid}.photo-search label{color:#4d4a43;font-size:13px;font-weight:700}.search-row{border:1px solid #cfc6b8;border-radius:8px;grid-template-columns:18px minmax(0,1fr) auto;align-items:center;gap:8px;min-height:40px;padding:0 10px;display:grid}.search-row svg{color:#6d6b64}.search-row input{color:#282d27;font:inherit;background:0 0;border:0;outline:none;min-width:0;font-size:13px}.search-row button{color:#4d4a43;cursor:pointer;background:0 0;border:0;justify-content:center;align-items:center;width:28px;height:28px;padding:0;display:inline-flex}.photo-results{border:1px solid #e3ded4;border-radius:8px;margin-top:14px;overflow:hidden}.photo-results-header{background:#f5f0e7;border-bottom:1px solid #e3ded4;justify-content:space-between;align-items:center;padding:9px 10px;display:flex}.photo-results-header span,.photo-results-header strong{font-size:12px}.photo-result-list{max-height:240px;display:grid;overflow-y:auto}.photo-result-list button{color:#282d27;cursor:pointer;text-align:left;background:#fffdf8;border:0;border-bottom:1px solid #eee8dd;gap:3px;min-height:48px;padding:8px 10px;display:grid}.photo-result-list button:last-child{border-bottom:0}.photo-result-list button.selected{background:#e5f0ef}.photo-result-list span{text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:700;overflow:hidden}.photo-result-list small{color:#6d6b64;font-size:11px}.metric{border-bottom:1px solid #e3ded4;padding-bottom:14px}.metric:last-child{border-bottom:0;padding-bottom:0}.metric span{color:#6d6b64;font-size:13px;display:block}.metric strong{margin-top:4px;font-size:26px;display:block}.actions{gap:10px;margin-top:24px;display:flex}.icon-button{color:#fffdf8;cursor:pointer;background:#17201a;border:1px solid #17201a;border-radius:8px;align-items:center;gap:8px;min-height:40px;padding:0 14px;display:inline-flex}.icon-button.secondary{color:#17201a;background:0 0}.upload-box{grid-template-columns:minmax(0,1fr) auto;align-items:stretch;gap:12px;margin-top:24px;display:grid}.file-control{cursor:pointer;border:1px dashed #b9b1a4;border-radius:8px;grid-template-columns:28px minmax(0,1fr);align-items:center;gap:12px;min-height:48px;padding:0 14px;display:grid}.file-control svg{color:#2b6f70}.file-control span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.file-control input{opacity:0;width:1px;height:1px;position:absolute}.notice{border-radius:8px;margin-top:14px;padding:10px 12px;font-size:14px;line-height:1.4}.notice.success,.notice.saved{color:#235d3f;background:#e7f2ea}.notice.error{color:#8a2f2a;background:#f5e4e1}.notice.idle,.notice.uploading{color:#4d4a43;background:#eee9df}.table-wrap{border:1px solid #e3ded4;border-radius:8px;margin-top:20px;overflow-x:auto}.empty-card{color:#6d6b64;border:1px dashed #d8d0c4;border-radius:8px;justify-content:center;align-items:center;min-height:120px;margin-top:20px;padding:24px;display:flex}.review-card{border:1px solid #e3ded4;border-radius:8px;margin-top:20px;overflow:hidden}.review-card-header{background:#faf7f0;border-bottom:1px solid #e3ded4;justify-content:space-between;align-items:flex-start;gap:16px;padding:16px;display:flex}.review-card h3{overflow-wrap:anywhere;margin:0;font-size:18px;line-height:1.25}.photo-meta{color:#6d6b64;flex-wrap:wrap;align-items:center;gap:8px;margin-top:10px;font-size:13px;display:flex}.review-nav{flex:none;align-items:center;gap:8px;display:flex}.reviewer-switch{border:1px solid #c8c1b4;border-radius:8px;margin-right:8px;display:inline-flex;overflow:hidden}.reviewer-switch button{color:#4d4a43;cursor:pointer;background:0 0;border:0;min-height:34px;padding:0 10px;font-size:13px}.reviewer-switch button.selected{color:#fffdf8;background:#17201a}.review-nav span{color:#4d4a43;text-align:center;min-width:44px;font-size:13px}.square-button{justify-content:center;width:36px;min-height:36px;padding:0}.review-body{grid-template-columns:minmax(220px,.34fr) minmax(0,1fr);gap:16px;padding:16px;display:grid}.review-tools{gap:14px;min-width:0;display:grid}.photo-preview{color:#fffdf8;cursor:pointer;text-align:left;background:#111612;border:0;border-radius:8px;align-self:start;padding:0;display:grid;overflow:hidden}.photo-preview img{aspect-ratio:4/5;object-fit:contain;width:100%;height:auto;max-height:520px;display:block}.photo-preview span{justify-content:center;align-items:center;gap:8px;min-height:40px;padding:0 12px;font-size:13px;display:flex}.review-footer{border-top:1px solid #e3ded4;justify-content:space-between;align-items:center;gap:10px;padding:14px 16px;display:flex}.autosave-status{color:#6d6b64;min-height:20px;font-size:13px}.autosave-status.error{color:#8a2f2a}table{border-collapse:collapse;width:100%;min-width:720px}th,td{text-align:left;vertical-align:middle;border-bottom:1px solid #e7e1d7;padding:12px;font-size:14px}th{color:#4d4a43;text-transform:uppercase;background:#f5f0e7;font-size:12px;font-weight:700}td{color:#282d27}tbody tr:last-child td{border-bottom:0}.empty{color:#6d6b64;text-align:center;height:72px}.badge{color:#4d4a43;background:#eee9df;border:1px solid #d9d1c4;border-radius:999px;min-height:26px;padding:4px 10px;font-size:12px;display:inline-flex}.badge.accent{color:#225f60;background:#e5f0ef;border-color:#bed6d2}.badge.ai{color:#5b3f77;background:#efeaf5;border-color:#d6c9e3}.answer-row td{background:#faf7f0;padding-top:0}.matrix-wrap{border:1px solid #e3ded4;border-radius:8px;max-width:100%;overflow-x:auto}.review-matrix{table-layout:fixed;min-width:980px}.review-matrix th,.review-matrix td{vertical-align:top;min-width:150px}.review-matrix th{text-transform:none}.review-matrix thead th{background:#f1ece2}.review-matrix thead th span{color:#282d27;text-transform:uppercase;font-size:12px;font-weight:800;display:block}.review-matrix thead th small{color:#5d5a52;text-transform:none;margin-top:4px;font-size:11px;font-weight:600;line-height:1.35;display:block}.review-matrix .source-column{z-index:1;width:132px;min-width:132px;position:sticky;left:0}.review-matrix thead .source-column{z-index:2}.review-matrix tbody .source-column{color:#282d27;background:#fffdf8;font-size:13px;font-weight:800}.matrix-answer{gap:4px;min-height:24px;display:grid}.matrix-answer strong{color:#282d27;overflow-wrap:anywhere;font-size:13px}.human-answer{color:#282d27;overflow-wrap:anywhere;font-size:13px;display:block}.matrix-answer span,.pending-cell{color:#6d6b64;font-size:12px}.pending-cell{min-height:24px;padding-top:2px;display:inline-flex}.matrix-select{color:#282d27;font:inherit;background:#fffdf8;border:1px solid #cfc6b8;border-radius:8px;width:100%;max-width:100%;min-height:34px;padding:0 8px;font-size:12px}.run-details{border:1px solid #e3ded4;border-radius:8px;overflow:hidden}.run-details-header{background:#f5f0e7;border-bottom:1px solid #e3ded4;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;display:flex}.run-details-header strong{font-size:13px}.run-details-header span{color:#6d6b64;font-size:12px}.review-focus{border-bottom:1px solid #e7e1d7;gap:10px;padding:12px;display:grid}.review-focus strong{font-size:13px}.review-focus p{color:#5d5a52;margin:0;font-size:12px;line-height:1.45}.focus-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.focus-grid span{color:#6d6b64;margin-bottom:4px;font-size:11px;display:block}.focus-grid ol{gap:4px;margin:0;padding-left:18px;display:grid}.focus-grid li{font-size:12px}.focus-grid small{color:#6d6b64}.run-detail-grid{gap:0;display:grid}.run-detail{border-bottom:1px solid #e7e1d7;gap:10px;padding:12px;display:grid}.run-detail:last-child{border-bottom:0}.run-detail-title{justify-content:space-between;align-items:center;gap:8px;display:flex}.run-detail-title strong{font-size:13px}.run-detail p{color:#5d5a52;margin:0;font-size:12px;line-height:1.45}.run-facts{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin:0;display:grid}.run-facts div{min-width:0}.run-facts dt{color:#6d6b64;font-size:11px}.run-facts dd{color:#282d27;overflow-wrap:anywhere;margin:2px 0 0;font-size:12px;font-weight:700}.token-breakdown{color:#6d6b64;flex-wrap:wrap;gap:8px;font-size:12px;display:flex}.token-breakdown span{background:#faf7f0;border:1px solid #e7e1d7;border-radius:999px;padding:4px 8px}.gate-list{gap:8px;margin:0;padding:0;list-style:none;display:grid}.gate-list li{background:#faf7f0;border:1px solid #e7e1d7;border-radius:8px;gap:3px;padding:8px;display:grid}.gate-list strong,.gate-list span,.gate-list small{font-size:12px}.gate-list span,.gate-list small{color:#5d5a52}.run-error{color:#8a2f2a!important}.image-modal{z-index:20;background:#111612eb;grid-template-rows:auto minmax(0,1fr);padding:18px;display:grid;position:fixed;inset:0}.image-modal-header{color:#fffdf8;justify-content:space-between;align-items:center;gap:16px;min-height:44px;display:flex}.image-modal-header span{text-overflow:ellipsis;white-space:nowrap;font-size:14px;overflow:hidden}.modal-close{color:#fffdf8;border-color:#fffdf8}.image-modal img{object-fit:contain;place-self:center;max-width:100%;max-height:calc(100vh - 92px);display:block}.export-button{justify-content:center;width:100%;margin-top:24px}.mini-note{color:#6d6b64;grid-template-columns:18px minmax(0,1fr);align-items:flex-start;gap:8px;margin-top:16px;font-size:13px;line-height:1.5;display:grid}.mini-note svg{color:#2b6f70;margin-top:2px}@media (width<=760px){.topbar{flex-direction:column;align-items:flex-start;gap:12px;padding:18px}.main{grid-template-columns:1fr;padding:24px 18px}.section-header{display:grid}.upload-box{grid-template-columns:1fr}.review-card-header{display:grid}.review-nav{flex-wrap:wrap}.review-body,.focus-grid{grid-template-columns:1fr}}
