:root{--hue-primary: 210;--hue-accent: 220;--hue-success: 150;--hue-warning: 35;--hue-danger: 350;--bg-app: hsl(var(--hue-primary), 20%, 96%);--bg-panel: hsl(0, 0%, 100%);--bg-card: hsl(var(--hue-primary), 20%, 98%);--bg-input: hsl(0, 0%, 100%);--bg-glass: hsla(0, 0%, 100%, .8);--bg-glass-strong: hsla(0, 0%, 100%, .95);--text-main: hsl(var(--hue-primary), 30%, 15%);--text-secondary: hsl(var(--hue-primary), 10%, 40%);--text-muted: hsl(var(--hue-primary), 10%, 60%);--text-highlight: hsl(var(--hue-accent), 70%, 40%);--primary: hsl(var(--hue-accent), 80%, 50%);--primary-hover: hsl(var(--hue-accent), 80%, 45%);--primary-glow: hsla(var(--hue-accent), 80%, 50%, .3);--success: hsl(var(--hue-success), 70%, 45%);--danger: hsl(var(--hue-danger), 80%, 55%);--border-subtle: hsla(var(--hue-primary), 10%, 80%, .5);--border-focus: hsla(var(--hue-accent), 50%, 50%, .5);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--nav-width: 260px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-app);color:var(--text-main);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;font-size:15px}a{text-decoration:none;color:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.glass-panel{background:var(--bg-panel);box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.app-container{display:flex;height:100vh;overflow:hidden;background:var(--bg-app)}.main-content{flex:1;overflow-y:auto;padding:2rem;position:relative}h1,h2,h3,h4{font-weight:600;color:var(--text-main);margin-bottom:1rem}h1{font-size:2rem;letter-spacing:-.02em}h2{font-size:1.5rem}h3{font-size:1.25rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;border-radius:var(--radius-sm);border:none;font-weight:500;font-size:.9rem;cursor:pointer;transition:all .2s ease}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 2px 4px var(--primary-glow)}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:#fff;color:var(--text-secondary);border:1px solid var(--border-subtle)}.btn-secondary:hover{background:#f8fafc;color:var(--text-main);border-color:#cbd5e1}.btn-danger{background:#fee2e2;color:var(--danger);border:1px solid #fecaca}.btn-danger:hover{background:#fecaca}.form-control{width:100%;padding:.75rem 1rem;border-radius:var(--radius-sm);border:1px solid var(--border-subtle);background:var(--bg-input);color:var(--text-main);font-size:.95rem;transition:all .2s ease}input[type=text],input[type=number],input[type=search],input[type=url],input[type=email],input[type=password]{background:var(--bg-input);border:1px solid var(--border-subtle);color:var(--text-main);transition:border-color .15s ease}input:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-glow)}.animate-fade-in{animation:fadeIn .4s ease-out forwards}.sidebar{width:var(--nav-width);height:100vh;display:flex;flex-direction:column;padding:1.5rem;position:fixed;left:0;top:0;border-right:1px solid var(--border-subtle);border-top:none;border-bottom:none;border-left:none;background:var(--bg-glass-strong);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:100}.sidebar-header{display:flex;align-items:center;gap:.75rem;margin-bottom:2.5rem;padding:0 .5rem}.logo-icon{color:var(--primary);filter:drop-shadow(0 2px 4px var(--primary-glow));display:flex;align-items:center;justify-content:center;background:hsla(var(--hue-primary),30%,90%,.5);padding:8px;border-radius:12px}.logo-text{font-size:1.1rem;font-weight:700;margin:0;background:linear-gradient(135deg,var(--primary) 0%,var(--text-main) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:.5px;text-transform:uppercase}.sidebar-nav{display:flex;flex-direction:column;gap:.8rem;flex:1}.nav-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.2rem;border-radius:var(--radius-md);color:var(--text-secondary);transition:all .2s ease;font-weight:500;text-decoration:none}.nav-item:hover{background:hsla(var(--hue-primary),30%,30%,.05);color:var(--text-main);transform:translate(4px)}.nav-item.active{background:var(--primary);color:#fff;box-shadow:0 4px 12px var(--primary-glow);border-left:none}.nav-item svg{opacity:.7;transition:opacity .2s ease}.nav-item.active svg{opacity:1;color:#fff}.sidebar-footer{margin-top:auto;font-size:.8rem;color:var(--text-muted);text-align:center;padding-top:1rem;border-top:1px solid var(--border-subtle)}.mobile-close-btn{display:none;background:transparent;border:none;color:var(--text-main);margin-left:auto;cursor:pointer}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:99;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@media(max-width:768px){.sidebar{transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);width:80%;max-width:300px}.sidebar.mobile-open{transform:translate(0);box-shadow:20px 0 50px #0000004d}.sidebar-overlay.active{display:block;animation:fadeIn .3s ease}.mobile-close-btn{display:block}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-top:2rem}.stat-card{padding:2rem;display:flex;flex-direction:column;gap:.5rem}.stat-card h3{margin:0;font-size:1.1rem;color:var(--text-secondary);font-weight:500}.stat-value{font-size:3rem;font-weight:700;line-height:1}.stat-value.primary{color:var(--primary)}.stat-value.success{color:var(--success)}.book-toolbar{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.search-container{display:flex;gap:1rem;align-items:center}.search-input-wrapper{position:relative;flex:1;max-width:400px}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-muted)}.search-input{width:100%;padding:.8rem 2.5rem .8rem 3rem;border-radius:var(--radius-lg);border:1px solid var(--border-subtle);background:var(--bg-input);color:var(--text-main);outline:none}.clear-btn{position:absolute;right:.8rem;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;padding:.2rem;border-radius:50%}.stats-info{font-size:.9rem;color:var(--text-secondary);margin-left:.5rem}.table-container{overflow-x:auto}.book-table{width:100%;border-collapse:collapse;font-size:.95rem}.book-table th{border-bottom:1px solid var(--border-subtle);text-align:left;padding:1rem;color:var(--text-muted)}.book-table tbody tr{border-bottom:1px solid var(--border-subtle);transition:background .2s}.book-table tbody tr:hover{background:var(--bg-card)}.book-table td{padding:1rem}.book-title-cell{display:flex;align-items:center;gap:.8rem;font-weight:500}.icon-wrapper{padding:.5rem;background:var(--bg-app);border-radius:6px}.btn-icon{color:var(--text-muted);transition:color .2s;display:inline-flex}.btn-icon:hover{color:var(--primary)}.pagination{display:flex;justify-content:flex-end;margin-top:1.5rem;gap:1rem;align-items:center}.book-thumbnail-wrapper{width:60px;height:80px;background:var(--bg-card);border-radius:4px;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;border:1px solid var(--border-subtle)}.book-thumbnail{width:100%;height:100%;object-fit:cover}.book-placeholder{color:var(--text-muted)}.status-tick{color:var(--success);display:flex;align-items:center;justify-content:center}.book-link{font-weight:500;color:var(--text-main);transition:color .15s;text-decoration:none}.book-link:hover{color:var(--primary);text-decoration:underline}.loading-cell{padding:3rem;text-align:center}.loading-content{display:flex;justify-content:center;gap:.5rem;color:var(--text-muted)}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.book-toolbar,.search-container{flex-direction:column;align-items:stretch}.search-input-wrapper{max-width:100%}.book-table th,.book-table td{padding:.75rem .5rem}.book-thumbnail-wrapper{width:40px;height:55px}.status-tick{justify-content:flex-start}}.import-container{max-width:800px;margin:0 auto;padding:2.5rem}.import-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.import-container .form-group label{display:flex;align-items:center;gap:.5rem;font-weight:500;color:var(--text-secondary)}.import-container .form-group input[type=text]{padding:.8rem 1rem;border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:#0003;color:var(--text-main);font-size:1rem;transition:all .2s}.import-container .form-group input[type=text]:focus{border-color:var(--primary);box-shadow:0 0 0 2px rgba(var(--primary-rgb),.1);outline:none}.file-drop-area{border:2px dashed var(--border-subtle);border-radius:var(--radius-md);padding:2rem;text-align:center;transition:all .2s;background:#ffffff05}.file-drop-area:hover{border-color:var(--primary);background:rgba(var(--primary-rgb),.05)}.file-upload-label{cursor:pointer;width:100%;height:100%;display:block}.file-placeholder{display:flex;flex-direction:column;align-items:center;gap:.8rem;color:var(--text-muted)}.file-selected{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--text-main);font-weight:500}.success-icon{color:var(--success)}.file-size{font-size:.85rem;color:var(--text-muted);font-weight:400}.btn-upload{margin-top:1rem;padding:1rem;font-size:1.1rem;display:flex;align-items:center;justify-content:center;gap:.8rem}.status-message{padding:1rem;border-radius:var(--radius-md);display:flex;align-items:center;gap:.8rem;font-weight:500}.status-message.success{background:#10b9811a;color:#10b981;border:1px solid rgba(16,185,129,.2)}.status-message.error{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.2)}.hint-text{text-align:center;color:var(--text-muted);font-size:.9rem;margin-top:-.5rem}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content.indexed-pages-modal{background:#fff;width:90%;max-width:800px;height:80vh;display:flex;flex-direction:column;border-radius:8px;box-shadow:0 4px 6px #0000001a}.modal-header{padding:1rem;border-bottom:1px solid #ddd;display:flex;justify-content:space-between;align-items:center}.modal-body{flex:1;overflow-y:auto;padding:1rem}.search-bar{display:flex;align-items:center;background:#f0f0f0;border-radius:4px;padding:.5rem;margin-bottom:1rem}.search-bar input{border:none;background:transparent;flex:1;margin-left:.5rem;outline:none}.pages-list{display:flex;flex-direction:column;gap:1rem}.page-item{border:1px solid #eee;padding:1rem;border-radius:4px}.page-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-weight:600}.status{padding:2px 8px;border-radius:12px;font-size:.8em;text-transform:capitalize}.status.pending{background-color:#fff3cd;color:#856404}.status.indexed,.status.success{background-color:#d4edda;color:#155724}.page-content-preview{font-size:.9em;white-space:pre-wrap;max-height:150px;overflow-y:auto;background:#f9f9f9;padding:.5rem;border-radius:4px}.modal-footer{padding:1rem;border-top:1px solid #ddd;display:flex;justify-content:space-between;align-items:center}.close-btn{background:none;border:none;cursor:pointer}.book-edit-page{padding-bottom:2rem}.edit-layout{display:grid;grid-template-columns:1fr 1fr;gap:2rem;max-width:1200px;margin:0 auto}.back-btn{background:transparent;border:none;color:var(--text-muted);display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:1rem;padding:0;margin-right:1rem}.back-btn:hover{color:var(--primary)}.info-panel,.upload-panel{padding:2rem;display:flex;flex-direction:column;gap:1.5rem}.info-group{display:flex;flex-direction:column;gap:.5rem}.info-group label{font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600}.info-value{font-size:1.1rem;color:var(--text-main);padding:.5rem 0;border-bottom:1px solid var(--border-subtle)}.info-value.title{font-size:1.4rem;font-weight:600;color:var(--primary);border-bottom:none}.info-value.code{font-family:monospace;font-size:.9rem;background:#0003;padding:.5rem;border-radius:var(--radius-sm);word-break:break-all;border:none}.status-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:99px;font-weight:500;width:fit-content;font-size:.95rem}.status-badge.indexed{background:#10b98126;color:#10b981}.status-badge.not-indexed{background:#ef444426;color:#ef4444}.panel-desc{color:var(--text-secondary);font-size:.95rem;line-height:1.5}.file-drop-area.small{padding:1.5rem}.btn-upload-content{width:100%;margin-top:1rem;justify-content:center}.status-message.compact{margin-top:1rem;padding:.75rem;font-size:.9rem}@media(max-width:768px){.edit-layout{grid-template-columns:1fr}}.info-group input.form-input{width:100%;padding:.75rem;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-size:1rem;background:var(--bg-input);color:var(--text-main);transition:all .2s}.info-group input.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-glow);outline:none}.info-group label{display:flex;align-items:center;gap:.5rem}.search-panel{padding:2rem;margin-bottom:2rem;border-radius:var(--radius-lg)}@media(max-width:768px){.search-panel{padding:1rem}.search-form{flex-direction:column}.btn-search-submit{width:100%;margin-top:.5rem;justify-content:center}}.search-form{display:flex;gap:1rem}.search-field-wrapper{position:relative;flex:1}.search-input-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--primary)}.search-main-input{width:100%;padding:1rem 1rem 1rem 3.5rem;border-radius:var(--radius-md);border:1px solid var(--border-focus);background:var(--bg-app);color:var(--text-main);outline:none;font-size:1.1rem;transition:box-shadow .2s,border-color .2s}.search-main-input:focus{box-shadow:0 0 0 2px var(--primary-glow);border-color:var(--primary)}.btn-search-submit{padding:0 2rem;font-size:1.1rem;white-space:nowrap}.search-results-header{margin:2rem 0 1.5rem;font-size:1.2rem;font-weight:600;color:var(--text-primary);border-bottom:1px solid var(--border-subtle);padding-bottom:.5rem}.results-list{display:flex;flex-direction:column;gap:2rem}.book-result-group{padding:0;overflow:hidden;border:1px solid var(--border-subtle);border-radius:var(--radius-md);animation:fadeIn .3s ease-in-out}.book-group-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#ffffff08;border-bottom:1px solid var(--border-subtle)}.book-group-info{display:flex;flex-direction:column;gap:.25rem}.book-group-title{margin:0;font-size:1.15rem;color:var(--primary);font-weight:600}.book-group-author{font-size:.9rem;color:var(--text-muted)}.match-count-badge{background:var(--primary-color-alpha, rgba(59, 130, 246, .1));color:var(--primary);padding:.25rem .75rem;border-radius:99px;font-size:.85rem;font-weight:500;border:1px solid var(--primary-color-alpha, rgba(59, 130, 246, .2))}.book-matches-list{display:flex;flex-direction:column;gap:1.5rem}.match-item{background:#ffffff08;border-radius:var(--radius-sm);padding:1rem;border-left:3px solid var(--primary)}.match-meta-link{display:inline-flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:600;color:var(--primary);text-decoration:none;margin-bottom:.5rem;padding:.2rem .5rem;background:rgba(var(--primary-rgb),.1);border-radius:4px;transition:all .2s}.match-meta-link:hover{background:var(--primary);color:#fff}.book-group-titlelink{text-decoration:none;color:inherit}.book-group-titlelink:hover .book-group-title{color:var(--primary);text-decoration:underline}.group-actions{display:flex;justify-content:center;margin-top:1rem}.btn-show-more-hits{width:auto;padding:.5rem 1.5rem;background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-full);color:var(--text-muted);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-show-more-hits:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-show-more-hits.expanded{border-style:solid;color:var(--text-secondary)}.scroll-top-btn{position:fixed;bottom:2.5rem;right:2.5rem;width:3.5rem;height:3.5rem;border-radius:50%;background:var(--primary);color:#fff;border:none;font-size:1.5rem;cursor:pointer;box-shadow:0 4px 12px #00000040;z-index:1000;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.175,.885,.32,1.275);opacity:.9}.scroll-top-btn:hover{transform:translateY(-5px) scale(1.05);box-shadow:0 8px 16px #0000004d;opacity:1}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:var(--text-muted)}.loader-wrapper{display:flex;align-items:center;justify-content:center}.match-meta{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-muted);margin-bottom:.5rem;font-weight:500}.match-snippet{display:flex;gap:.75rem;align-items:flex-start}.quote-icon-sm{color:var(--text-muted);flex-shrink:0;margin-top:3px;opacity:.5}.snippet-content{font-size:.95rem;color:var(--text-secondary);line-height:1.6}.snippet-content em{font-style:normal;background:#ffd70033;color:var(--text-highlight);border-bottom:2px solid rgba(255,215,0,.5);padding:0 2px;border-radius:2px;font-weight:600}.no-results{text-align:center;padding:4rem;color:var(--text-muted);background:#ffffff05;border-radius:var(--radius-lg)}.no-results-icon{opacity:.2;margin-bottom:1rem}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.settings-container{padding:2rem;max-width:900px;margin:0 auto}.settings-list{display:flex;flex-direction:column;gap:1.5rem}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;background:#ffffff08;border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:border-color .2s}.setting-item:hover{border-color:var(--primary-color-alpha);background:#ffffff0d}.setting-info{flex:1;padding-right:2rem}.setting-label{margin:0 0 .25rem;font-size:1.05rem;color:var(--text-primary);font-weight:500}.setting-key-hint{color:var(--text-muted);font-family:monospace;font-size:.8rem;opacity:.3;transition:opacity .2s}.setting-item:hover .setting-key-hint{opacity:.7}.setting-control{display:flex;gap:1rem;align-items:center;min-width:300px}.form-control{flex:1;padding:.6rem 1rem;border-radius:6px;border:1px solid var(--border-subtle);background:#0003;color:var(--text-main);font-size:.95rem}.form-control:focus{border-color:var(--primary);outline:none;background:#0000004d}.btn-save{padding:.6rem 1.25rem;background:var(--primary);color:#fff;border-radius:6px;font-weight:500;min-width:70px;display:flex;justify-content:center;align-items:center}.btn-save:hover{filter:brightness(1.1)}.btn-save:disabled{opacity:.7;cursor:wait}.settings-actions{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-subtle);display:flex;justify-content:flex-end}.btn-save-all{display:flex;align-items:center;gap:.5rem;padding:.8rem 2rem;font-size:1.1rem;font-weight:600;border-radius:var(--radius-md);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transition:all .2s}.btn-save-all:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.btn-save-all:disabled{opacity:.7;transform:none;cursor:wait}.loading-state{display:flex;align-items:center;justify-content:center;padding:3rem;color:var(--text-muted)}.ml-2{margin-left:.75rem}.ocr-container{padding:20px}.controls{margin-bottom:20px;display:flex;gap:15px;align-items:center}.controls select{padding:8px;font-size:16px;border-radius:4px;border:1px solid #ccc;min-width:150px}.controls button{padding:8px 16px;font-size:14px;background-color:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer}.controls button:disabled{background-color:#ccc;cursor:not-allowed}.ocr-table{width:100%;border-collapse:collapse;background:#fff;box-shadow:0 1px 3px #0000001a}.ocr-table th,.ocr-table td{padding:12px;text-align:left;border-bottom:1px solid #eee}.ocr-table th{background-color:#f8f9fa;font-weight:600}.status-pending{color:#fece32e0;font-weight:700}.status-processing{color:#007bff;font-weight:700}.status-completed{color:#28a745;font-weight:700}.status-error{color:#dc3545;font-weight:700}.action-btn{padding:6px 12px;cursor:pointer;border:none;border-radius:4px;margin-right:5px}.btn-process{background-color:#17a2b8;color:#fff}.btn-sync{background-color:#28a745;color:#fff}.main-content{margin-left:var(--nav-width);width:calc(100% - var(--nav-width))}.page-header{margin-bottom:2rem}.subtitle{color:var(--text-muted);font-size:1.1rem}.mobile-menu-toggle{display:none;position:fixed;top:1rem;left:1rem;z-index:90;background:var(--bg-glass-strong);color:var(--text-main);border:1px solid var(--border-subtle);padding:.5rem;border-radius:var(--radius-md);cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}@media(max-width:768px){.main-content{margin-left:0;width:100%;padding-top:4rem}.mobile-menu-toggle{display:flex;align-items:center;justify-content:center}}
