:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--text-primary: rgba(255, 255, 255, .87);--text-secondary: rgba(255, 255, 255, .6);--text-tertiary: rgba(255, 255, 255, .4);--surface-primary: #1a1a1a;--surface-secondary: #2a2a2a;--surface-tertiary: #333333;--surface-hover: rgba(255, 255, 255, .05);--border-color: rgba(255, 255, 255, .15);--accent-color: #646cff;--accent-hover: #5458d9;--accent-bg: rgba(100, 108, 255, .1);--danger-color: #ef4444;--error-bg: rgba(239, 68, 68, .1);--error-border: rgba(239, 68, 68, .3);--error-text: #f87171;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff;--text-primary: #213547;--text-secondary: #4a5568;--text-tertiary: #718096;--surface-primary: #ffffff;--surface-secondary: #f7f7f7;--surface-tertiary: #e8e8e8;--surface-hover: rgba(0, 0, 0, .03);--border-color: rgba(0, 0, 0, .12);--accent-color: #535bf2;--accent-hover: #4349d4;--accent-bg: rgba(83, 91, 242, .1);--danger-color: #dc2626;--error-bg: rgba(220, 38, 38, .1);--error-border: rgba(220, 38, 38, .3);--error-text: #dc2626;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1)}a:hover{color:#747bff}button{background-color:#f9f9f9}}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.user-menu{display:flex;align-items:center;gap:1rem;margin-left:auto;padding-right:.5rem}.user-menu__name{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.user-menu__logout{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background:none;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:all .2s ease}.user-menu__logout:hover{background-color:var(--surface-hover);border-color:var(--error-border);color:var(--error-text)}.tabs{display:flex;align-items:center;gap:.5rem;padding:.5rem;background-color:var(--surface-secondary);border-radius:var(--radius-lg);margin-bottom:1.5rem}.tabs__brand{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border:none;border-radius:var(--radius-md);background-color:transparent;cursor:default}.tabs__brand--clickable{cursor:pointer;transition:background-color .2s ease}.tabs__brand--clickable:hover{background-color:var(--surface-hover)}.tabs__brand-logo{width:28px;height:auto}.tabs__brand-name{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.tabs__separator{color:var(--text-tertiary);font-size:.875rem;-webkit-user-select:none;user-select:none}.tabs__breadcrumb{padding:.5rem .75rem;border:none;border-radius:var(--radius-md);background-color:transparent;font-size:1rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.tabs__breadcrumb:hover{color:var(--text-primary);background-color:var(--surface-hover)}.tabs__breadcrumb--active{color:var(--text-primary);cursor:default}.tabs__breadcrumb--active:hover{background-color:transparent}.modal{position:fixed;inset:0;width:100%;max-width:480px;margin:auto;padding:0;border:none;border-radius:var(--radius-lg);background-color:var(--surface-primary);box-shadow:var(--shadow-lg)}.modal::backdrop{background-color:#00000080}.modal__content{display:flex;flex-direction:column}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color)}.modal__title{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-primary)}.modal__close-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;border-radius:var(--radius-sm);background-color:transparent;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.modal__close-button:hover{background-color:var(--surface-hover);color:var(--text-primary)}.modal__body{padding:1.5rem}.project-card{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem 2rem;background-color:var(--surface-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease;min-width:180px}.project-card:hover{background-color:var(--surface-hover);border-color:var(--accent-color);transform:translateY(-2px);box-shadow:var(--shadow-md)}.project-card__icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;background-color:var(--surface-tertiary);border-radius:var(--radius-md);color:var(--accent-color)}.project-card__name{font-size:1rem;font-weight:500;color:var(--text-primary)}.project-card__stats{display:flex;gap:1rem}.project-card__stat{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--text-secondary)}.project-card__stat svg{opacity:.7}.create-project-form{display:flex;flex-direction:column;gap:1.25rem}.create-project-form__field{display:flex;flex-direction:column;gap:.5rem}.create-project-form__label{font-size:.875rem;font-weight:500;color:var(--text-primary)}.create-project-form__required{color:var(--error-color)}.create-project-form__input,.create-project-form__textarea{padding:.625rem .875rem;font-size:.9375rem;font-family:inherit;color:var(--text-primary);background-color:var(--surface-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:border-color .15s ease,box-shadow .15s ease}.create-project-form__input:focus,.create-project-form__textarea:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px var(--accent-color-alpha)}.create-project-form__input::placeholder,.create-project-form__textarea::placeholder{color:var(--text-tertiary)}.create-project-form__input:disabled,.create-project-form__textarea:disabled{opacity:.6;cursor:not-allowed}.create-project-form__textarea{resize:vertical;min-height:80px}.create-project-form__actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:.5rem}.create-project-form__button{padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.create-project-form__button:disabled{opacity:.6;cursor:not-allowed}.create-project-form__button--secondary{color:var(--text-secondary);background-color:transparent;border:1px solid var(--border-color)}.create-project-form__button--secondary:hover:not(:disabled){background-color:var(--surface-hover);color:var(--text-primary)}.create-project-form__button--primary{color:#fff;background-color:var(--accent-color);border:1px solid var(--accent-color)}.create-project-form__button--primary:hover:not(:disabled){background-color:var(--accent-color-hover);border-color:var(--accent-color-hover)}.home-tab{display:flex;justify-content:center;align-items:center;min-height:400px;padding:2rem}.home-tab__content{text-align:center;max-width:800px}.home-tab__title{margin:0 0 .5rem;font-size:2rem;font-weight:600;color:var(--text-primary)}.home-tab__subtitle{margin:0 0 2rem;font-size:1.125rem;color:var(--text-secondary)}.home-tab__projects{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.home-tab__loading{display:flex;flex-direction:column;align-items:center;gap:1rem;color:var(--text-secondary)}.home-tab__spinner{width:32px;height:32px;border:3px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;animation:home-tab-spin .8s linear infinite}@keyframes home-tab-spin{to{transform:rotate(360deg)}}.home-tab__new-project-card{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem 2rem;background-color:transparent;border:2px dashed var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease;min-width:180px}.home-tab__new-project-card:hover{background-color:var(--surface-hover);border-color:var(--accent-color);border-style:solid}.home-tab__new-project-icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;background-color:var(--surface-tertiary);border-radius:var(--radius-md);color:var(--text-secondary);transition:all .2s ease}.home-tab__new-project-card:hover .home-tab__new-project-icon{color:var(--accent-color);background-color:var(--accent-color-alpha)}.home-tab__new-project-text{font-size:1rem;font-weight:500;color:var(--text-secondary);transition:color .2s ease}.home-tab__new-project-card:hover .home-tab__new-project-text{color:var(--text-primary)}.volume-list{display:flex;flex-direction:column;height:100%;background:var(--surface-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color);overflow:hidden}.volume-list__header{padding:16px;border-bottom:1px solid var(--border-color)}.volume-list__title{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.volume-list__form{display:flex;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border-color);background:var(--surface-primary)}.volume-list__input{flex:1;padding:8px 12px;font-size:.875rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--surface-secondary);color:var(--text-primary)}.volume-list__input:focus{outline:none;border-color:var(--accent-color)}.volume-list__input::placeholder{color:var(--text-tertiary)}.volume-list__create-btn{padding:8px 16px;font-size:.875rem;font-weight:500;color:#fff;background:var(--accent-color);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:opacity .15s}.volume-list__create-btn:hover:not(:disabled){opacity:.9}.volume-list__create-btn:disabled{opacity:.5;cursor:not-allowed}.volume-list__items{flex:1;overflow-y:auto;padding:8px}.volume-list__loading,.volume-list__empty{padding:24px 16px;text-align:center;color:var(--text-tertiary);font-size:.875rem}.volume-list__item{display:flex;align-items:center;gap:12px;width:100%;padding:12px;margin-bottom:4px;text-align:left;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s,border-color .15s}.volume-list__item:hover{background:var(--surface-hover)}.volume-list__item--selected{background:var(--surface-primary);border-color:var(--accent-color)}.volume-list__item-icon{flex-shrink:0;color:var(--text-tertiary)}.volume-list__item--selected .volume-list__item-icon{color:var(--accent-color)}.volume-list__item-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.volume-list__item-name{font-size:.875rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.volume-list__item-tags{font-size:.75rem;color:var(--text-tertiary)}.batch-list{margin-top:24px}.batch-list__title{margin:0 0 12px;font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.batch-list__loading,.batch-list__empty{padding:24px;text-align:center;color:var(--text-tertiary);font-size:.875rem;background:var(--surface-secondary);border-radius:var(--radius-sm);border:1px dashed var(--border-color)}.batch-list__items{display:flex;flex-direction:column;gap:8px}.batch-list__item{padding:12px 16px;background:var(--surface-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm)}.batch-list__item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.batch-list__status{font-size:.75rem;font-weight:500;padding:2px 8px;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.03em}.batch-list__status--pending{background:#fef3c7;color:#92400e}.batch-list__status--completed{background:#d1fae5;color:#065f46}.batch-list__status--failed{background:#fee2e2;color:#991b1b}.batch-list__date{font-size:.75rem;color:var(--text-tertiary)}.batch-list__item-details{display:flex;align-items:center;gap:8px}.batch-list__file-count{font-size:.875rem;color:var(--text-secondary)}.dropzone{display:flex;align-items:center;justify-content:center;width:100%;min-height:200px;padding:2rem;border:2px dashed var(--border-color);border-radius:var(--radius-lg);background-color:var(--surface-secondary);cursor:pointer;transition:all .2s ease;box-sizing:border-box}.dropzone:hover{border-color:var(--accent-color);background-color:var(--surface-hover)}.dropzone--dragging{border-color:var(--accent-color);background-color:var(--accent-bg);border-style:solid}.dropzone__input{display:none}.dropzone__content{display:flex;flex-direction:column;align-items:center;text-align:center}.dropzone__icon{color:var(--text-tertiary);margin-bottom:1rem}.dropzone--dragging .dropzone__icon{color:var(--accent-color)}.dropzone__text{margin:0 0 .5rem;font-size:1rem;color:var(--text-secondary)}.dropzone__link{color:var(--accent-color);font-weight:500}.dropzone__hint{margin:0;font-size:.875rem;color:var(--text-tertiary)}.volume-details{display:flex;flex-direction:column;height:100%;padding:24px;background:var(--surface-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color);overflow-y:auto}.volume-details__header{margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border-color)}.volume-details__title-row{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:8px}.volume-details__title-actions{display:flex;align-items:center;gap:12px}.volume-details__name{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.volume-details__image-count{font-size:.875rem;color:var(--text-tertiary)}.volume-details__header-btn{padding:.375rem .875rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--surface-primary);color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.volume-details__header-btn:hover:not(:disabled){background-color:var(--surface-hover);border-color:var(--accent-color)}.volume-details__header-btn:disabled{opacity:.6;cursor:not-allowed}.volume-details__header-btn--transcribe{background-color:var(--accent-color);border-color:var(--accent-color);color:#fff}.volume-details__header-btn--transcribe:hover:not(:disabled){background-color:var(--accent-hover, #4f46e5)}.volume-details__header-btn--retry{background-color:var(--warning-color, #ca8a04);border-color:var(--warning-color, #ca8a04);color:#fff}.volume-details__header-btn--retry:hover:not(:disabled){background-color:#b45309}.volume-details__transcription-warning{margin-top:12px;padding:8px 12px;background-color:var(--warning-bg, #fefce8);border:1px solid var(--warning-color, #ca8a04);border-radius:var(--radius-sm);color:var(--warning-color, #ca8a04);font-size:.8125rem}.volume-details__transcription-status{margin-top:12px;padding:8px 12px;border-radius:var(--radius-sm);font-size:.8125rem}.volume-details__transcription-status--pending,.volume-details__transcription-status--submitted{background-color:var(--warning-bg, #fefce8);border:1px solid var(--warning-color, #ca8a04);color:var(--warning-color, #ca8a04)}.volume-details__transcription-status--processing{background-color:var(--info-bg, #eff6ff);border:1px solid var(--info-color, #2563eb);color:var(--info-color, #2563eb)}.volume-details__transcription-status--completed{background-color:var(--success-bg, #f0fdf4);border:1px solid var(--success-color, #22c55e);color:var(--success-color, #22c55e)}.volume-details__tags{display:flex;flex-wrap:wrap;gap:8px}.volume-details__tag{display:inline-flex;padding:4px 8px;font-size:.75rem;background:var(--surface-tertiary);border-radius:var(--radius-sm)}.volume-details__tag-key{color:var(--text-tertiary);margin-right:4px}.volume-details__tag-value{color:var(--text-secondary)}.volume-details__success{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem;padding:.75rem 1rem;background-color:var(--success-bg, #f0fdf4);border:1px solid var(--success-color, #22c55e);border-radius:var(--radius-md);color:var(--success-color, #22c55e);font-size:.875rem}.volume-details__success-dismiss{display:flex;align-items:center;justify-content:center;padding:.25rem;border:none;background:transparent;color:var(--success-color, #22c55e);cursor:pointer;opacity:.7;transition:opacity .2s ease}.volume-details__success-dismiss:hover{opacity:1}.volume-details__error{margin-bottom:1rem;padding:.75rem 1rem;background-color:var(--danger-bg, #fef2f2);border:1px solid var(--danger-color, #ef4444);border-radius:var(--radius-md);color:var(--danger-color, #ef4444);font-size:.875rem}.volume-details__upload-section{margin-bottom:24px}.volume-details__section-title{margin:0 0 12px;font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.volume-details .dropzone{min-height:120px}.volume-details__pending{display:flex;align-items:center;gap:12px;margin-top:12px;padding:10px 14px;background-color:var(--surface-primary);border:1px solid var(--border-color);border-radius:var(--radius-md)}.volume-details__pending-thumbnails{display:flex;gap:6px;flex-shrink:0}.volume-details__thumbnail{width:40px;height:40px;border-radius:var(--radius-sm);overflow:hidden;background:var(--surface-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-tertiary)}.volume-details__thumbnail img{width:100%;height:100%;object-fit:cover}.volume-details__pending-info{flex:1;min-width:0}.volume-details__pending-count{font-size:.875rem;font-weight:500;color:var(--text-primary)}.volume-details__pending-more{font-weight:400;color:var(--text-tertiary)}.volume-details__upload-btn{padding:.5rem 1.25rem;border:none;border-radius:var(--radius-md);background-color:var(--accent-color);color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background-color .2s ease,opacity .2s ease}.volume-details__upload-btn:hover:not(:disabled){background-color:var(--accent-hover, #4f46e5)}.volume-details__upload-btn:disabled{opacity:.6;cursor:not-allowed}.project-tab{display:grid;grid-template-columns:320px 1fr;gap:24px;height:calc(100vh - 160px);padding:24px;box-sizing:border-box}.project-tab__left,.project-tab__right{min-width:0;height:100%}.project-tab__placeholder{display:flex;align-items:center;justify-content:center;height:100%;background:var(--surface-secondary);border-radius:var(--radius-md);border:1px dashed var(--border-color)}.project-tab__placeholder-content{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:320px;padding:48px 24px}.project-tab__placeholder-icon{color:var(--text-tertiary);margin-bottom:16px}.project-tab__placeholder-title{margin:0 0 8px;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.project-tab__placeholder-text{margin:0;font-size:.875rem;color:var(--text-tertiary);line-height:1.5}@media(max-width:768px){.project-tab{grid-template-columns:1fr;grid-template-rows:auto 1fr;height:auto}.project-tab__left{height:300px}}.volume-tab{display:flex;flex-direction:column;align-items:center;padding:2rem}.volume-tab__title{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.volume-tab__description{margin:0 0 1.5rem;color:var(--text-secondary);text-align:center}.volume-tab__empty{display:flex;flex-direction:column;align-items:center;padding:3rem 2rem;color:var(--text-secondary)}.volume-tab__empty p{margin:0}.volume-tab__empty-hint{margin-top:.5rem!important;font-size:.875rem;color:var(--text-tertiary)}.volume-tab__table-container{width:100%;max-width:900px;overflow-x:auto}.volume-tab__table{width:100%;border-collapse:collapse;font-size:.875rem}.volume-tab__table th,.volume-tab__table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border-color)}.volume-tab__table th{font-weight:600;color:var(--text-secondary);background-color:var(--surface-secondary);white-space:nowrap}.volume-tab__table tbody tr{transition:background-color .15s ease}.volume-tab__table tbody tr:hover{background-color:var(--surface-hover)}.volume-tab__filename{max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary)}.volume-tab__status{display:inline-block;padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;text-transform:capitalize}.volume-tab__status--saved{background-color:var(--success-bg, #f0fdf4);color:var(--success-color, #22c55e)}.volume-tab__status--rejected{background-color:var(--danger-bg, #fef2f2);color:var(--danger-color, #ef4444)}.volume-tab__status--skipped{background-color:var(--warning-bg, #fffbeb);color:var(--warning-color, #f59e0b)}.volume-tab__row--clickable{cursor:pointer}.volume-tab__row--clickable:hover .volume-tab__filename{color:var(--accent-color, #3b82f6)}.volume-tab__actions-header{width:60px;text-align:center}.volume-tab__actions{text-align:center}.volume-tab__download-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;border-radius:var(--radius-sm);background-color:transparent;color:var(--text-secondary);cursor:pointer;transition:background-color .15s ease,color .15s ease}.volume-tab__download-btn:hover{background-color:var(--surface-secondary);color:var(--accent-color, #3b82f6)}.volume-tab__download-btn:active{background-color:var(--surface-tertiary)}@media(max-width:640px){.volume-tab__table-container{margin:0 -1rem;padding:0 1rem}.volume-tab__table th,.volume-tab__table td{padding:.5rem .75rem}.volume-tab__filename{max-width:150px}}.file-tab{display:flex;flex-direction:column;padding:2rem;width:100%;height:100%;overflow:hidden;box-sizing:border-box}.file-tab__header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.file-tab__header-info{flex:1;min-width:0}.file-tab__title{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:var(--text-primary);word-break:break-word}.file-tab__meta{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.875rem}.file-tab__meta-separator{color:var(--text-tertiary)}.file-tab__download-btn{padding:.5rem 1rem;background-color:var(--accent-color);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .15s ease;flex-shrink:0}.file-tab__download-btn:hover{background-color:var(--accent-hover)}.file-tab__content{flex:1;min-height:0;overflow:hidden}.file-tab__layout{display:grid;grid-template-columns:2fr 1fr;gap:2rem;height:100%;min-height:0;overflow:hidden}.file-tab__preview-section,.file-tab__transcription-section{display:flex;flex-direction:column;min-height:0;overflow:hidden}.file-tab__section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-shrink:0}.file-tab__section-title{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.file-tab__preview-container{flex:1;display:flex;align-items:flex-start;justify-content:flex-start;background-color:var(--surface-secondary);border-radius:var(--radius-md);overflow:auto;min-height:0}.file-tab__preview-viewport{cursor:grab}.file-tab__preview-viewport:active{cursor:grabbing}.file-tab__preview-image{max-width:100%;max-height:100%;object-fit:contain;-webkit-user-select:none;user-select:none}.image-controls{display:flex;align-items:center;gap:.5rem;background-color:var(--surface-secondary);border-radius:var(--radius-md);padding:.25rem .5rem}.image-controls__btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:var(--radius-sm);background-color:transparent;color:var(--text-secondary);cursor:pointer;transition:background-color .15s ease,color .15s ease}.image-controls__btn:hover{background-color:var(--surface-hover);color:var(--text-primary)}.image-controls__btn--reset{width:auto;padding:0 .5rem;font-size:.75rem;font-weight:500}.image-controls__scale{min-width:3rem;text-align:center;font-size:.75rem;color:var(--text-secondary);font-variant-numeric:tabular-nums}.file-tab__preview-loading,.file-tab__preview-error,.file-tab__preview-unavailable{display:flex;align-items:center;justify-content:center;color:var(--text-secondary);padding:2rem;text-align:center}.file-tab__preview-error{color:var(--danger-color, #ef4444)}.file-tab__transcription-placeholder,.file-tab__transcription-loading,.file-tab__transcription-error{flex:1;display:flex;align-items:center;justify-content:center;background-color:var(--surface-secondary);border-radius:var(--radius-md);color:var(--text-secondary);padding:2rem;text-align:center;min-height:0}.file-tab__transcription-error{color:var(--danger-color, #ef4444)}.file-tab__transcription-content{flex:1;display:flex;flex-direction:column;background-color:var(--surface-secondary);border-radius:var(--radius-md);overflow:hidden;min-height:0}.file-tab__transcription-text{flex:1;margin:0;padding:1rem;font-family:inherit;font-size:.9375rem;line-height:1.6;color:var(--text-primary);white-space:pre-wrap;word-wrap:break-word;overflow-y:auto}.file-tab__transcription-meta{padding:.75rem 1rem;font-size:.75rem;color:var(--text-tertiary);border-top:1px solid var(--border-color);background-color:var(--surface-tertiary)}.file-tab__pdf-notice,.file-tab__unsupported{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;background-color:var(--surface-secondary);border-radius:var(--radius-md);color:var(--text-secondary);text-align:center}.file-tab__pdf-notice p,.file-tab__unsupported p{margin:.5rem 0}@media(max-width:768px){.file-tab{padding:1rem}.file-tab__header{flex-direction:column}.file-tab__download-btn{width:100%}.file-tab__layout{grid-template-columns:1fr}.file-tab__section-header{flex-wrap:wrap;gap:.5rem}.image-controls{width:100%;justify-content:center}}.auth-form-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:2rem}.auth-form__back{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;margin-bottom:1.5rem;background:none;border:none;color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:color .2s ease}.auth-form__back:hover{color:var(--text-primary)}.auth-form{width:100%;max-width:400px;padding:2rem;background-color:var(--surface-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.auth-form__title{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:var(--text-primary);text-align:center}.auth-form__subtitle{margin:0 0 1.5rem;font-size:.875rem;color:var(--text-secondary);text-align:center}.auth-form__error{padding:.75rem 1rem;margin-bottom:1rem;background-color:var(--error-bg);border:1px solid var(--error-border);border-radius:var(--radius-md);color:var(--error-text);font-size:.875rem}.auth-form__field{margin-bottom:1rem}.auth-form__label{display:block;margin-bottom:.375rem;font-size:.875rem;font-weight:500;color:var(--text-primary)}.auth-form__input{width:100%;padding:.75rem 1rem;font-size:1rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--surface-primary);color:var(--text-primary);transition:border-color .2s ease;box-sizing:border-box}.auth-form__input:focus{outline:none;border-color:var(--accent-color)}.auth-form__input:disabled{opacity:.7;cursor:not-allowed}.auth-form__hint{display:block;margin-top:.25rem;font-size:.75rem;color:var(--text-tertiary)}.auth-form__checkbox-field{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem}.auth-form__checkbox{width:18px;height:18px;accent-color:var(--accent-color)}.auth-form__checkbox-label{font-size:.875rem;color:var(--text-secondary)}.auth-form__submit{width:100%;padding:.875rem 1.5rem;margin-top:.5rem;font-size:1rem;font-weight:500;background-color:var(--accent-color);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color .2s ease;box-sizing:border-box}.auth-form__submit:hover:not(:disabled){background-color:var(--accent-hover)}.auth-form__submit:disabled{opacity:.7;cursor:not-allowed}.auth-form__switch{margin-top:1.5rem;text-align:center;font-size:.875rem;color:var(--text-secondary)}.auth-form__switch-link{background:none;border:none;color:var(--accent-color);font-size:inherit;cursor:pointer;text-decoration:underline}.auth-form__switch-link:hover{color:var(--accent-hover)}.landing-page{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:2rem}.landing-page__content{text-align:center;max-width:400px}.landing-page__logo{width:80px;height:auto;margin-bottom:1.5rem}.landing-page__title{margin:0 0 .5rem;font-size:2.5rem;font-weight:700;color:var(--text-primary)}.landing-page__subtitle{margin:0 0 2rem;font-size:1.125rem;color:var(--text-secondary);line-height:1.5}.landing-page__actions{display:flex;flex-direction:column;gap:.75rem}.landing-page__button{padding:.875rem 1.5rem;font-size:1rem;font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease}.landing-page__button--primary{background-color:var(--accent-color);color:#fff;border:none}.landing-page__button--primary:hover{background-color:var(--accent-hover)}.landing-page__button--secondary{background-color:transparent;color:var(--text-primary);border:1px solid var(--border-color)}.landing-page__button--secondary:hover{background-color:var(--surface-hover);border-color:var(--accent-color)}.app{display:flex;flex-direction:column;margin:0 auto;padding:1rem 2rem 2rem;height:100vh;box-sizing:border-box}.app--loading{display:flex;justify-content:center;align-items:center}.app__loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app__main{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}
