*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;height:100%;overflow:hidden}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:15px;line-height:1.45;color:#1a1a1a;background:#f4f4f5}button,input,select{font:inherit}.annotate-page{height:100%;display:flex;flex-direction:column;overflow:hidden}.annotate-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1.25rem;background:#fff;border-bottom:1px solid #ddd;flex-shrink:0}.annotate-header__left{display:flex;align-items:center;gap:1rem;min-width:0}.annotate-header__left h1{margin:0;font-size:1.1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.back-link{color:#444;text-decoration:none;font-size:.9rem;white-space:nowrap}.back-link:hover{text-decoration:underline}.annotate-user{font-size:.85rem;color:#666}.annotate-progress{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.annotate-index{font-weight:700}.annotate-progress progress{width:180px;height:.75rem;flex-shrink:0;accent-color:#2563eb}.annotate-progress__label{font-size:.85rem;color:#555;white-space:nowrap}.banner{padding:.65rem 1.25rem}.banner--error{background:#fde8e8;color:#9b1c1c}.banner--info{background:#e8f4fd;color:#1e429f}.annotate-layout{flex:1;display:grid;gap:0;min-height:0;overflow:hidden}.annotate-layout--fixed{grid-template-columns:minmax(320px,420px) 1fr}.annotate-layout--resizable{grid-template-columns:420px 6px 1fr}.annotate-resizer{cursor:col-resize;background:#e8e8e8;border-left:1px solid #ddd;border-right:1px solid #ddd;transition:background .15s;touch-action:none}.annotate-resizer:hover,.annotate-resizer:active{background:#c5d4f0}.annotate-left{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:#fff;overflow:hidden;min-height:0;min-width:0}.annotate-layout--fixed .annotate-left{border-right:1px solid #ddd}.annotate-form{padding:1rem 1.25rem;overflow-y:auto;min-height:0}.video-panel{display:flex;flex-direction:column;gap:.5rem;flex-shrink:0}.video-panel iframe{width:100%;aspect-ratio:9 / 16;max-height:min(52vh,620px);border:1px solid #ccc;border-radius:6px;background:#000}.video-panel__link{font-size:.9rem}.video-panel--empty{padding:1rem;border:1px dashed #ccc;border-radius:6px;color:#666}.text-panel{flex:1;min-height:0;padding:.75rem;border:1px solid #e5e5e5;border-radius:6px;background:#fafafa;overflow-y:auto;overflow-wrap:anywhere}.text-panel p{margin:.35rem 0}.text-panel p:first-child{margin-top:0}.text-panel p:last-child{margin-bottom:0}.text-panel b,.text-panel strong{font-weight:600}.text-panel em,.text-panel i{font-style:italic}.text-panel h1,.text-panel h2,.text-panel h3{margin:.5rem 0 .35rem;font-size:1rem;line-height:1.35}.text-panel ul,.text-panel ol{margin:.35rem 0;padding-left:1.25rem}.text-panel mark{border-radius:2px;padding:0 .05em}.annotate-nav{display:flex;gap:.5rem;flex-shrink:0}.annotate-nav button{flex:1;padding:.55rem 1rem;border:1px solid #bbb;border-radius:6px;background:#fff;cursor:pointer}.annotate-nav button:disabled{opacity:.45;cursor:not-allowed}.form-section{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0}.form-section__title{margin:0 0 .75rem;font-size:1.05rem}.form-question{margin-bottom:1rem}.form-question__header{margin-bottom:.4rem}.form-question__text p{margin:0}.form-question__help{margin-top:.35rem;font-size:.78rem;color:#555;line-height:1.45}.form-question__help summary{cursor:pointer;color:#666;font-size:.75rem;-webkit-user-select:none;user-select:none}.form-question__help-body{margin-top:.4rem;padding:.5rem .65rem;background:#f7f7f8;border-radius:4px;border-left:3px solid #d8d8dc;font-size:.78rem}.form-question__help-body p{margin:.35rem 0}.form-question__help-body p:first-child{margin-top:0}.form-question__help-body p:last-child{margin-bottom:0}.form-question__help-body ul,.form-question__help-body ol{margin:.35rem 0;padding-left:1.2rem}.form-question__help-body li{margin:.15rem 0}.form-question__help-body strong{font-weight:600}.form-question__help-body em{font-style:italic}.form-question__help-body code{font-size:.92em;background:#ececee;padding:.05rem .25rem;border-radius:3px}.binary-select,.text-input{width:100%;padding:.45rem .55rem;border:1px solid #bbb;border-radius:4px}.mc-options{display:flex;flex-direction:column;gap:.45rem}.mc-option{display:flex;gap:.5rem;align-items:flex-start;cursor:pointer}.mc-option input{margin-top:.2rem;flex-shrink:0}.mc-option span{flex:1}.unsupported-type{color:#9b1c1c;font-style:italic}.app-loading,.app-error{padding:2rem;text-align:center}.app-error a{color:#1e429f}.auth-page{min-height:100vh;height:100vh;overflow-y:auto;display:flex;align-items:center;justify-content:center;padding:2rem;background:#eef0f3}.auth-card{width:100%;max-width:400px;padding:2rem;background:#fff;border-radius:10px;box-shadow:0 4px 24px #00000014}.auth-card h1{margin:0;text-align:center}.auth-subtitle{margin:.25rem 0 1.5rem;text-align:center;color:#666;font-size:.95rem}.auth-tabs{display:flex;gap:.5rem;margin-bottom:1.25rem}.auth-tabs button{flex:1;padding:.5rem;border:1px solid #ccc;border-radius:6px;background:#f8f8f8;cursor:pointer}.auth-tabs button.active{background:#1a1a1a;color:#fff;border-color:#1a1a1a}.auth-form label{display:block;margin-bottom:.85rem;font-size:.9rem}.auth-form input{display:block;width:100%;margin-top:.3rem;padding:.5rem .6rem;border:1px solid #bbb;border-radius:4px}.auth-error{color:#9b1c1c;font-size:.9rem}.auth-submit{width:100%;margin-top:.5rem;padding:.6rem;border:none;border-radius:6px;background:#1a1a1a;color:#fff;cursor:pointer}.auth-submit:disabled{opacity:.6;cursor:wait}.auth-hint{margin:1rem 0 0;font-size:.85rem;color:#666;text-align:center}.optional{color:#888;font-weight:400}.datasets-page{height:100vh;overflow-y:auto;padding:1.5rem;max-width:900px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}.page-header h1{margin:0}.page-subtitle{margin:.25rem 0 0;color:#666}.page-header__actions{display:flex;gap:.5rem;flex-shrink:0}.page-header__actions button,.upload-card button,.dataset-card__action{padding:.5rem 1rem;border:1px solid #bbb;border-radius:6px;background:#fff;cursor:pointer;text-decoration:none;color:inherit;font:inherit}.btn-muted{color:#666}.upload-card{padding:1.25rem;margin-bottom:1.5rem;background:#fff;border:1px solid #ddd;border-radius:8px}.upload-card h2{margin:0 0 .5rem;font-size:1.1rem}.upload-hint{margin:0 0 1rem;font-size:.9rem;color:#666}.upload-card label{display:block;margin-bottom:.75rem;font-size:.9rem}.upload-card input[type=text],.upload-card textarea{display:block;width:100%;margin-top:.25rem;padding:.45rem .55rem;border:1px solid #bbb;border-radius:4px}.checkbox-label{display:flex!important;align-items:center;gap:.5rem}.empty-state{color:#666;text-align:center;padding:2rem}.dataset-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem}.dataset-card{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;background:#fff;border:1px solid #ddd;border-radius:8px}.dataset-card h2{margin:0 0 .25rem;font-size:1.05rem}.dataset-card p{margin:0}.dataset-meta{margin-top:.35rem!important;font-size:.85rem;color:#666}.dataset-card__action{white-space:nowrap;background:#1a1a1a;color:#fff;border-color:#1a1a1a}.groups-page,.settings-page{height:100vh;overflow-y:auto;padding:1.5rem;max-width:960px;margin:0 auto}.groups-section{margin-bottom:2rem}.groups-section h2{font-size:1.1rem;margin:0 0 .75rem}.group-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem}.group-card{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;background:#fff;border:1px solid #ddd;border-radius:8px}.group-card h3{margin:0 0 .25rem;font-size:1.05rem}.group-card__actions{display:flex;gap:.5rem;align-items:center;flex-shrink:0}.btn-muted-link{font-size:.9rem;color:#555;text-decoration:none}.btn-muted-link:hover{text-decoration:underline}.settings-form{background:#fff;border:1px solid #ddd;border-radius:8px;padding:1.25rem;margin-bottom:2rem}.config-mode-tabs{display:flex;gap:.35rem;margin-bottom:1rem;border-bottom:1px solid #ddd;padding-bottom:.5rem}.config-mode-tab{padding:.4rem .85rem;border:1px solid transparent;border-radius:6px 6px 0 0;background:transparent;cursor:pointer;font-size:.9rem;color:#555}.config-mode-tab:hover{background:#f5f5f5}.config-mode-tab--active{background:#fff;border-color:#ddd;border-bottom-color:#fff;margin-bottom:-1px;color:#1a1a1a;font-weight:600}.config-json-editor{margin-bottom:1rem}.config-json-toolbar{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.config-json-toolbar button{padding:.35rem .75rem;border:1px solid #bbb;border-radius:4px;background:#fafafa;cursor:pointer;font-size:.85rem}.config-json-toolbar button:hover{background:#f0f0f0}.config-json-textarea{display:block;width:100%;min-height:420px;padding:.75rem;border:1px solid #bbb;border-radius:6px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.82rem;line-height:1.45;-moz-tab-size:2;tab-size:2;resize:vertical}.config-json-error{margin:.5rem 0 0;color:#b00020;font-size:.9rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.config-editor label{display:block;margin-bottom:.75rem;font-size:.9rem}.config-editor input[type=text],.config-editor textarea,.config-editor select{display:block;width:100%;margin-top:.25rem;padding:.45rem .55rem;border:1px solid #bbb;border-radius:4px}.config-fieldset{border:1px solid #ddd;border-radius:6px;padding:.75rem 1rem;margin-bottom:1rem}.config-fieldset legend{padding:0 .35rem;font-weight:600}.radio-inline{display:inline-flex!important;align-items:center;gap:.35rem;margin-right:1rem}.config-sections-header{display:flex;justify-content:space-between;align-items:center;margin:1rem 0 .5rem}.config-section{border:1px solid #e0e0e0;border-radius:6px;margin-bottom:.75rem;background:#fafafa}.config-section summary{padding:.65rem .85rem;cursor:pointer;font-weight:600}.config-section-body{padding:0 .85rem .85rem}.config-question{border:1px solid #ddd;border-radius:6px;padding:.75rem;margin:.75rem 0;background:#fff}.config-question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.depends-row{display:flex;gap:.5rem;margin-top:.25rem}.depends-row input{flex:1}.btn-danger{color:#9b1c1c;border-color:#e8b4b4;background:#fff;padding:.25rem .5rem;font-size:.85rem;cursor:pointer}.section-remove{margin-top:.5rem}.invite-section{background:#fff;border:1px solid #ddd;border-radius:8px;padding:1.25rem}.invite-form{display:flex;gap:.5rem;margin-top:.75rem}.invite-form input{flex:1;padding:.45rem .55rem;border:1px solid #bbb;border-radius:4px}.invite-form button{padding:.5rem 1rem;border:1px solid #bbb;border-radius:6px;background:#fff;cursor:pointer}.dependency-editor{margin-bottom:.75rem}.dependency-editor__label{display:block;font-size:.9rem;margin-bottom:.25rem}.dependency-editor__mode{width:100%;margin-bottom:.5rem;padding:.4rem}.dependency-compound{display:flex;flex-direction:column;gap:.5rem}.dependency-not{white-space:nowrap;margin:0}.text-panel--capture{outline:2px solid #1e429f;cursor:text}.text-panel mark{border-radius:2px}.compound-question{display:flex;flex-direction:column;gap:.75rem}.compound-entry{border:1px solid #ddd;border-radius:6px;padding:.75rem;background:#fafafa}.compound-entry__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.compound-field{display:block;margin-bottom:.5rem}.compound-span-row{display:flex;gap:.5rem}.compound-span-row input{flex:1}.span-btn{white-space:nowrap;padding:.35rem .6rem;border:1px solid #bbb;border-radius:4px;background:#fff;cursor:pointer}.span-btn--active{background:#1e429f;color:#fff;border-color:#1e429f}.danger-section{margin-top:2rem;padding:1.25rem;border:1px solid #e8b4b4;border-radius:8px;background:snow}.analysis-page{height:100vh;overflow-y:auto;padding:1.5rem;max-width:960px;margin:0 auto}.analysis-toolbar{display:flex;gap:1rem;align-items:flex-end;margin-bottom:1.5rem}.analysis-toolbar label{display:flex;flex-direction:column;gap:.25rem}.analysis-summary{color:#666}.analysis-question{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #e0e0e0}.dist-chart{display:flex;flex-direction:column;gap:.35rem;margin:.5rem 0 1rem}.dist-row{display:grid;grid-template-columns:1fr 120px 2rem;gap:.5rem;align-items:center;font-size:.85rem}.dist-bar-wrap{background:#eee;height:.75rem;border-radius:3px;overflow:hidden}.dist-bar{height:100%;background:#1a1a1a}.kappa-list{font-size:.9rem}.analysis-user-block{margin-bottom:.75rem}@media(max-width:960px){html,body,#root{overflow:auto}.annotate-page{height:auto;min-height:100%;overflow:visible}.annotate-layout--fixed,.annotate-layout--resizable{grid-template-columns:1fr;overflow:visible}.annotate-resizer{display:none}.annotate-left{overflow:visible;min-height:auto}.text-panel{flex:none;max-height:none;overflow:visible}.annotate-form{overflow:visible}}
