html,body,#root{margin:0;padding:0;height:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:#f5f5f4;color:#111827}.app-root{display:flex;flex-direction:column;height:100vh}.app-header{display:flex;align-items:baseline;gap:12px;padding:12px 18px;background:#111827;color:#fafafa;border-bottom:1px solid #374151}.app-header h1{font-size:18px;margin:0}.app-subtitle{font-size:12px;color:#9ca3af}.app-header-spacer{flex:1}.app-user{font-size:12px;color:#d1d5db}.app-user strong{color:#fafafa}.app-logout{font-size:12px;padding:4px 10px;background:transparent;color:#fafafa;border:1px solid #4b5563;border-radius:4px;cursor:pointer}.app-logout:hover{background:#1f2937}.app-tabs{display:flex;gap:4px;padding:0 18px;background:#fff;border-bottom:1px solid #e5e7eb}.app-tab{background:transparent;border:0;border-bottom:2px solid transparent;padding:10px 14px;font-size:13px;color:#6b7280;cursor:pointer;display:inline-flex;align-items:center;gap:6px}.app-tab:hover:not(.active){color:#111827}.app-tab.active{color:#111827;border-bottom-color:#111827;font-weight:600}.app-tab-count{font-size:11px;background:#e5e7eb;color:#374151;padding:1px 6px;border-radius:10px;font-variant-numeric:tabular-nums;font-weight:500}.app-tab.active .app-tab-count{background:#111827;color:#fafafa}.history-pane{flex:1;min-height:0;padding:12px;display:flex}.history-pane>*{flex:1;min-height:0;background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.app-body{display:grid;grid-template-columns:minmax(360px,1fr) 2fr;flex:1;min-height:0;gap:12px;padding:12px}.editor-pane,.viewer-pane{background:#fff;border:1px solid #e5e7eb;border-radius:8px;display:flex;flex-direction:column;min-height:0;position:relative}.editor-pane.drag-active{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb26}.editor-pane.drag-active:after{content:"Drop image to transcribe";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#dbeafe8c;border:2px dashed #2563eb;border-radius:8px;color:#1d4ed8;font-size:14px;font-weight:600;pointer-events:none;z-index:5}.editor-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid #e5e7eb;background:#f9fafb;border-radius:8px 8px 0 0}.editor-header label{font-weight:600;font-size:13px}.mode-switch{display:inline-flex;border:1px solid #d1d5db;border-radius:4px;overflow:hidden;background:#fff}.mode-tab{padding:5px 12px;border:none;background:transparent;font-size:13px;cursor:pointer;color:#374151;border-right:1px solid #d1d5db}.mode-tab:last-child{border-right:none}.mode-tab:hover:not(.active){background:#f3f4f6}.mode-tab.active{background:#111827;color:#fafafa;font-weight:600}.problem-textarea{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:14px;line-height:1.5}.unsupported-banner{border-top:1px solid #fde68a;background:#fffbeb;color:#78350f;padding:10px 14px;font-size:13px;line-height:1.5}.unsupported-banner strong{color:#92400e}.unsupported-banner .unsupported-hint{margin-top:8px;font-size:12px;color:#92400e;line-height:1.6}.unsupported-banner code{background:#fef3c7;padding:0 4px;border-radius:2px;font-size:11px}.editor-actions button{margin-left:6px;padding:5px 12px;border:1px solid #d1d5db;border-radius:4px;background:#fff;font-size:13px;cursor:pointer}.editor-actions button:hover:not(:disabled){background:#f3f4f6}.editor-actions button:disabled{color:#9ca3af;cursor:not-allowed}.editor-textarea{flex:1;min-height:0;resize:none;border:none;outline:none;padding:12px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:12px;line-height:1.4;color:#111827}.validation-errors{border-top:1px solid #fecaca;background:#fef2f2;color:#991b1b;padding:8px 12px;font-size:12px;max-height:35%;overflow-y:auto}.validation-errors ul{margin:6px 0 0;padding-left:18px}.validation-errors code{background:#fee2e2;padding:0 3px;border-radius:2px;font-size:11px}.err-type{color:#b91c1c;font-size:10px;margin-left:4px}.viewer-pane{overflow-y:auto;padding:16px}.empty-viewer{color:#6b7280;font-size:14px;line-height:1.6;padding:24px}.scene{display:flex;flex-direction:column;gap:10px;min-height:0}.scene-question{padding:12px 14px;background:#eff6ff;border:1px solid #bfdbfe;border-left:4px solid #2563eb;border-radius:6px;font-size:14px;line-height:1.5;color:#1e3a8a;display:flex;gap:10px;align-items:baseline}.scene-question-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#1d4ed8;background:#dbeafe;padding:2px 7px;border-radius:4px;flex:0 0 auto}.scene-question-text{flex:1;font-weight:500}.scene-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:6px 2px;flex-wrap:wrap}.scene-toolbar-left{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.scene-toolbar-right{display:flex;align-items:center;gap:6px}.step-indicator{font-size:12px;color:#374151;font-weight:500}.variant-btn,.nav-btn{padding:5px 12px;border:1px solid #d1d5db;border-radius:4px;background:#fff;font-size:12px;color:#374151;cursor:pointer}.variant-btn:hover:not(:disabled),.nav-btn:hover:not(:disabled){background:#f3f4f6}.variant-btn.active{background:#111827;color:#fafafa;border-color:#111827;font-weight:600}.variant-btn.eliminated{border-color:#fca5a5;color:#b91c1c;background:#fef2f2}.variant-btn.eliminated:hover:not(:disabled){background:#fee2e2}.variant-btn.eliminated.active{background:#dc2626;color:#fff;border-color:#dc2626}.nav-btn:disabled{color:#9ca3af;cursor:not-allowed;background:#f9fafb}.scene-body{display:grid;grid-template-columns:minmax(0,3fr) minmax(220px,1.25fr);gap:12px;min-height:0;flex:1}.scene-viz,.scene-side{display:flex;flex-direction:column;min-width:0}.scene-canvas{background:#fafafa;border:1px solid #e5e7eb;border-radius:6px;overflow:hidden}.clues-list{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:10px 12px;overflow-y:auto;min-height:0}.clues-heading{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#6b7280;padding-bottom:6px;border-bottom:1px solid #e5e7eb;margin-bottom:8px}.clues-list ul{list-style:none;margin:0;padding:0}.clue-item{display:flex;gap:8px;align-items:flex-start;padding:7px 9px;margin:3px 0;border-radius:5px;font-size:12.5px;line-height:1.45;color:#6b7280;border:1px solid transparent}.clue-bullet{flex:0 0 auto;font-weight:700;color:#9ca3af}.clue-text{flex:1}.clue-item.partial{background:#fef3c7;color:#78350f;border-color:#fde68a;font-weight:500}.clue-item.partial .clue-bullet{color:#d97706}.clue-item.used{background:#dcfce7;color:#14532d;border-color:#86efac;font-weight:500}.clue-item.used .clue-bullet{color:#16a34a}.clue-item.current{background:#fef3c7;color:#78350f;border:2px solid #16a34a;padding:6px 8px;font-weight:600;box-shadow:0 0 0 1px #16a34a40}.clue-item.current .clue-bullet{color:#16a34a}.questions-panel{margin-top:10px;background:#fff;border:1px solid #86efac;border-left:4px solid #16a34a;border-radius:6px;padding:10px 12px;display:flex;flex-direction:column;gap:8px}.questions-header{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #dcfce7;padding-bottom:6px}.questions-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#14532d}.questions-nav{display:flex;gap:4px}.questions-nav button{padding:3px 9px;border:1px solid #86efac;border-radius:4px;background:#fff;color:#14532d;font-size:11px;cursor:pointer}.questions-nav button:hover:not(:disabled){background:#dcfce7}.questions-nav button:disabled{color:#9ca3af;border-color:#e5e7eb;cursor:not-allowed}.question-text{margin:0;font-size:13px;line-height:1.45;color:#1f2937;font-weight:500}.options-list{list-style:none;margin:0;padding:0}.option-item{display:flex;gap:6px;padding:4px 6px;font-size:12px;color:#6b7280;border-radius:4px}.option-item.answer{background:#dcfce7;color:#14532d;font-weight:600}.option-letter{flex:0 0 auto;font-weight:700;min-width:18px}.option-label{flex:1}.question-justification{font-size:12px;line-height:1.45;color:#14532d;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:4px;padding:6px 8px}.scene-error{padding:20px;color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:6px}.auth-loading{display:flex;align-items:center;justify-content:center;height:100vh;color:#6b7280;font-size:14px}.auth-root{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px;background:#f5f5f4}.auth-card{width:100%;max-width:360px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:24px;display:flex;flex-direction:column;gap:16px;box-shadow:0 1px 2px #0000000a}.auth-title{margin:0;font-size:18px;color:#111827}.auth-mode-switch{display:flex;gap:4px;border-bottom:1px solid #e5e7eb}.auth-tab{flex:1;background:transparent;border:0;border-bottom:2px solid transparent;padding:8px 0;font-size:13px;color:#6b7280;cursor:pointer}.auth-tab.active{color:#111827;border-bottom-color:#111827;font-weight:600}.auth-form{display:flex;flex-direction:column;gap:12px}.auth-label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:#374151}.auth-label input{font-size:13px;padding:8px 10px;border:1px solid #d1d5db;border-radius:4px;background:#fff}.auth-label input:focus{outline:2px solid #93c5fd;outline-offset:0;border-color:#2563eb}.auth-error{font-size:12px;padding:8px 10px;background:#fef2f2;border:1px solid #fecaca;color:#991b1b;border-radius:4px}.auth-submit{font-size:13px;padding:8px 12px;background:#111827;color:#fafafa;border:0;border-radius:4px;cursor:pointer}.auth-submit:hover:not(:disabled){background:#1f2937}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-hint{margin:0;font-size:11px;color:#6b7280}.history-loading,.history-empty{padding:32px 24px;color:#6b7280;font-size:13px;line-height:1.5}.history-empty strong{display:block;color:#111827;font-size:14px;margin-bottom:6px}.history-empty-hint{color:#6b7280}.history-list{display:flex;flex-direction:column;flex:1;min-height:0}.history-header{display:flex;align-items:baseline;justify-content:space-between;padding:12px 16px 8px;border-bottom:1px solid #e5e7eb}.history-header strong{font-size:13px;color:#111827}.history-count{font-size:12px;color:#6b7280;font-variant-numeric:tabular-nums}.history-list ul{list-style:none;margin:0;padding:0;overflow-y:auto;flex:1}.history-item{border-bottom:1px solid #f3f4f6}.history-row{width:100%;text-align:left;background:transparent;border:0;padding:10px 16px;cursor:pointer;display:flex;flex-direction:column;gap:4px}.history-row:hover:not(:disabled){background:#f9fafb}.history-row:disabled{opacity:.6;cursor:wait}.history-row-top{display:flex;justify-content:space-between;font-size:11px;color:#6b7280}.history-family{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:#e0f2fe;color:#075985;padding:1px 6px;border-radius:4px;font-size:11px}.history-date{font-variant-numeric:tabular-nums}.history-title{font-size:13px;font-weight:600;color:#111827}.history-preview{font-size:12px;color:#4b5563;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.history-loading-badge{font-size:11px;color:#2563eb}.similar-panel{margin:8px 12px 12px;padding:12px;background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;display:flex;flex-direction:column;gap:10px}.similar-panel-header{display:flex;flex-direction:column;gap:2px}.similar-panel-header strong{font-size:13px;color:#075985}.similar-panel-hint{font-size:12px;color:#0c4a6e}.similar-match-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.similar-match{background:#fff;border:1px solid #e0f2fe;border-radius:6px;padding:10px 12px;display:flex;flex-direction:column;gap:6px}.similar-match.near-identical{border-color:#16a34a;background:#f0fdf4}.similar-match-top{display:flex;justify-content:space-between;align-items:center;gap:8px;font-size:11px}.similar-family{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:#e0f2fe;color:#075985;padding:2px 6px;border-radius:4px}.similar-match.near-identical .similar-family{background:#dcfce7;color:#14532d}.similar-score{color:#475569;font-variant-numeric:tabular-nums}.similar-title{font-size:13px;font-weight:600;color:#0f172a}.similar-preview{font-size:12px;color:#475569;line-height:1.4;white-space:pre-wrap}.similar-actions{display:flex;justify-content:flex-end}.similar-actions button{font-size:12px;padding:4px 10px}.similar-panel-footer{display:flex;justify-content:flex-end}.generate-fresh{font-size:12px;padding:6px 14px}@media(max-width:900px){.app-body{grid-template-columns:1fr}}
