:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#334155;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--header-height: 3.5rem;--toolbar-height: 2.75rem;--sticky-header-height: calc(var(--header-height) + var(--toolbar-height))}html{scroll-behavior:smooth}body{margin:0;min-height:100vh;background-color:#f9fafb;color:#334155}body.transcription-active{overflow:hidden}#root{min-height:100vh}.app{display:flex;flex-direction:column;min-height:100vh}.site-header{position:fixed;top:0;left:0;right:0;z-index:20;background:#fff;box-shadow:0 1px 2px #0000000d}.app-header{background:#fff;padding:1rem;display:flex;justify-content:space-between;align-items:center;height:var(--header-height);box-sizing:border-box;gap:1rem}.header-actions{display:flex;gap:.5rem;align-items:center}.outline-toggle-header{display:flex;align-items:center;gap:.25rem;padding:.375rem .75rem;border:1px solid #e5e7eb;border-radius:6px;background:#fff;color:#4b5563;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.outline-toggle-header:hover{background:#f9fafb;border-color:#d1d5db;color:#1f2937}.outline-toggle-header.active{background:#eff6ff;border-color:#3b82f6;color:#2563eb}.outline-toggle-header svg{width:16px;height:16px;transition:transform .2s ease}.outline-toggle-header.active svg{transform:rotate(180deg)}.btn-text{font-size:.875rem}.file-info{display:flex;align-items:center;gap:1rem;flex:1;min-width:0}.file-name{font-weight:500}.word-count{font-size:.875rem;color:#6b7280;margin-left:1rem;font-weight:400}.file-path-container{display:flex;align-items:center;gap:.5rem;max-width:400px}.file-path{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.875rem;color:#4b5563}.saved-notice{font-size:.75rem;color:#6b7280;animation:pulse 1s ease-in-out infinite}.reload-notice{font-size:.75rem;color:#f59e0b;animation:pulse .8s ease-in-out infinite}.merge-notice{font-size:.75rem;color:#10b981;animation:pulse .8s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:0}}.toolbar{display:flex;gap:.375rem;font-size:.875rem;background:#fff;border-bottom:1px solid #e5e7eb;padding:.375rem;height:var(--toolbar-height);box-sizing:border-box;align-items:center}.btn{border:none;padding:.25rem .75rem;border-radius:4px;background:#f3f4f6;color:#1f2937;cursor:pointer;transition:background-color .2s}.btn:hover{background:#e5e7eb}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover{background:#2563eb}.toolbar-button{border:none;padding:.5rem .75rem;border-radius:6px;background:transparent;color:#1f2937;cursor:pointer;transition:all .2s ease;font-size:1rem;font-weight:500;min-height:2rem;display:inline-flex;align-items:center;justify-content:center}.toolbar-button:hover{background:#f3f4f6;transform:translateY(-1px)}.toolbar-button.active{background:#e0e7ff;color:#4338ca}.toolbar-separator{width:1px;height:1.75rem;background:#e5e7eb;margin:0 .5rem}.width-toggle{display:flex;align-items:center;gap:.375rem}.toolbar-button-text{font-size:.875rem}.content{flex:1;display:flex;overflow:hidden;position:relative;margin-top:var(--sticky-header-height)}.preview{flex:1;display:flex;overflow:auto;justify-content:center;scroll-behavior:smooth;position:relative}.preview.with-outline{margin-right:280px;transition:margin-right .3s cubic-bezier(.4,0,.2,1)}.editor-wrapper{width:100%;max-width:48rem;padding:2rem;box-sizing:border-box;transition:max-width .3s ease-in-out,padding .3s ease-in-out;margin:2rem auto;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;border:1px solid #e5e7eb}.editor-wrapper.full-width{max-width:none;padding:2rem 3rem;margin:2rem}.doc-editor{width:100%;max-width:100%;overflow-x:hidden}.doc-editor .ProseMirror{min-height:calc(100vh - 12rem);max-width:100%;padding-top:1rem}.ProseMirror{outline:none;padding:1rem 0;line-height:1.7;width:100%;max-width:100%;overflow-wrap:break-word;word-wrap:break-word;word-break:break-word}.ProseMirror:focus{outline:none}.prose{color:#334155}.ProseMirror h1,.ProseMirror h2,.ProseMirror h3,.ProseMirror h4,.ProseMirror h5,.ProseMirror h6{margin-top:2rem;margin-bottom:1rem;scroll-margin-top:var(--sticky-header-height)}.ProseMirror h1{font-size:2.5em;font-weight:700;line-height:1.2}.ProseMirror h2{font-size:2em;font-weight:700;line-height:1.3}.ProseMirror h3{font-size:1.5em;font-weight:600;line-height:1.4}.ProseMirror h4{font-size:1.25em;font-weight:600}.ProseMirror h5{font-size:1.1em;font-weight:600}.ProseMirror h6{font-size:1em;font-weight:600}.ProseMirror h1:first-child,.ProseMirror h2:first-child,.ProseMirror h3:first-child{margin-top:0}.ProseMirror h1:target,.ProseMirror h2:target,.ProseMirror h3:target,.ProseMirror h4:target,.ProseMirror h5:target,.ProseMirror h6:target{background-color:#ffff001a;border-radius:4px;padding:.5rem;margin:-.5rem;box-shadow:0 0 0 2px #ffff004d;transition:all .3s ease}.ProseMirror p{margin-top:1rem;margin-bottom:1rem}.ProseMirror p:first-child{margin-top:0}.ProseMirror ul,.ProseMirror ol{margin-top:1rem;margin-bottom:1rem;list-style-position:outside;padding-left:1.75rem}.ProseMirror li{margin-bottom:.25rem}.ProseMirror li>p{margin:0}.ProseMirror ul{list-style-type:disc}.ProseMirror ol{list-style-type:decimal}.ProseMirror blockquote{margin-top:1.5rem;margin-bottom:1.5rem;padding-left:1rem;border-left:4px solid rgb(229,231,235);font-style:normal}.ProseMirror pre{margin-top:1.5rem;margin-bottom:1.5rem;padding:1rem;background-color:#f8fafc;border-radius:.375rem;overflow-x:auto;font-family:Courier New,Courier,monospace;max-width:100%}.ProseMirror pre code{background:none;padding:0;font-size:.9em}.ProseMirror code{background-color:#f8fafc;padding:.125rem .25rem;border-radius:.25rem;font-size:.875em}.ProseMirror table{border-collapse:collapse;margin:1rem 0;width:100%;table-layout:fixed;overflow:visible;display:table;max-width:100%}.editor-wrapper.full-width .ProseMirror table{table-layout:auto;width:100%;min-width:100%}.ProseMirror th,.ProseMirror td{border:1px solid #e5e7eb;padding:.5rem;text-align:left;vertical-align:top;position:relative;min-width:1em}.ProseMirror th{background:#f9fafb;font-weight:600}.ProseMirror .selectedCell:after{z-index:2;position:absolute;content:"";left:0;right:0;top:0;bottom:0;background:#c8c8ff66;pointer-events:none}.ProseMirror .column-resize-handle{position:absolute;right:-2px;top:0;bottom:-2px;width:4px;background-color:#adf;pointer-events:none}.ProseMirror.resize-cursor{cursor:ew-resize;cursor:col-resize}.ProseMirror hr{border:none;border-top:2px solid #e5e7eb;margin:2rem 0}.ProseMirror .link{color:#3b82f6;text-decoration:underline;cursor:pointer;word-break:break-all}.ProseMirror .link:hover{color:#2563eb}.ProseMirror .link:hover{cursor:pointer}.ProseMirror img{max-width:100%;height:auto}.ProseMirror ::selection{background:#b3d4fc}.btn:focus-visible,.toolbar-button:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.outline-sidebar{position:fixed;top:var(--sticky-header-height);right:0;width:280px;height:calc(100vh - var(--sticky-header-height));background:#fff;border-left:1px solid #e5e7eb;z-index:15;display:flex;flex-direction:column;overflow:hidden;box-shadow:-2px 0 4px #0000000d;will-change:transform}.outline-resize-handle{position:absolute;left:0;top:0;bottom:0;width:6px;cursor:col-resize;background:transparent;transition:background .2s ease;z-index:10}.outline-resize-handle:hover{background:#3b82f633}.outline-resize-handle:active,.outline-sidebar.resizing .outline-resize-handle{background:#3b82f666}.outline-sidebar.resizing{-webkit-user-select:none;user-select:none}body.resizing-outline{-webkit-user-select:none;user-select:none;cursor:col-resize}.outline-header-bar{padding:.75rem 1rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center;background:#f9fafb;flex-shrink:0}.outline-title{margin:0;font-size:.875rem;font-weight:600;color:#1f2937;text-transform:uppercase;letter-spacing:.05em}.outline-close{border:none;background:none;font-size:1.5rem;line-height:1;color:#6b7280;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.outline-close:hover{background:#f3f4f6;color:#1f2937}.outline-tree{padding:0 .5rem}.outline-item{margin-bottom:2px}.outline-header{display:flex;align-items:center;padding:.375rem .5rem;cursor:pointer;transition:all .2s ease;border-radius:6px;position:relative;font-size:.875rem;color:#4b5563}.outline-header:hover{background:#f3f4f6;color:#1f2937}.outline-header:active{background:#e5e7eb}.outline-header.active{background:#eff6ff;color:#2563eb}.outline-header.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:#3b82f6;border-radius:0 2px 2px 0}.outline-toggle{background:none;border:none;padding:0;margin:0;margin-right:.25rem;width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#9ca3af;cursor:pointer;transition:all .2s ease;border-radius:4px}.outline-toggle:hover{background:#e5e7eb;color:#6b7280}.outline-toggle svg{transition:transform .2s ease}.outline-spacer{width:20px;height:20px;margin-right:.25rem;flex-shrink:0}.outline-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.4}.outline-children{margin-left:1rem;padding-left:.5rem;position:relative}.outline-children:before{content:"";position:absolute;left:0;top:0;bottom:0;width:1px;background:#e5e7eb}.outline-header-1 .outline-text{font-size:.9375rem;font-weight:600;color:#1f2937}.outline-header-2 .outline-text{font-size:.875rem;font-weight:500}.outline-header-3 .outline-text{font-size:.8125rem;font-weight:400}.outline-header-4 .outline-text,.outline-header-5 .outline-text,.outline-header-6 .outline-text{font-size:.75rem;font-weight:400;color:#6b7280}.outline-empty{padding:2rem 1rem;text-align:center;color:#9ca3af;font-size:.875rem;line-height:1.5}.preview.with-outline{transition:margin-right .3s cubic-bezier(.4,0,.2,1)}.preview:not(.with-outline){margin-right:0;transition:margin-right .3s cubic-bezier(.4,0,.2,1)}@media (max-width: 768px){.outline-sidebar{width:100%;max-width:320px;box-shadow:-4px 0 8px #0000001a;position:fixed;top:var(--sticky-header-height);height:calc(100vh - var(--sticky-header-height))}.preview.with-outline{margin-right:0}.outline-toggle-header .btn-text{display:none}.outline-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:14;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.outline-overlay.visible{opacity:1;visibility:visible}.file-info{flex-direction:column;align-items:flex-start;gap:.25rem}.word-count{margin-left:0;font-size:.75rem}}.outline-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:.5rem 0;scrollbar-width:thin;scrollbar-color:#e5e7eb transparent;scroll-behavior:smooth}.outline-content::-webkit-scrollbar{width:6px}.outline-content::-webkit-scrollbar-track{background:transparent}.outline-content::-webkit-scrollbar-thumb{background:#e5e7eb;border-radius:3px}.outline-content::-webkit-scrollbar-thumb:hover{background:#d1d5db}.editor-source-fullscreen{width:100%;min-height:calc(100vh - 12rem);font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:.875rem;line-height:1.5;padding:0;border:none;outline:none;resize:none;color:#1e293b;background:transparent;box-sizing:border-box;transition:all .2s ease}.editor-source-fullscreen:focus{outline:none}.editor-wrapper:has(.editor-source-fullscreen:focus){box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border-color:#d1d5db;transition:all .2s ease}.editor-source-fullscreen::placeholder{color:#9ca3af;font-style:italic}.editor-wrapper:has(.ProseMirror:focus){box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border-color:#d1d5db;transition:all .2s ease}.transcription-split-view{display:flex;flex-direction:row;width:100%;height:calc(100vh - var(--sticky-header-height));overflow:hidden;background:#f9fafb;position:relative;align-items:stretch;isolation:isolate;contain:layout size style}.transcription-image-panel{display:flex;align-items:center;justify-content:center;background:#1f2937;overflow:hidden;position:relative;min-width:100px;max-width:85%;height:100%;flex-shrink:0;flex-grow:0;transition:width .15s ease-out;isolation:isolate;overscroll-behavior:contain}.transcription-split-view.resizing .transcription-image-panel{transition:none}.transcription-divider{width:8px;min-width:8px;max-width:8px;background:linear-gradient(to right,transparent 2px,#e5e7eb 2px,#e5e7eb 6px,transparent 6px);cursor:col-resize;position:relative;flex-shrink:0;flex-grow:0;transition:background .2s ease}.transcription-divider:hover{background:linear-gradient(to right,transparent 2px,#9ca3af 2px,#9ca3af 6px,transparent 6px)}.transcription-divider:before{content:"";position:absolute;top:0;bottom:0;left:-8px;right:-8px;z-index:1}.transcription-divider:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:2px;height:40px;background:repeating-linear-gradient(to bottom,#9ca3af 0,#9ca3af 2px,transparent 2px,transparent 6px);border-radius:1px;opacity:0;transition:opacity .2s ease;pointer-events:none}.transcription-divider:hover:after{opacity:.5}.transcription-split-view.resizing,body.resizing-transcription{-webkit-user-select:none;user-select:none;cursor:col-resize}.transcription-split-view.resizing *{cursor:col-resize!important}.transcription-divider.active{background:linear-gradient(to right,transparent 2px,#3b82f6 2px,#3b82f6 6px,transparent 6px)}.transcription-divider.active:after{opacity:1;background:repeating-linear-gradient(to bottom,#3b82f6 0,#3b82f6 2px,transparent 2px,transparent 6px)}.transcription-editor-panel{overflow:hidden;display:flex;justify-content:center;background:#f9fafb;min-width:100px;max-width:85%;height:100%;flex-shrink:0;flex-grow:0;transition:width .15s ease-out;isolation:isolate;position:relative;contain:layout style}.transcription-split-view.resizing .transcription-editor-panel{transition:none}.image-viewer-container{display:flex;align-items:center;justify-content:center;width:100%;height:100%;padding:2rem;overflow:hidden;position:relative}.transcription-image{max-width:100%;max-height:100%;object-fit:contain;display:block}.image-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.placeholder-content{text-align:center;color:#9ca3af}.placeholder-content p{margin-bottom:1rem;font-size:1.125rem}.image-drop-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;border:3px dashed;pointer-events:none;background:#1e64e61f;border-color:#3b82f6;color:#1e3a8a;font-size:1.25rem;font-weight:600}.image-drop-overlay.invalid{background:#e632321f;border-color:#ef4444;color:#7f1d1d}.btn.active{background:#3b82f6;color:#fff}.transcription-editor-panel .editor-wrapper{max-width:100%;margin:0;padding:2rem;box-sizing:border-box;background:transparent;box-shadow:none;border:none;border-radius:0;height:100%;overflow:auto;overscroll-behavior:contain}.transcription-editor-panel .editor-wrapper.full-width{max-width:100%;padding:2rem}.transcription-editor-panel .doc-editor{max-width:100%;word-wrap:break-word;overflow-wrap:break-word;height:auto;min-height:100%}.transcription-editor-panel .doc-editor .ProseMirror{min-height:auto;height:auto}.transcription-editor-panel .editor-source-fullscreen{min-height:100%;height:auto}.transcription-image-panel::-webkit-scrollbar,.transcription-editor-panel::-webkit-scrollbar,.transcription-editor-panel .editor-wrapper::-webkit-scrollbar{width:8px;height:8px}.transcription-image-panel::-webkit-scrollbar-track,.transcription-editor-panel::-webkit-scrollbar-track,.transcription-editor-panel .editor-wrapper::-webkit-scrollbar-track{background:transparent}.transcription-image-panel::-webkit-scrollbar-thumb{background:#4b5563;border-radius:4px}.transcription-editor-panel::-webkit-scrollbar-thumb,.transcription-editor-panel .editor-wrapper::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.transcription-image-panel::-webkit-scrollbar-thumb:hover{background:#6b7280}.transcription-editor-panel::-webkit-scrollbar-thumb:hover,.transcription-editor-panel .editor-wrapper::-webkit-scrollbar-thumb:hover{background:#94a3b8}.transcription-editor-panel.with-outline{margin-right:280px;transition:margin-right .3s cubic-bezier(.4,0,.2,1)}.image-controls{position:absolute;top:1rem;left:50%;transform:translate(-50%);display:flex;gap:.5rem;background:#1f2937e6;padding:.5rem;border-radius:8px;z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.zoom-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid #4b5563;background:#374151;color:#e5e7eb;border-radius:6px;cursor:pointer;transition:all .2s ease;font-size:.875rem;font-weight:500}.zoom-btn:hover{background:#4b5563;color:#fff;transform:translateY(-1px)}.zoom-btn:active{transform:translateY(0)}.zoom-level{display:flex;align-items:center;padding:0 .75rem;color:#9ca3af;font-size:.875rem;font-weight:500;min-width:60px;justify-content:center}.zoom-step{display:inline-flex;align-items:center;gap:.25rem;background:#1f2937;border:1px solid #374151;border-radius:6px;padding:.25rem .5rem}.zoom-step-label{color:#9ca3af;font-size:.75rem;font-weight:500}.zoom-input{width:56px;height:28px;padding:0 .25rem;font-size:.875rem;color:#e5e7eb;background:#111827;border:1px solid #374151;border-radius:4px;outline:none}.zoom-input:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f64d}.zoom-step-suffix{color:#9ca3af;font-size:.75rem}.image-viewer-container{position:relative;width:100%;height:100%;overflow:hidden;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;overscroll-behavior:contain}.transcription-image{max-width:100%;max-height:100%;object-fit:contain;display:block;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;pointer-events:all;will-change:transform}.image-viewer-container.dragging{cursor:grabbing!important}.transcription-image-panel{position:relative;-webkit-user-select:none;user-select:none}@media (max-width: 768px){.image-controls{top:.5rem;gap:.25rem;padding:.375rem}.zoom-btn{width:32px;height:32px}}@media (pointer: coarse){.zoom-btn{width:44px;height:44px}}
