: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-color-hover: #5458d9;--accent-color-alpha: rgba(100, 108, 255, .15);--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;--baptism-color: #5b8dd9;--baptism-bg: rgba(91, 141, 217, .12);--baptism-border: rgba(91, 141, 217, .35);--birth-color: #d4728c;--birth-bg: rgba(212, 114, 140, .12);--birth-border: rgba(212, 114, 140, .35);--marriage-color: #c9a84c;--marriage-bg: rgba(201, 168, 76, .12);--marriage-border: rgba(201, 168, 76, .35);--death-color: #8b8b8b;--death-bg: rgba(139, 139, 139, .12);--death-border: rgba(139, 139, 139, .35);--census-color: #5ba87a;--census-bg: rgba(91, 168, 122, .12);--census-border: rgba(91, 168, 122, .35);--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-color-hover: #4349d4;--accent-color-alpha: rgba(83, 91, 242, .15);--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;--baptism-bg: rgba(91, 141, 217, .1);--baptism-border: rgba(91, 141, 217, .4);--birth-bg: rgba(212, 114, 140, .1);--birth-border: rgba(212, 114, 140, .4);--marriage-bg: rgba(201, 168, 76, .1);--marriage-border: rgba(201, 168, 76, .4);--death-bg: rgba(139, 139, 139, .1);--death-border: rgba(139, 139, 139, .4);--census-bg: rgba(91, 168, 122, .1);--census-border: rgba(91, 168, 122, .4);--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}.language-selector{position:relative}.language-selector__trigger{display:flex;align-items:center;gap:4px;padding:4px 6px;background:none;border:1px solid transparent;border-radius:var(--radius-sm, 4px);cursor:pointer;color:var(--text-secondary);transition:background-color .15s,border-color .15s}.language-selector__trigger:hover{background-color:var(--surface-hover);border-color:var(--border-color)}.language-selector__chevron{opacity:.6}.language-selector__dropdown{position:absolute;top:calc(100% + 4px);right:0;z-index:100;min-width:140px;background-color:var(--surface-primary, #fff);border:1px solid var(--border-color);border-radius:var(--radius-md, 6px);box-shadow:var(--shadow-md, 0 4px 12px rgba(0, 0, 0, .12));padding:4px}.language-selector__option{display:flex;align-items:center;gap:8px;width:100%;padding:6px 8px;background:none;border:none;border-radius:var(--radius-sm, 4px);cursor:pointer;font-size:.8125rem;color:var(--text-primary);transition:background-color .1s}.language-selector__option:hover{background-color:var(--surface-hover)}.language-selector__option--active{font-weight:600;background-color:var(--surface-secondary)}.landing-page>.language-selector{position:absolute;top:1rem;right:1rem}.search-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--surface-primary);border:1px solid var(--border-color);border-radius:var(--radius-md)}.search-bar__icon{flex-shrink:0;color:var(--text-tertiary)}.search-bar__input{flex:1;min-width:0;border:none;outline:none;background:transparent;font-size:.875rem;color:var(--text-primary);font-family:inherit}.search-bar__input::placeholder{color:var(--text-tertiary)}.search-bar__clear{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-tertiary);cursor:pointer}.search-bar__clear:hover{background:var(--surface-secondary);color:var(--text-primary)}.search-bar__submit{flex-shrink:0;padding:6px 16px;border:none;border-radius:var(--radius-sm);background:var(--accent-color);color:#fff;font-size:.8125rem;font-weight:500;cursor:pointer;font-family:inherit}.search-bar__submit:hover:not(:disabled){opacity:.9}.search-bar__submit:disabled{opacity:.5;cursor:not-allowed}.search-bar--disabled{opacity:.5}.avatar-dropdown{position:relative}.avatar-dropdown__trigger{display:flex;align-items:center;gap:.5rem;padding:.25rem;background:none;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color .15s}.avatar-dropdown__trigger:hover{background-color:var(--surface-hover)}.avatar-dropdown__circle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background-color:var(--accent-color);color:#fff;font-size:.75rem;font-weight:600;line-height:1;-webkit-user-select:none;user-select:none}.avatar-dropdown__name{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.avatar-dropdown__menu{position:absolute;top:calc(100% + 4px);right:0;z-index:100;min-width:180px;background-color:var(--surface-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md, 0 4px 12px rgba(0, 0, 0, .12));padding:.5rem}.avatar-dropdown__credits{display:flex;align-items:center;gap:.5rem;padding:.5rem;font-size:.8125rem;font-weight:500;color:var(--text-secondary)}.avatar-dropdown__credits svg{flex-shrink:0;color:var(--text-tertiary)}.avatar-dropdown__languages{display:flex;gap:.25rem;padding:.375rem .5rem}.avatar-dropdown__lang-btn{display:flex;align-items:center;justify-content:center;padding:.25rem .375rem;background:none;border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:background-color .15s,border-color .15s}.avatar-dropdown__lang-btn:hover{background-color:var(--surface-hover);border-color:var(--border-color)}.avatar-dropdown__lang-btn--active{border-color:var(--accent-color);background-color:var(--surface-secondary)}.avatar-dropdown__divider{height:1px;background-color:var(--border-color);margin:.25rem 0}.avatar-dropdown__logout{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.8125rem;font-family:inherit;cursor:pointer;transition:all .15s}.avatar-dropdown__logout:hover{background-color:var(--surface-hover);color:var(--error-text)}.top-header{display:flex;align-items:center;gap:1rem;padding:.75rem 2rem;background:var(--surface-secondary);position:sticky;top:0;z-index:50}.top-header__brand{display:flex;align-items:center;gap:.5rem;padding:.25rem .5rem;background:none;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color .15s;flex-shrink:0}.top-header__brand:hover{background-color:var(--surface-hover)}.top-header__logo{width:28px;height:auto}.top-header__brand-name{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.top-header__search{flex:1;min-width:0}.top-header>.avatar-dropdown{margin-left:auto;flex-shrink:0}.breadcrumbs{display:flex;align-items:center;gap:.375rem;padding:.375rem 2rem;font-size:.875rem;min-height:1.5rem}.breadcrumbs__segment{display:flex;align-items:center;gap:.25rem}.breadcrumbs__icon{flex-shrink:0;color:var(--text-tertiary)}.breadcrumbs__label{color:var(--text-tertiary);font-weight:400}.breadcrumbs__value{color:var(--text-primary);font-weight:500}.breadcrumbs__description{color:var(--text-tertiary);font-weight:400;margin-left:.25rem}.breadcrumbs__link{background:none;border:none;padding:.125rem .375rem;border-radius:var(--radius-sm);color:var(--accent-color);font-weight:500;font-size:inherit;font-family:inherit;cursor:pointer;transition:background-color .15s}.breadcrumbs__link:hover{background-color:var(--surface-hover);text-decoration:underline}.breadcrumbs__separator{flex-shrink:0;color:var(--text-tertiary)}.breadcrumbs__portal{display:inline-flex;align-items:center;gap:.375rem}.breadcrumbs__rename-btn{background:none;border:none;padding:.125rem;margin-left:.25rem;cursor:pointer;color:var(--text-tertiary);display:inline-flex;align-items:center;border-radius:var(--radius-sm);transition:color .15s,background-color .15s}.breadcrumbs__rename-btn:hover{color:var(--text-primary);background-color:var(--surface-hover)}.breadcrumbs__rename-input{padding:.25rem .5rem;font-size:inherit;font-family:inherit;font-weight:500;color:var(--text-primary);background:var(--surface-primary);border:1px solid var(--accent-color);border-radius:var(--radius-sm);outline:none;box-shadow:0 0 0 3px var(--accent-color-alpha);min-width:250px;max-width:500px}.breadcrumbs__navigation-portal{display:inline-flex;align-items:center}.breadcrumbs__actions-portal{margin-left:auto;display:flex;align-items:center;gap:.375rem}.breadcrumbs .nav-controls{gap:.25rem}.breadcrumbs .nav-controls__btn{width:28px;height:28px}.breadcrumbs .nav-controls__btn svg{width:16px;height:16px}.breadcrumbs .nav-controls__position{font-size:.8125rem;gap:.25rem}.breadcrumbs .nav-controls__position-input{font-size:.8125rem;padding:.125rem .25rem}.breadcrumbs__action-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background-color:transparent;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.breadcrumbs__action-btn:hover{background-color:var(--surface-hover);color:var(--text-primary);border-color:var(--text-tertiary)}.breadcrumbs__action-btn--accent{color:var(--accent-color);border-color:color-mix(in srgb,var(--accent-color) 40%,var(--border-color))}.breadcrumbs__action-btn--accent:hover{color:var(--accent-color);border-color:var(--accent-color);background-color:color-mix(in srgb,var(--accent-color) 10%,transparent)}.breadcrumbs__action-btn--danger{color:var(--text-tertiary)}.breadcrumbs__action-btn--danger:hover{color:var(--danger-color);border-color:var(--danger-color);background-color:#ef444414}.breadcrumbs__action-btn--active{color:var(--accent-color);border-color:var(--accent-color);background-color:color-mix(in srgb,var(--accent-color) 10%,var(--surface-tertiary))}.breadcrumbs__action-btn--active:hover{background-color:color-mix(in srgb,var(--accent-color) 18%,var(--surface-tertiary));color:var(--accent-color);border-color:var(--accent-color)}.verification-banner{display:flex;align-items:center;gap:.75rem;padding:.5rem 2rem;background:var(--accent-color);color:#fff;font-size:.875rem;flex-wrap:wrap}.verification-banner__message{flex:1;min-width:200px}.verification-banner__actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.verification-banner__btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.4);padding:.25rem .75rem;border-radius:4px;cursor:pointer;font-size:.8125rem;white-space:nowrap}.verification-banner__btn:hover:not(:disabled){background:#ffffff4d}.verification-banner__btn:disabled{opacity:.6;cursor:not-allowed}.verification-banner__input{width:7rem;padding:.25rem .5rem;border:1px solid rgba(255,255,255,.4);border-radius:4px;background:#ffffff26;color:#fff;font-size:.875rem;text-align:center;letter-spacing:.15em}.verification-banner__input::placeholder{color:#fff9;letter-spacing:normal}.verification-banner__input:focus{outline:none;border-color:#fff;background:#ffffff40}.verification-banner__feedback{font-size:.8125rem;opacity:.9}.verification-banner__error{font-size:.8125rem;color:#ffd4d4}.app{display:flex;flex-direction:column;margin:0 auto;padding:0;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}.app__main{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.auth-form-container{width:100%}.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:480px;padding:2rem;background-color:var(--surface-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color);text-align:left}.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__name-row{display:flex;gap:1rem}.auth-form__name-row .auth-form__field{flex:1;min-width:0}.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__tos-field{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:1rem}.auth-form__tos-field .auth-form__checkbox{margin-top:2px;flex-shrink:0}.auth-form__tos-label{font-size:.8125rem;color:var(--text-secondary);line-height:1.4}.auth-form__tos-link{color:var(--accent-color);text-decoration:underline;cursor:pointer}.auth-form__tos-link:hover{color:var(--accent-hover)}.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)}.auth-form__forgot-link{display:block;text-align:right;margin-bottom:1rem;background:none;border:none;color:var(--text-secondary);font-size:.8125rem;cursor:pointer;text-decoration:none;padding:0}.auth-form__forgot-link:hover{color:var(--accent-color);text-decoration:underline}.auth-form__success{padding:.75rem 1rem;margin-bottom:1rem;background-color:var(--success-bg, rgba(34, 197, 94, .1));border:1px solid var(--success-border, rgba(34, 197, 94, .3));border-radius:var(--radius-md);color:var(--success-text, #16a34a);font-size:.875rem}.landing-page{position:relative;display:flex;justify-content:center;align-items:center;min-height:100vh;padding:2rem}.landing-page__content{text-align:center;max-width:480px}.landing-page__header{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:1.5rem}.landing-page__logo{width:52px;height:auto}.landing-page__title{margin:0;font-size:2rem;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 .language-selector{justify-content:center;margin-bottom:1.5rem}.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)}.modal{position:fixed;inset:0;width:100%;max-width:560px;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}.confirm-dialog{display:flex;flex-direction:column;gap:1rem}.confirm-dialog__message{margin:0;font-size:.9375rem;color:var(--text-primary);line-height:1.5}.confirm-dialog__cascade-warning{margin:0;padding:.75rem;font-size:.8125rem;color:var(--danger-color);background-color:#ef444414;border-radius:var(--radius-md);line-height:1.5}.confirm-dialog__actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:.5rem}.confirm-dialog__button{padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.confirm-dialog__button:disabled{opacity:.6;cursor:not-allowed}.confirm-dialog__button--cancel{color:var(--text-secondary);background-color:transparent;border:1px solid var(--border-color)}.confirm-dialog__button--cancel:hover:not(:disabled){background-color:var(--surface-hover);color:var(--text-primary)}.confirm-dialog__button--danger{color:#fff;background-color:var(--danger-color);border:1px solid var(--danger-color)}.confirm-dialog__button--danger:hover:not(:disabled){filter:brightness(.9)}.archive-card{position:relative;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}.archive-card:hover{background-color:var(--surface-hover);border-color:var(--accent-color);transform:translateY(-2px);box-shadow:var(--shadow-md)}.archive-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)}.archive-card__name{font-size:1rem;font-weight:500;color:var(--text-primary)}.archive-card__stats{display:flex;gap:1rem}.archive-card__stat{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--text-secondary)}.archive-card__stat svg{opacity:.7}.archive-card__actions{position:absolute;top:.5rem;right:.5rem;display:flex;gap:.25rem}.archive-card__action-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:var(--radius-sm);background-color:var(--surface-tertiary);color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.archive-card__action-btn:hover{background-color:var(--surface-hover);color:var(--text-primary)}.create-archive-form{display:flex;flex-direction:column;gap:1.25rem}.create-archive-form__field{display:flex;flex-direction:column;gap:.5rem}.create-archive-form__label{font-size:.875rem;font-weight:500;color:var(--text-primary)}.create-archive-form__required{color:var(--error-color)}.create-archive-form__input,.create-archive-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-archive-form__input:focus,.create-archive-form__textarea:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px var(--accent-color-alpha)}.create-archive-form__input::placeholder,.create-archive-form__textarea::placeholder{color:var(--text-tertiary)}.create-archive-form__input:disabled,.create-archive-form__textarea:disabled{opacity:.6;cursor:not-allowed}.create-archive-form__textarea{resize:vertical;min-height:80px}.create-archive-form__actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:.5rem}.create-archive-form__button{padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.create-archive-form__button:disabled{opacity:.6;cursor:not-allowed}.create-archive-form__button--secondary{color:var(--text-secondary);background-color:transparent;border:1px solid var(--border-color)}.create-archive-form__button--secondary:hover:not(:disabled){background-color:var(--surface-hover);color:var(--text-primary)}.create-archive-form__button--primary{color:#fff;background-color:var(--accent-color);border:1px solid var(--accent-color)}.create-archive-form__button--primary:hover:not(:disabled){background-color:var(--accent-color-hover);border-color:var(--accent-color-hover)}.create-archive-form__actions--with-delete{justify-content:space-between}.create-archive-form__actions-right{display:flex;gap:.75rem}.create-archive-form__button--danger{color:var(--danger-color, #ef4444);background-color:transparent;border:1px solid var(--danger-color, #ef4444)}.create-archive-form__button--danger:hover:not(:disabled){background-color:#ef444414}.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__archives{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-archive-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-archive-card:hover{background-color:var(--surface-hover);border-color:var(--accent-color);border-style:solid}.home-tab__new-archive-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-archive-card:hover .home-tab__new-archive-icon{color:var(--accent-color);background-color:var(--accent-color-alpha)}.home-tab__new-archive-text{font-size:1rem;font-weight:500;color:var(--text-secondary);transition:color .2s ease}.home-tab__new-archive-card:hover .home-tab__new-archive-text{color:var(--text-primary)}.create-volume-form{display:flex;flex-direction:column;gap:1.25rem}.create-volume-form__field{display:flex;flex-direction:column;gap:.5rem}.create-volume-form__label{font-size:.875rem;font-weight:500;color:var(--text-primary)}.create-volume-form__required{color:var(--error-color)}.create-volume-form__input,.create-volume-form__select{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-volume-form__input:focus,.create-volume-form__select:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px var(--accent-color-alpha)}.create-volume-form__input::placeholder{color:var(--text-tertiary)}.create-volume-form__input:disabled,.create-volume-form__select:disabled{opacity:.6;cursor:not-allowed}.create-volume-form__half-row{display:flex;gap:.75rem}.create-volume-form__half-row>*{flex:1 1 0;min-width:0}.create-volume-form__date-row{display:flex;gap:.375rem}.create-volume-form__input--year,.create-volume-form__select--month,.create-volume-form__select--day{flex:1 1 0;min-width:0;padding-left:.5rem;padding-right:.25rem}.create-volume-form__date-group{display:flex;flex-direction:column;gap:.5rem;min-width:0}.create-volume-form__location-row,.create-volume-form__location-field{display:flex;flex-direction:column;gap:.5rem}.create-volume-form__sublabel{font-size:.75rem;color:var(--text-secondary)}.create-volume-form__type-header{display:flex;align-items:center;gap:.5rem}.create-volume-form__type-tip{position:relative;display:inline-flex;align-items:center;gap:.25rem;cursor:help}.create-volume-form__type-tip-icon{color:#e6a817;flex-shrink:0}.create-volume-form__type-tip-text{font-size:.75rem;font-weight:400;font-style:italic;color:var(--text-tertiary)}.create-volume-form__type-tip:after{content:attr(data-tip);position:absolute;left:0;top:calc(100% + 6px);width:300px;padding:.5rem .75rem;font-size:.8125rem;font-weight:400;font-style:normal;line-height:1.4;color:var(--text-primary);background-color:var(--surface-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 4px 12px #00000026;white-space:normal;pointer-events:none;opacity:0;transition:opacity .15s ease;z-index:10}.create-volume-form__type-tip:hover:after{opacity:1}.create-volume-form__custom-toggle{display:flex;align-items:center;gap:.375rem;margin-left:auto}.create-volume-form__custom-toggle input[type=checkbox]{margin:0;cursor:pointer}.create-volume-form__custom-toggle label{font-size:.8125rem;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.create-volume-form__actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:.5rem}.create-volume-form__button{padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.create-volume-form__button:disabled{opacity:.6;cursor:not-allowed}.create-volume-form__button--secondary{color:var(--text-secondary);background-color:transparent;border:1px solid var(--border-color)}.create-volume-form__button--secondary:hover:not(:disabled){background-color:var(--surface-hover);color:var(--text-primary)}.create-volume-form__button--primary{color:#fff;background-color:var(--accent-color);border:1px solid var(--accent-color)}.create-volume-form__button--primary:hover:not(:disabled){background-color:var(--accent-color-hover);border-color:var(--accent-color-hover)}.create-volume-form__actions--with-delete{justify-content:space-between}.create-volume-form__actions-right{display:flex;gap:.75rem}.create-volume-form__button--danger{color:var(--danger-color, #ef4444);background-color:transparent;border:1px solid var(--danger-color, #ef4444)}.create-volume-form__button--danger:hover:not(:disabled){background-color:#ef444414}.volume-list{display:flex;flex-direction:column;height:100%;max-height:100%;min-height:0;background:var(--surface-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color);overflow:hidden;box-sizing:border-box}.volume-list__header{display:flex;align-items:center;gap:8px;padding:8px;border-bottom:1px solid var(--border-color)}.volume-list__filter{flex:1;min-width:0;padding:6px 10px;font-size:.8125rem;font-family:inherit;color:var(--text-primary);background:var(--surface-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);outline:none;transition:border-color .15s ease}.volume-list__filter:focus{border-color:var(--accent-color)}.volume-list__filter::placeholder{color:var(--text-tertiary)}.volume-list__new-btn{padding:6px 14px;font-size:.8125rem;font-weight:500;color:#fff;background:var(--accent-color);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background-color .15s;white-space:nowrap}.volume-list__new-btn:hover{background-color:var(--accent-color-hover)}.volume-list__items{flex:1;min-height:0;min-width:0;overflow-y:auto;overflow-x:hidden;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:8px;width:100%;padding:8px 10px;margin-bottom:2px;text-align:left;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;color:inherit;font-family:inherit;transition:background .15s,border-color .15s}.volume-list__item:hover{background:var(--surface-hover)}.volume-list__item--selected{background:var(--accent-color);border-color:var(--accent-color)}.volume-list__item--selected:hover{background:var(--accent-color)}.volume-list__item-icon{flex-shrink:0;color:var(--text-tertiary)}.volume-list__item--selected .volume-list__item-icon{color:#fff}.volume-list__item-name{flex:1;min-width:0;font-size:.875rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.volume-list__item--selected .volume-list__item-name{color:#fff}.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)}.upload-progress{padding:8px 12px}.upload-progress__track{height:6px;background:var(--border-color);border-radius:3px;overflow:hidden}.upload-progress__fill{height:100%;background:var(--accent-color);border-radius:3px;transition:width .3s ease}.pending-files{border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--surface-primary);overflow:hidden;display:flex;flex-direction:column}.pending-files__toolbar{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 12px;background:var(--surface-tertiary);border-bottom:1px solid var(--border-color)}.pending-files__total-size{font-size:.8125rem;font-weight:500;color:var(--text-secondary)}.pending-files__clear-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:.8125rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.pending-files__clear-btn:hover{background-color:var(--surface-hover);border-color:var(--accent-color)}.pending-files__upload-btn{padding:.375rem .875rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--accent-color);border-color:var(--accent-color);color:#fff;font-size:.8125rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:background-color .2s ease,opacity .2s ease}.pending-files__upload-btn:hover:not(:disabled){background-color:var(--accent-hover, #4f46e5)}.pending-files__upload-btn:disabled{opacity:.6;cursor:not-allowed}.pending-files__list{max-height:205px;overflow-y:auto}.pending-files__table{width:100%;border-collapse:collapse;table-layout:fixed}.pending-files__table td{padding:8px 12px;font-size:.8125rem;color:var(--text-primary);border-bottom:1px solid var(--border-color)}.pending-files__table tbody tr:last-child td{border-bottom:none}.pending-files__table tbody tr:hover{background:var(--surface-hover)}.pending-files__remove-cell{width:40px;text-align:center}.pending-files__name{word-break:break-all;display:flex;align-items:center;gap:8px}.pending-files__size{width:80px;color:var(--text-tertiary);white-space:nowrap}.pending-files__row--duplicate{background:var(--warning-bg, #fefce8)}.pending-files__row--duplicate:hover{background:#fef9c3}.pending-files__duplicate-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 6px;border-radius:var(--radius-sm);background:#fef3c7;color:#92400e;font-size:.75rem;font-weight:500;white-space:nowrap;flex-shrink:0}.pending-files__remove-btn{display:flex;align-items:center;justify-content:center;padding:4px;border:none;background:none;color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-sm);transition:all .15s ease}.pending-files__remove-btn:hover{color:var(--danger-color, #ef4444);background:var(--danger-bg, #fef2f2)}.page-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;padding:12px}.page-grid__cell{display:flex;flex-direction:column;align-items:center;gap:4px;border:2px solid transparent;border-radius:var(--radius-md);padding:4px;transition:border-color .15s ease}.page-grid__cell--selected{border-color:var(--accent-color);background-color:#6366f10a}.page-grid__thumb-wrap{position:relative;width:100%;aspect-ratio:3 / 4;border-radius:var(--radius-sm);overflow:hidden;background:var(--surface-tertiary)}.page-grid__thumb{width:100%;height:100%;object-fit:cover}.page-grid__checkbox-overlay{position:absolute;top:4px;left:4px;display:flex;align-items:center;justify-content:center;width:20px;height:20px;cursor:pointer}.page-grid__checkbox-overlay input[type=checkbox]{margin:0;accent-color:var(--accent-color);cursor:pointer}.page-grid__checkbox-overlay input[type=checkbox]:disabled{cursor:not-allowed}.page-grid__badges{position:absolute;bottom:4px;right:4px;display:flex;gap:3px}.page-grid__badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 4px;border-radius:9999px;font-size:.625rem;font-weight:600;line-height:1;color:#fff}.page-grid__badge--transcription{background-color:var(--info-color, #2563eb)}.page-grid__badge--record{background-color:var(--success-color, #22c55e)}.page-grid__active-badges{position:absolute;top:4px;right:4px;display:flex;flex-direction:column;gap:3px;align-items:flex-end}.page-grid__badge--transcribing{background-color:var(--info-color, #2563eb);animation:badge-pulse 1.5s ease-in-out infinite}.page-grid__badge--extracting{background-color:var(--accent-color, #6366f1);animation:badge-pulse 1.5s ease-in-out infinite}.page-grid__badge--transcription-failed{background-color:var(--error-color, #dc2626)}.page-grid__badge--extraction-failed{background-color:var(--warning-color, #f97316)}@keyframes badge-pulse{0%,to{opacity:1}50%{opacity:.55}}.page-grid__filename{font-size:.6875rem;color:var(--text-secondary);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.page-grid__filename--bold{font-weight:600;color:var(--text-primary)}.volume-details{display:flex;flex-direction:column;height:100%;max-height:100%;min-height:0;padding:16px 16px 8px;background:var(--surface-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color);overflow:hidden;box-sizing:border-box}.volume-details__top-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding-bottom:12px;flex-shrink:0}.volume-details__title-area{display:flex;align-items:center;gap:12px;flex-wrap:wrap;min-width:0}.volume-details__delete-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid var(--border-color);border-radius:var(--radius-md);background-color:transparent;color:var(--text-tertiary);cursor:pointer;transition:all .15s ease;flex-shrink:0}.volume-details__delete-btn:hover{color:var(--danger-color);border-color:var(--danger-color);background-color:#ef444414}.volume-details__name{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.volume-details__edit-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid var(--border-color);border-radius:var(--radius-md);background-color:transparent;color:var(--text-tertiary);cursor:pointer;transition:all .15s ease;flex-shrink:0}.volume-details__edit-btn:hover{color:var(--text-primary);background-color:var(--surface-hover);border-color:var(--text-tertiary)}.volume-details__subtitle-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px;padding-bottom:12px;flex-shrink:0}.volume-details__meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.volume-details__badge{display:inline-flex;padding:3px 10px;font-size:.75rem;font-weight:500;background:var(--accent-color);color:#fff;border-radius:999px}.volume-details__meta-item{font-size:.8125rem;color:var(--text-secondary)}.volume-details__meta-item:before{content:"·";margin-right:8px;color:var(--text-tertiary)}.volume-details__tag{display:inline-flex;padding:4px 8px;font-size:.75rem;background:var(--surface-tertiary);border-radius:var(--radius-sm);color:var(--text-secondary)}.volume-details__view-buttons{display:flex;gap:8px;flex-shrink:0}.volume-details__view-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:.8125rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.volume-details__view-btn:hover:not(:disabled){background-color:var(--surface-hover);border-color:var(--accent-color)}.volume-details__view-btn:disabled{opacity:.5;cursor:not-allowed}.volume-details__view-btn--disabled{opacity:.5}.volume-details__bulk-actions{display:flex;align-items:center;gap:6px}.volume-details__separator{color:var(--text-tertiary, #9ca3af);font-size:.75rem;-webkit-user-select:none;user-select:none}.volume-details__selected-count{font-size:.8125rem;font-weight:500;color:var(--text-secondary)}.volume-details__credits{display:inline-flex;align-items:center;padding:.25rem .625rem;font-size:.75rem;font-weight:500;background-color:var(--info-bg, #eff6ff);border:1px solid var(--info-color, #2563eb);border-radius:9999px;color:var(--info-color, #2563eb);white-space:nowrap}.volume-details__credits--empty{background-color:var(--warning-bg, #fefce8);border-color:var(--warning-color, #ca8a04);color:var(--warning-color, #ca8a04)}.volume-details__link-btn{padding:0;border:none;background:none;color:var(--accent-color);font-size:.8125rem;font-weight:500;cursor:pointer;text-decoration:none}.volume-details__link-btn:hover:not(:disabled){text-decoration:underline}.volume-details__link-btn:disabled{opacity:.5;cursor:not-allowed}.volume-details__action-btn{padding:.5rem 1.25rem;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s ease,opacity .2s ease}.volume-details__action-btn:disabled{opacity:.6;cursor:not-allowed}.volume-details__action-btn--primary{background-color:var(--accent-color);color:#fff}.volume-details__action-btn--primary:hover:not(:disabled){background-color:var(--accent-hover, #4f46e5)}.volume-details__action-btn--retry{background-color:var(--warning-color, #ca8a04);color:#fff}.volume-details__action-btn--retry:hover:not(:disabled){background-color:#b45309}.volume-details__content{flex:1;overflow-y:auto;min-height:0;display:flex;flex-direction:column;gap:16px;padding-bottom:4px}.volume-details__info{padding:8px 12px;background-color:var(--info-bg, #eff6ff);border:1px solid var(--info-color, #2563eb);border-radius:var(--radius-sm);color:var(--info-color, #2563eb);font-size:.8125rem}.volume-details__warning{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__status{padding:8px 12px;border-radius:var(--radius-sm);font-size:.8125rem}.volume-details__status--pending,.volume-details__status--submitted{background-color:var(--warning-bg, #fefce8);border:1px solid var(--warning-color, #ca8a04);color:var(--warning-color, #ca8a04)}.volume-details__status--processing{background-color:var(--info-bg, #eff6ff);border:1px solid var(--info-color, #2563eb);color:var(--info-color, #2563eb)}.volume-details__status--completed{background-color:var(--success-bg, #f0fdf4);border:1px solid var(--success-color, #22c55e);color:var(--success-color, #22c55e)}.volume-details__upload-area{display:flex;flex-direction:column;gap:16px}.volume-details__upload-area--split{flex-direction:row;align-items:stretch}.volume-details__upload-area--split>*{flex:1;min-width:0}.volume-details__upload-area .dropzone{min-height:150px;padding:2rem}.volume-details__upload-area--split .dropzone{min-height:0}.volume-details__success{display:flex;align-items:center;justify-content:space-between;gap: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__dismiss-btn{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__dismiss-btn:hover{opacity:1}.volume-details__upload-error{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__notice-list{display:flex;flex-direction:column;gap:8px}.volume-details__notice-item{margin:0;padding:10px 14px;background-color:var(--surface-tertiary);border-radius:var(--radius-sm);font-size:.875rem;color:var(--text-secondary);line-height:1.5;display:flex;align-items:flex-start;gap:10px}.volume-details__notice-item--warning{background-color:var(--warning-bg, #fefce8);color:var(--warning-color, #ca8a04)}.volume-details__notice-item--warning svg{color:var(--warning-color, #ca8a04)}.volume-details__notice-item svg{flex-shrink:0;color:var(--text-tertiary);margin-top:2px}.modal:has(.volume-details__confirm-dialog){max-width:620px}.volume-details__confirm-dialog{display:flex;flex-direction:column;gap:16px}.volume-details__confirm-summary{display:flex;align-items:center;justify-content:space-between;gap:12px}.volume-details__confirm-count{margin:0;font-size:.875rem;color:var(--text-primary);font-weight:500}.volume-details__confirm-count--warning{color:var(--warning-color, #ca8a04)}.volume-details__confirm-actions{display:flex;justify-content:flex-end;gap:8px}.volume-details__confirm-cancel{padding:.5rem 1.25rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--surface-primary);color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s ease}.volume-details__confirm-cancel:hover{background-color:var(--surface-hover)}.archive-tab{display:grid;grid-template-columns:480px 1fr;grid-template-rows:1fr;gap:16px;height:calc(100vh - 140px);max-height:calc(100vh - 140px);padding:16px;box-sizing:border-box;overflow:hidden}.archive-tab__left,.archive-tab__right{min-width:0;min-height:0;max-height:100%;overflow:hidden}.archive-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)}.archive-tab__placeholder-content{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:320px;padding:48px 24px}.archive-tab__placeholder-icon{color:var(--text-tertiary);margin-bottom:16px}.archive-tab__placeholder-title{margin:0 0 8px;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.archive-tab__placeholder-text{margin:0;font-size:.875rem;color:var(--text-tertiary);line-height:1.5}@media(max-width:768px){.archive-tab{grid-template-columns:1fr;grid-template-rows:auto 1fr;height:auto}.archive-tab__left{height:300px}}.archive-page{display:flex;flex-direction:column;flex:1;min-height:0;padding:16px 2rem 0;box-sizing:border-box;overflow:hidden}.archive-page>.archive-tab{height:auto;max-height:none;flex:1;min-height:0;padding:0 0 16px}.record-browser{padding:1rem;flex:1;min-height:0;display:flex;flex-direction:column}.record-browser__files-btn{display:inline-flex;align-items:center;gap:.35rem;padding:4px 8px;background-color:var(--surface-tertiary);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;transition:all .15s ease;white-space:nowrap}.record-browser__files-btn:hover{border-color:var(--accent-color);color:var(--accent-color);background-color:var(--accent-bg)}.record-browser__loading,.record-browser__error,.record-browser__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:var(--text-tertiary);font-size:14px;gap:.75rem}.record-browser__error{color:var(--error-color, #e53e3e)}.record-browser__spinner{width:24px;height:24px;border:2px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;animation:record-spin .8s linear infinite}@keyframes record-spin{to{transform:rotate(360deg)}}.record-table-wrap{overflow:auto;flex:1;min-height:0;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--surface-secondary)}.record-table{width:100%;border-collapse:collapse}.record-table colgroup .col-action{width:70px}.record-table colgroup .col-image{width:140px;max-width:140px}.record-table colgroup .col-order{width:50px}.record-table colgroup .col-events,.record-table colgroup .col-other{width:320px}.record-table thead{background:var(--surface-tertiary);position:sticky;top:0;z-index:2}.record-table th{padding:8px 12px;text-align:left;font-size:12px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border-color);white-space:nowrap}.record-table th.col-action{text-align:center}.record-table td{padding:10px 12px;font-size:13px;color:var(--text-primary);border-bottom:1px solid var(--border-color);vertical-align:top}.record-table tbody tr:last-child td{border-bottom:none}.record-table tbody tr:hover{background:var(--surface-hover)}.record-table tbody tr:nth-child(2n){background:var(--surface-tertiary)}.record-table tbody tr{border-left:5px solid transparent}.record-table tbody tr[data-type=baptism]{border-left-color:var(--baptism-color)}.record-table tbody tr[data-type=birth]{border-left-color:var(--birth-color)}.record-table tbody tr[data-type=marriage],.record-table tbody tr[data-type=civil_marriage]{border-left-color:var(--marriage-color)}.record-table tbody tr[data-type=death]{border-left-color:var(--death-color)}.record-table tbody tr[data-type=census]{border-left-color:var(--census-color)}.cell-image{font-family:SF Mono,Cascadia Code,Consolas,monospace;font-size:12px;color:var(--text-secondary);word-break:break-all}.cell-order{text-align:center;font-variant-numeric:tabular-nums;font-weight:500;color:var(--text-secondary)}.cell-other{font-size:12px;color:var(--text-secondary);line-height:1.45}.td-events{padding:0!important}.event-subtable{width:100%;border-collapse:collapse}.event-subtable .event-sub-type{width:90px;min-width:70px}.event-subtable .event-sub-date{width:70px;min-width:50px}.event-subtable td{padding:10px 12px;font-size:13px;color:var(--text-primary);vertical-align:middle;border-bottom:none}.event-subtable .event-sub-date{font-variant-numeric:tabular-nums;white-space:nowrap;color:var(--text-secondary)}.event-subtable .event-sub-place{color:var(--text-secondary);max-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-subtable tr{background:transparent!important;border-left:none}.event-subrow+.event-subrow td{border-top:1px dashed var(--border-color)}.badge{display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px;border:1px solid;white-space:nowrap;line-height:1}.badge--baptism{background:var(--baptism-bg);border-color:var(--baptism-border);color:var(--baptism-color)}.badge--birth{background:var(--birth-bg);border-color:var(--birth-border);color:var(--birth-color)}.badge--marriage,.badge--civil_marriage{background:var(--marriage-bg);border-color:var(--marriage-border);color:var(--marriage-color)}.badge--death{background:var(--death-bg);border-color:var(--death-border);color:var(--death-color)}.badge--census{background:var(--census-bg);border-color:var(--census-border);color:var(--census-color)}.badge--unknown{background:var(--surface-tertiary);border-color:var(--border-color);color:var(--text-secondary)}.action-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--surface-tertiary);color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.action-btn:hover{border-color:var(--accent-color);color:var(--accent-color);background:var(--accent-bg)}.action-btn svg{width:16px;height:16px}.td-action{text-align:center}.record-table td.td-action{vertical-align:middle}.td-action .action-btn{margin:0 auto}.principals{min-width:280px}.principals__child{font-weight:600;font-size:13px;margin-bottom:3px}.principals__child-detail{font-weight:400;color:var(--text-tertiary)}.couple{display:grid;grid-template-columns:1fr auto 1fr;gap:0 8px;align-items:start}.couple__left,.couple__right{min-width:0}.couple__symbol{font-size:20px;line-height:1.2;color:var(--text-tertiary);align-self:start;-webkit-user-select:none;user-select:none}.couple__name{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.couple__detail{font-weight:400;color:var(--text-tertiary);font-style:italic}.tree-links{margin-top:2px;padding-left:2px}.tree-link{display:flex;align-items:baseline;gap:4px;font-size:13px;line-height:1.5;color:var(--text-primary)}.tree-link__connector{color:var(--text-tertiary);flex-shrink:0;-webkit-user-select:none;user-select:none}.tree-link__label{font-size:11px;color:var(--text-tertiary);font-style:italic;flex-shrink:0}.pedigree-parents--stacked{margin-top:2px;padding-left:2px}.household-children{list-style:disc;margin:5px 0 0 20px;padding:0;font-size:13px;color:var(--text-primary)}.household-children li{line-height:1.5}.principals__children{grid-column:1 / -1;border-top:1px solid var(--border-color);margin-top:5px;padding-top:5px;font-size:13px;color:var(--text-primary)}.principals__children-label{font-weight:600;font-size:11px;color:var(--text-tertiary);text-transform:lowercase}.principals__children-list{display:inline}.child-entry__age{color:var(--text-tertiary)}@media(max-width:1024px){.record-table colgroup .col-image{width:0}.record-table .col-image,.record-table td:nth-child(2),.record-table th:nth-child(2){display:none}}@media(max-width:768px){.record-table{min-width:0}.record-table colgroup,.record-table thead{display:none}.record-table tbody tr{display:block;margin-bottom:12px;border:1px solid var(--border-color);border-radius:var(--radius-md);border-left-width:4px;background:var(--surface-secondary);padding:10px 14px}.record-table td{display:block;padding:3px 0;border-bottom:none;font-size:13px}.record-table td:before{content:attr(data-label);display:inline-block;width:80px;font-size:10px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.03em;vertical-align:top}.record-table td.td-principals,.record-table td.td-action{padding-top:8px}.record-table td.td-principals:before{display:block;width:auto;margin-bottom:4px}.record-table td.td-action:before{display:none}.record-table td.td-action{text-align:left}.event-subtable td{display:table-cell;padding:4px 8px;font-size:12px}.event-subtable td:before{display:none}.record-table td.td-events{padding:3px 0!important}.principals{min-width:0}}.volume-browser{display:grid;grid-template-rows:1fr auto;flex:1;min-height:0;background-color:var(--surface-primary);overflow:hidden}.volume-browser--empty{grid-template-rows:auto 1fr}.volume-browser__empty-content{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center}.volume-browser__empty-icon{color:var(--text-tertiary);margin-bottom:1.5rem;opacity:.5}.volume-browser__empty-text{margin:0 0 .5rem;font-size:1.125rem;color:var(--text-secondary)}.volume-browser__empty-hint{margin:0;font-size:.875rem;color:var(--text-tertiary)}.volume-browser__header{display:flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;background-color:var(--surface-secondary);border-bottom:1px solid var(--border-color)}.volume-browser__title{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-primary);white-space:nowrap}.volume-browser__filename{font-size:.9375rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:400px}.volume-browser__transcription-checkbox{margin:0;accent-color:var(--accent-color);cursor:pointer}.volume-browser__filename-wrapper{display:inline-flex;align-items:center;gap:.375rem;min-width:0}.volume-browser__filename-edit{display:inline-flex;align-items:center;gap:0}.volume-browser__filename-input{padding:.125rem .375rem;font-size:.9375rem;font-weight:600;font-family:inherit;color:var(--text-primary);background:var(--surface-primary);border:1px solid var(--accent-color);border-radius:var(--radius-sm) 0 0 var(--radius-sm);outline:none;max-width:300px}.volume-browser__filename-ext{padding:.125rem .375rem;font-size:.9375rem;font-weight:600;color:var(--text-tertiary);background:var(--surface-tertiary);border:1px solid var(--border-color);border-left:none;border-radius:0 var(--radius-sm) var(--radius-sm) 0}.volume-browser__rename-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;border-radius:var(--radius-sm);background-color:transparent;color:var(--text-tertiary);cursor:pointer;opacity:0;transition:all .15s ease}.volume-browser__filename-wrapper:hover .volume-browser__rename-btn{opacity:1}.volume-browser__rename-btn:hover{background-color:var(--surface-hover);color:var(--text-primary)}.volume-browser__actions{display:flex;align-items:center;gap:.5rem}.volume-browser__delete-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background-color:transparent;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.volume-browser__delete-btn:hover{color:var(--danger-color);border-color:var(--danger-color);background-color:#ef444414}.volume-browser__download-btn{display:inline-flex;align-items:center;gap:.5rem;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}.volume-browser__download-btn:hover{background-color:var(--accent-hover)}.volume-browser__records-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background-color:var(--surface-tertiary);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease}.volume-browser__records-btn:hover:not(:disabled){border-color:var(--accent-color);color:var(--accent-color);background-color:var(--accent-bg)}.volume-browser__records-btn:disabled{opacity:.4;cursor:not-allowed}.nav-controls{display:flex;align-items:center;gap:.5rem}.nav-controls__btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background-color:var(--surface-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:all .15s ease}.nav-controls__btn:hover:not(:disabled){background-color:var(--surface-hover);border-color:var(--accent-color);color:var(--accent-color)}.nav-controls__btn:disabled{opacity:.4;cursor:not-allowed}.nav-controls__position{display:flex;align-items:center;gap:.375rem;font-size:.875rem;font-weight:500;color:var(--text-primary);font-variant-numeric:tabular-nums}.nav-controls__position-label{color:var(--text-secondary);white-space:nowrap}.nav-controls__position-input{padding:.25rem .375rem;font-size:.875rem;text-align:center;background-color:var(--surface-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-variant-numeric:tabular-nums;font-weight:600}.nav-controls__position-input:focus{outline:none;border-color:var(--accent-color);background-color:var(--surface-primary)}.volume-browser__main{overflow:hidden;min-height:0}.page-viewer{display:grid;grid-template-columns:2fr 1fr;grid-template-rows:1fr;gap:0;height:100%;background-color:var(--border-color)}.page-viewer--transcription-closed{grid-template-columns:1fr}.page-viewer--empty,.page-viewer--unsupported{display:flex;align-items:center;justify-content:center;background-color:var(--surface-secondary)}.page-viewer__empty-message,.page-viewer__unsupported-message{text-align:center;color:var(--text-secondary);padding:2rem}.page-viewer__filename{margin-top:.5rem;font-size:.875rem;color:var(--text-tertiary);word-break:break-all}.page-viewer__zoom-overlay{position:absolute;top:.5rem;left:50%;transform:translate(-50%);z-index:10;pointer-events:auto;opacity:.6;transition:opacity .2s ease}.page-viewer__zoom-overlay:hover{opacity:1}.page-viewer__zoom-overlay .image-controls{background-color:#0000008c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#ffffffe6}.page-viewer__zoom-overlay .image-controls__btn{color:#fffc}.page-viewer__zoom-overlay .image-controls__btn:hover{background-color:#ffffff26;color:#fff}.page-viewer__zoom-overlay .image-controls__scale{color:#fffc}.page-viewer__zoom-overlay .image-controls__btn--reset{color:#ffffffb3}.page-viewer__zoom-overlay .image-controls__btn--reset:hover{color:#fff}.page-viewer__preview-section{position:relative;display:flex;flex-direction:column;background-color:var(--surface-primary);min-height:0;overflow:hidden}.page-viewer__preview-viewport--hidden{position:absolute;width:0;height:0;overflow:hidden}.page-viewer__preview-viewport{flex:1;background-color:#1a1a1a;cursor:grab;overflow:hidden}.page-viewer__preview-viewport:active{cursor:grabbing}.page-viewer__preview-content{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.page-viewer__preview-image{width:100%;height:100%;object-fit:contain;-webkit-user-select:none;user-select:none}.page-viewer__nav-arrow{position:absolute;top:0;bottom:0;width:60px;z-index:10;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:#fff;cursor:pointer;opacity:0;transition:opacity .2s ease;padding:0}.page-viewer__nav-arrow:hover{opacity:1}.page-viewer__nav-arrow--prev{left:0}.page-viewer__nav-arrow--prev:hover{background:linear-gradient(to right,rgba(0,0,0,.3),transparent)}.page-viewer__nav-arrow--next{right:0}.page-viewer__nav-arrow--next:hover{background:linear-gradient(to left,rgba(0,0,0,.3),transparent)}.page-viewer__nav-arrow svg{background:#0006;border-radius:50%;padding:6px;width:36px;height:36px}.page-viewer__preview-loading,.page-viewer__preview-error{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background-color:var(--surface-secondary);color:var(--text-secondary)}.page-viewer__preview-error{color:var(--danger-color)}.page-viewer__spinner{width:24px;height:24px;border:2px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.page-viewer__transcription-section{display:flex;flex-direction:column;background-color:var(--surface-primary);min-height:0;overflow:hidden}.page-viewer__tab-bar{display:flex;background-color:var(--surface-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0}.page-viewer__tab{flex:1;padding:.625rem 1rem;border:none;border-bottom:3px solid transparent;background:none;font-size:.8125rem;font-weight:600;color:var(--text-tertiary);cursor:pointer;transition:all .15s ease}.page-viewer__tab:hover{color:var(--text-secondary);background-color:var(--surface-hover)}.page-viewer__tab--active{color:var(--accent-color);border-bottom-color:var(--accent-color)}.page-viewer__tab--active:hover{color:var(--accent-color)}.page-viewer__records-content{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.page-viewer__records-table-wrap{flex:1;overflow:auto}.inline-record--even td{background-color:var(--surface-secondary)}.inline-record--odd td{background-color:var(--surface-primary)}.inline-record__header-row td{border-bottom:none!important}.inline-record__header-row td[colspan]{padding:.375rem 1rem .125rem!important;font-size:.8125rem;color:var(--text-secondary);border-top:1px solid var(--border-color)}.inline-record__header-cell{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.inline-record__order{font-weight:700;font-variant-numeric:tabular-nums;color:var(--text-tertiary)}.inline-record__event{display:inline-flex;align-items:center;gap:.375rem}.page-viewer__records-table-wrap .couple__name{white-space:normal;overflow:visible;text-overflow:unset}.inline-record__event-detail{font-size:.75rem;color:var(--text-tertiary)}.page-viewer__records-empty{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;text-align:center;color:var(--text-secondary);background-color:var(--surface-secondary)}.page-viewer__canonical-pill{display:inline-flex;align-items:center;padding:.15rem .5rem;border-radius:999px;font-size:.6875rem;font-weight:600;color:#166534;background-color:#dcfce7;border:1px solid #bbf7d0}.page-viewer__transcription-loading,.page-viewer__transcription-error,.page-viewer__transcription-placeholder{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;text-align:center;color:var(--text-secondary);background-color:var(--surface-secondary)}.page-viewer__transcription-error{color:var(--danger-color)}.page-viewer__transcription-content{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.page-viewer__transcription-sections{flex:1;overflow-y:auto}.page-viewer__transcription-block{margin:0;padding:.75rem 1rem;font-family:inherit;font-size:.9375rem;line-height:1.6;color:var(--text-primary);white-space:pre-wrap;word-wrap:break-word}.page-viewer__transcription-block--even{background-color:var(--surface-secondary)}.page-viewer__transcription-block--odd{background-color:var(--surface-primary)}.page-viewer__transcription-meta{padding:.5rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:.375rem;font-size:.75rem;color:var(--text-tertiary);border-top:1px solid var(--border-color);background-color:var(--surface-tertiary);flex-shrink:0}.page-viewer__transcription-history-controls{display:flex;align-items:center;gap:.5rem;min-width:0}.page-viewer__transcription-history-btn{border:1px solid var(--border-color);background-color:var(--surface-primary);color:var(--text-secondary);border-radius:var(--radius-sm);font-size:.7rem;padding:.125rem .375rem;cursor:pointer}.page-viewer__transcription-history-btn:disabled{opacity:.5;cursor:not-allowed}.page-viewer__transcription-history-position{font-variant-numeric:tabular-nums}.page-viewer__transcription-meta-main{margin-left:auto;text-align:right;white-space:nowrap}.page-viewer__search-highlight{background-color:#fef08a;color:var(--text-primary);border-radius:2px;padding:0 1px}.page-viewer__transcription-block--highlight{animation:record-highlight 1.5s ease-out}@keyframes record-highlight{0%{background-color:color-mix(in srgb,var(--accent-color) 30%,transparent)}to{background-color:transparent}}.image-controls{display:flex;align-items:center;gap:.5rem;background-color:var(--surface-tertiary);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}.volume-browser__footer{background-color:var(--surface-secondary);border-top:1px solid var(--border-color);padding:.25rem .5rem;min-width:0}.volume-browser__footer--hidden{display:none}.filmstrip-container{display:flex;align-items:center;gap:0}.filmstrip-arrow{flex-shrink:0;width:24px;height:52px;padding:0;border:none;background:transparent;color:var(--text-tertiary);font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background-color .15s ease,color .15s ease}.filmstrip-arrow:hover{background-color:var(--surface-tertiary);color:var(--text-primary)}.filmstrip-arrow--hidden{visibility:hidden}.filmstrip{overflow-x:auto;overflow-y:hidden;scrollbar-width:none;min-width:0;flex:1;cursor:grab}.filmstrip::-webkit-scrollbar{display:none}.filmstrip__track{display:flex;gap:.375rem}.filmstrip__thumb{position:relative;flex-shrink:0;width:52px;height:52px;padding:0;background-color:var(--surface-tertiary);border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;overflow:hidden;transition:all .15s ease}.filmstrip__thumb:hover{border-color:var(--text-tertiary)}.filmstrip__thumb--active{border-color:#fff;outline:2px solid var(--accent-color);outline-offset:0px}.filmstrip__thumb-img{width:100%;height:100%;object-fit:cover}.filmstrip__thumb-loading,.filmstrip__thumb-error,.filmstrip__thumb-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--text-tertiary)}.filmstrip__thumb-spinner{width:16px;height:16px;border:2px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;animation:spin .8s linear infinite}.filmstrip__thumb-error{color:var(--danger-color);opacity:.6}.filmstrip__thumb-index{position:absolute;bottom:2px;right:2px;padding:1px 4px;font-size:.625rem;font-weight:600;color:#fff;background-color:#0009;border-radius:2px;font-variant-numeric:tabular-nums}@media(max-width:768px){.nav-controls__position-label{display:none}.page-viewer{grid-template-columns:1fr;grid-template-rows:1fr 1fr}.page-viewer--transcription-closed{grid-template-rows:1fr}.filmstrip__thumb{width:56px;height:56px}}@media(max-width:480px){.volume-browser__download-btn span{display:none}.volume-browser__download-btn{padding:.5rem}.nav-controls__position{min-width:4rem;font-size:.8125rem}.filmstrip__thumb{width:48px;height:48px}.filmstrip__thumb-index{font-size:.5625rem}}.page-browser-page{display:flex;flex-direction:column;flex:1;min-height:0}.search-results{display:flex;flex-direction:column;height:100%;overflow:hidden}.search-results__header{padding:8px 0;font-size:.8125rem;color:var(--text-secondary)}.search-results__list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.search-results__item{display:flex;align-items:flex-start;gap:12px;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--surface-primary);cursor:pointer;text-align:left;width:100%;font-family:inherit;font-size:inherit;color:inherit}.search-results__item:hover{background:var(--surface-secondary)}.search-results__thumb{flex-shrink:0;width:48px;height:48px;border-radius:var(--radius-sm);overflow:hidden;background:var(--surface-secondary)}.search-results__thumb img{width:100%;height:100%;object-fit:cover}.search-results__thumb-placeholder{width:100%;height:100%;background:var(--surface-secondary)}.search-results__content{flex:1;min-width:0}.search-results__file-info{font-size:.8125rem;font-weight:500;color:var(--text-primary);margin-bottom:4px}.search-results__volume-name{color:var(--text-secondary)}.search-results__separator{color:var(--text-tertiary);margin:0 4px}.search-results__filename{color:var(--text-primary)}.search-results__snippet{font-size:.8125rem;color:var(--text-secondary);line-height:1.4;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.search-results__highlight{background-color:#fef08a;color:var(--text-primary);border-radius:2px;padding:0 1px}.search-results__empty{display:flex;align-items:center;justify-content:center;padding:48px 24px;color:var(--text-tertiary);font-size:.875rem}.search-page{display:flex;flex-direction:column;flex:1;min-height:0;padding:16px 2rem 0;box-sizing:border-box;overflow:hidden}.search-page__results{flex:1;min-height:0;overflow:hidden;padding-bottom:16px}.timeline-family-tree{--tree-gen-0: #3b82f6;--tree-gen-1: #22c55e;--tree-gen-2: #eab308;--tree-gen-3: #ef4444;--tree-gen-4: #a855f7;--tree-gen-5: #ec4899;--tree-gen-6: #14b8a6;--tree-gen-7: #f97316;position:relative;overflow:auto;padding:20px}.timeline-family-tree__chart{position:relative}.family-tree-page{padding:24px 2rem}.family-tree-page h1{margin:0 0 16px;font-size:1.5rem;color:#333}.legal-page{display:flex;flex-direction:column;align-items:center;min-height:100vh;padding:2rem}.legal-page__card{width:100%;max-width:720px;padding:2.5rem;background-color:var(--surface-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color);margin-bottom:2rem}.legal-page__topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.25rem}.legal-page__topbar .language-selector{margin:0;flex-shrink:0}.legal-page__title{display:flex;align-items:center;gap:.5rem;margin:0;font-size:1.75rem;font-weight:700;color:var(--text-primary)}.legal-page__title-logo{width:32px;height:auto;flex-shrink:0}.legal-page__date{margin:0 0 2rem;font-size:.875rem;color:var(--text-tertiary)}.legal-page__intro{margin:0 0 2rem;font-size:.9375rem;line-height:1.6;color:var(--text-secondary)}.legal-page__section{margin-bottom:2rem}.legal-page__section-title{margin:0 0 .5rem;font-size:1.125rem;font-weight:600;color:var(--text-primary)}.legal-page__summary{margin:0 0 .75rem;padding:.625rem .875rem;background-color:var(--surface-primary);border-left:3px solid var(--accent-color);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:.8125rem;font-style:italic;color:var(--text-secondary);line-height:1.5}.legal-page__text{margin:0 0 .75rem;font-size:.9375rem;line-height:1.6;color:var(--text-secondary)}.legal-page__list{margin:0 0 .75rem;padding-left:1.5rem;list-style:disc}.legal-page__list li{margin-bottom:.375rem;font-size:.9375rem;line-height:1.5;color:var(--text-secondary)}.legal-page__back{margin-bottom:2rem}.legal-page__back-link{background:none;border:none;color:var(--accent-color);font-size:.875rem;cursor:pointer;text-decoration:underline}.legal-page__back-link:hover{color:var(--accent-hover)}@media(max-width:600px){.legal-page{padding:1rem}.legal-page__card{padding:1.5rem}.legal-page__title{font-size:1.25rem}.legal-page__title-logo{width:26px}}.feedback-fab{position:fixed;bottom:28px;right:40px;z-index:1000;width:56px;height:56px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;background-color:#646cffbf;color:#fff;box-shadow:0 2px 8px #0000004d;transition:transform .2s ease,box-shadow .2s ease,background-color .15s ease}.feedback-fab:hover{background-color:#646cffcc;transform:scale(1.08);box-shadow:0 4px 16px #0006}.feedback-fab:active{transform:scale(.96)}.feedback-form{display:flex;flex-direction:column;gap:16px}.feedback-form__type-toggle{display:flex;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-color)}.feedback-form__type-option{flex:1;padding:8px 12px;text-align:center;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--text-secondary);background-color:var(--surface-secondary);border-right:1px solid var(--border-color);transition:background-color .15s ease,color .15s ease;-webkit-user-select:none;user-select:none}.feedback-form__type-option:last-child{border-right:none}.feedback-form__type-option:hover{background-color:var(--surface-hover)}.feedback-form__type-option--active{background-color:var(--accent-bg);color:var(--accent-color)}.feedback-form__type-radio{position:absolute;opacity:0;pointer-events:none}.feedback-form__textarea{width:100%;min-height:120px;padding:12px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background-color:var(--surface-secondary);color:var(--text-primary);font-family:inherit;font-size:.9rem;line-height:1.5;resize:vertical;box-sizing:border-box;transition:border-color .15s ease}.feedback-form__textarea:focus{outline:none;border-color:var(--accent-color)}.feedback-form__textarea::placeholder{color:var(--text-tertiary)}.feedback-form__textarea:disabled{opacity:.6}.feedback-form__error{margin:0;padding:8px 12px;border-radius:var(--radius-sm);background-color:var(--error-bg);border:1px solid var(--error-border);color:var(--error-text);font-size:.85rem}.feedback-form__submit{padding:10px 20px;border-radius:var(--radius-sm);border:none;background-color:var(--accent-color);color:#fff;font-size:.9rem;font-weight:500;cursor:pointer;transition:background-color .15s ease}.feedback-form__submit:hover:not(:disabled){background-color:var(--accent-hover)}.feedback-form__submit:disabled{opacity:.5;cursor:not-allowed}.feedback-form__success{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px 0;color:var(--accent-color);text-align:center}.feedback-form__success p{margin:0;font-size:1rem;font-weight:500;color:var(--text-primary)}
