*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;overflow-x:hidden}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{min-height:100vh;padding:20px;position:relative}.App,.bubble-transition{align-items:center;display:flex;justify-content:center}.bubble-transition{bottom:0;left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:10000}.bubble{animation:bubbleShrinkPop 1.2s cubic-bezier(.68,-.55,.265,1.55);background:radial-gradient(circle at 30% 30%,#6366f14d,#6366f199);border-radius:50%;box-shadow:0 0 0 0 #6366f166,inset 0 0 20px #ffffff80;height:100px;width:100px}@keyframes bubbleShrinkPop{0%{opacity:0;transform:scale(0)}20%{opacity:.8;transform:scale(15)}50%{opacity:1;transform:scale(18)}70%{opacity:.6;transform:scale(.8)}85%{opacity:.3;transform:scale(1.2)}to{opacity:0;transform:scale(0)}}.ready-animation-overlay{align-items:center;animation:overlayFadeInOut 2s ease-in-out;bottom:0;display:flex;justify-content:center;left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:9999}@keyframes overlayFadeInOut{0%{opacity:0}20%{opacity:1}80%{opacity:1}to{opacity:0}}.ready-animation{align-items:center;display:flex;flex-direction:column;gap:20px}.book-opening{height:80px;perspective:1000px;position:relative;width:120px}.book-page{background:#fff;border:2px solid #6366f1;box-shadow:0 4px 15px #6366f14d;height:80px;position:absolute;width:60px}.left-page{animation:openLeftPage 1.5s ease-out;border-right:1px solid #6366f1;left:0;transform-origin:right center}.right-page{animation:openRightPage 1.5s ease-out;border-left:1px solid #6366f1;right:0;transform-origin:left center}@keyframes openLeftPage{0%{transform:rotateY(0deg)}50%{transform:rotateY(-85deg)}to{transform:rotateY(-85deg)}}@keyframes openRightPage{0%{transform:rotateY(0deg)}50%{transform:rotateY(85deg)}to{transform:rotateY(85deg)}}.ready-text{animation:readyTextBounce 1.5s cubic-bezier(.34,1.56,.64,1);font-size:1.8rem;text-align:center}@keyframes readyTextBounce{0%{opacity:0;transform:scale(.5) translateY(30px)}60%{opacity:1;transform:scale(1.1) translateY(0)}80%{transform:scale(.95) translateY(0)}to{opacity:1;transform:scale(1) translateY(0)}}.container{animation:containerFadeIn .4s ease-out;background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;max-width:1000px;padding:5px 35px 15px;position:relative;transition:all .6s cubic-bezier(.34,1.56,.64,1);width:100%}.container.minimal{box-shadow:0 4px 20px #00000014;max-width:600px;padding:75px 35px 45px}.container.loaded{box-shadow:0 4px 20px #00000014;max-width:800px;padding:25px 35px 30px}@keyframes containerFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.landing-slogan{animation:sloganFadeIn .8s ease-out;color:#1e293b;font-size:2rem;font-weight:700;line-height:1.3;margin:0 0 24px;text-align:center}.slogan-highlight{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;background-clip:text;color:#6366f1;font-weight:800}@keyframes sloganFadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.landing-controls{align-items:center;animation:sloganFadeIn .8s ease-out .2s both;gap:16px}.landing-add-books,.landing-controls{display:flex;justify-content:center;margin-bottom:40px}.landing-add-books{animation:sloganFadeIn .8s ease-out .4s both}.landing-add-books-button{align-items:center;animation:pulseGlow 2s ease-in-out infinite;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:12px;box-shadow:0 4px 20px #6366f14d;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:10px;padding:12px 24px;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.landing-add-books-button:hover{box-shadow:0 8px 30px #6366f180;transform:translateY(-4px) scale(1.05)}.landing-add-books-button:active{transform:translateY(-2px) scale(1.02)}.plus-icon-large{animation:rotateIcon 3s ease-in-out infinite;height:20px;width:20px}.add-books-text{font-size:1rem;letter-spacing:.3px}@keyframes pulseGlow{0%,to{box-shadow:0 4px 20px #6366f14d}50%{box-shadow:0 4px 30px #6366f199,0 0 0 8px #6366f11a}}@keyframes rotateIcon{0%,to{transform:rotate(0deg)}25%{transform:rotate(90deg)}50%{transform:rotate(90deg)}75%{transform:rotate(0deg)}}.info-button-inline{align-items:center;background:#fff;border:2px solid #c7d2fe;border-radius:8px;box-shadow:0 2px 8px #0000001a;color:#6366f1;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:8px;padding:8px 16px;transition:all .3s ease}.info-button-inline:hover{background:#eef2ff;border-color:#6366f1;box-shadow:0 4px 12px #6366f133;transform:translateY(-2px)}.dev-toggle-inline{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:8px 16px}.dev-toggle-corner{align-items:center;background:#fff;border:none;border-radius:50px;bottom:5px;cursor:pointer;display:flex;height:40px;justify-content:center;padding:0;position:fixed;right:10px;text-decoration:underline;transition:all .3s ease;width:100px;z-index:1000}.dev-toggle-corner:hover{transform:scale(1.05)}.dev-indicator{background:#cbd5e1;border-radius:50%;height:12px;transition:all .3s ease;width:12px}.dev-indicator.active{background:#041a32;box-shadow:0 0 8px #041a3266}.header{align-items:center;display:flex;justify-content:center;margin-bottom:30px}h1{color:#333;font-size:2rem;font-weight:600;margin:0;text-align:center}.welcome-section{animation:fadeInScale .6s cubic-bezier(.34,1.56,.64,1);margin-bottom:32px}.welcome-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;background-clip:text;color:#1a1a1a;font-size:1.8rem;font-weight:700;margin-bottom:16px;text-align:center}.welcome-description{color:#555;font-size:1.05rem;line-height:1.7;margin-bottom:20px;margin-left:auto;margin-right:auto;max-width:600px;text-align:center}.info-button-floating{align-items:center;background:#fff;border:2px solid #c7d2fe;border-radius:8px;box-shadow:0 2px 8px #0000001a;color:#6366f1;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:8px;left:20px;padding:8px 16px;position:fixed;top:20px;transition:all .3s ease;z-index:100}.info-button-floating:hover{background:#eef2ff;border-color:#6366f1;box-shadow:0 4px 12px #6366f133;transform:translateY(-2px)}.info-button{align-items:center;background:#0000;border:2px solid #c7d2fe;border-radius:8px;color:#6366f1;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:8px;margin:0 auto;padding:10px 20px;transition:all .3s ease}.info-button:hover{background:#eef2ff;border-color:#6366f1;transform:translateY(-2px)}.info-icon{height:20px;width:20px}.modal-overlay{align-items:center;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10001}.modal-content{animation:modalSlideIn .3s cubic-bezier(.34,1.56,.64,1);background:#fff;border-radius:16px;box-shadow:0 10px 40px #0003;max-width:500px;padding:32px;position:relative;width:90%}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-close{align-items:center;background:#0000;border:none;border-radius:4px;color:#999;cursor:pointer;display:flex;font-size:2rem;height:32px;justify-content:center;line-height:1;position:absolute;right:16px;top:16px;transition:all .2s ease;width:32px}.modal-close:hover{background:#f5f5f5;color:#333}.modal-content h3{color:#6366f1;font-size:1.3rem;font-weight:600;margin:0 0 16px;padding-right:40px}.modal-content h4{color:#6366f1;font-size:1.1rem;font-weight:600;margin:24px 0 16px}.modal-description{color:#64748b;font-size:.95rem;line-height:1.6;margin:0 0 20px}.how-it-works{background:linear-gradient(135deg,#eef2ff,#f5f3ff);border-radius:12px;margin-bottom:24px;padding:24px}.how-it-works h3{color:#6366f1;font-size:1.1rem;font-weight:600;margin:0 0 16px}.steps-list{list-style:none;margin:0;padding:0}.steps-list li{align-items:center;color:#444;display:flex;font-size:.95rem;gap:12px;line-height:1.6;margin-bottom:12px}.steps-list li:last-child{margin-bottom:0}.step-number{align-items:center;background:#6366f1;border-radius:50%;color:#fff;display:inline-flex;flex-shrink:0;font-size:.85rem;font-weight:600;height:24px;justify-content:center;width:24px}.input-hint{color:#888;display:block;font-size:.85rem;font-style:italic;margin-top:6px}h2{animation:slideInFromLeft .5s ease-out;color:#333;font-size:1.4rem;font-weight:500;margin-bottom:20px}@keyframes slideInFromLeft{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}form{animation:formFadeIn .6s ease-out}@keyframes formFadeIn{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.query-header{margin-bottom:20px;position:relative}.toggle-label{align-items:center;cursor:pointer;display:flex;gap:10px;position:relative}.toggle-label input[type=checkbox]{height:0;opacity:0;position:absolute;width:0}.toggle-slider{background-color:#ccc;border-radius:12px;height:24px;position:relative;transition:background-color .3s;width:44px}.toggle-slider:before{background-color:#fff;border-radius:50%;content:"";height:18px;left:3px;position:absolute;top:3px;transition:transform .3s;width:18px}.toggle-label input[type=checkbox]:checked+.toggle-slider{background-color:#041a32}.toggle-label input[type=checkbox]:checked+.toggle-slider:before{transform:translateX(20px)}.toggle-text{color:#666;font-size:14px;font-weight:500}.step-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.reset-button{background-color:initial;border:2px solid #6366f1;border-radius:8px;color:#6366f1;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .3s cubic-bezier(.34,1.56,.64,1);white-space:nowrap}.reset-button:hover{background-color:#6366f1;box-shadow:0 4px 12px #6366f14d;color:#fff;transform:translateY(-2px)}.reset-button:active{transform:translateY(0)}.input-label{color:#444;display:block;font-size:.9rem;font-weight:600;margin-bottom:8px}.embeddings-loading{animation:fadeInScale .6s cubic-bezier(.34,1.56,.64,1);padding:40px 20px;text-align:center}.embeddings-icon{height:120px;margin:0 auto 30px;position:relative;width:120px}.floating-particles{height:100%;position:absolute;width:100%}.particle{animation:floatParticle 3s ease-in-out infinite;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:50%;height:8px;opacity:0;position:absolute;width:8px}.particle:first-child{animation-delay:0s;left:20%;top:20%}.particle:nth-child(2){animation-delay:.6s;right:20%;top:10%}.particle:nth-child(3){animation-delay:1.2s;bottom:20%;left:10%}.particle:nth-child(4){animation-delay:1.8s;bottom:10%;right:10%}.particle:nth-child(5){animation-delay:2.4s;left:50%;top:50%}@keyframes floatParticle{0%{opacity:0;transform:translateY(0) scale(0)}50%{opacity:1;transform:translateY(-30px) scale(1)}to{opacity:0;transform:translateY(-60px) scale(0)}}.book-icon{animation:pulse 2s ease-in-out infinite;height:70px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:60px}.book-cover{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:4px;box-shadow:0 4px 15px #6366f166;width:100%}.book-cover,.book-spine{height:100%;position:absolute}.book-spine{background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:2px 0 0 2px;left:0;width:8px}.embeddings-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;background-clip:text;color:#333;font-size:1.5rem;font-weight:700;margin-bottom:10px}.embeddings-description{color:#666;font-size:1rem;margin-bottom:24px}.ready-message{animation:readyBounceIn .8s cubic-bezier(.34,1.56,.64,1);padding:60px 20px;text-align:center}.ready-icon{animation:scaleIn .5s cubic-bezier(.34,1.56,.64,1);height:100px;margin:0 auto 20px;width:100px}@keyframes scaleIn{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.checkmark,.checkmark-circle{height:100%;width:100%}.checkmark{stroke-width:3;stroke:#6366f1;stroke-miterlimit:10;border-radius:50%;box-shadow:0 4px 20px #6366f14d;display:block}.checkmark-circle-bg{stroke:#6366f1;stroke-dasharray:166;stroke-dashoffset:166;animation:stroke .6s cubic-bezier(.65,0,.45,1) forwards}.checkmark-check{stroke:#6366f1;stroke-dasharray:48;stroke-dashoffset:48;stroke-linecap:round;animation:stroke .3s cubic-bezier(.65,0,.45,1) .4s forwards}@keyframes stroke{to{stroke-dashoffset:0}}.ready-text{-webkit-text-fill-color:#0000;animation:readyTextPop .8s cubic-bezier(.34,1.56,.64,1) .2s backwards;background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:700}@keyframes readyBounceIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes readyTextPop{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.progress-container{animation:fadeIn .3s ease-in;margin-top:20px}.progress-bar{background-color:#e0e0e0;border-radius:4px;height:8px;margin-bottom:10px;overflow:hidden;width:100%}.progress-fill{background-color:#6366f1;border-radius:4px;height:100%;transition:width .5s ease}.progress-text{color:#666;font-size:14px;margin:0;text-align:center}.search-loading{animation:fadeInScale .4s ease-out;margin-top:40px;text-align:center}.model-loading-icon{margin-bottom:20px}.brain-icon,.model-loading-icon{display:flex;justify-content:center}.brain-icon{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:50%;box-shadow:0 4px 20px #6366f166;height:80px;position:relative;width:80px}.brain-wave{animation:brainWave 2s ease-out infinite;border:2px solid #6366f1;border-radius:50%;height:100%;opacity:0;position:absolute;width:100%}.brain-wave:nth-child(2){animation-delay:.5s}.brain-wave:nth-child(3){animation-delay:1s}@keyframes brainWave{0%{opacity:.8;transform:scale(1)}to{opacity:0;transform:scale(2)}}.model-response-debug{animation:fadeInScale .4s ease-out;background:linear-gradient(135deg,#eef2ff,#f5f3ff);border:2px solid #c7d2fe;border-radius:12px;margin-top:30px;padding:20px}.model-response-debug h4{color:#6366f1;font-size:1rem;font-weight:600;letter-spacing:.5px;margin:0 0 16px;text-transform:uppercase}.debug-item{margin-bottom:16px}.debug-item:last-child{margin-bottom:0}.debug-item strong{color:#4f46e5;display:block;font-size:.85rem;font-weight:600;letter-spacing:.3px;margin-bottom:6px;text-transform:uppercase}.debug-value{background:#fff;border-radius:8px;color:#333;font-family:Monaco,Courier New,monospace;font-size:.95rem;line-height:1.5;margin:0;padding:12px;word-break:break-word}.book-animation{align-items:center;display:flex;flex-direction:column;gap:20px}.book-icon{animation:bookFloat 2s ease-in-out infinite;font-size:48px}.search-dots{display:flex;gap:8px;justify-content:center;line-height:50px}.dot{animation:dotBounce 1.4s ease-in-out infinite;background-color:#6366f1;border-radius:50%;height:12px;width:12px}.dot:first-child{animation-delay:0s}.dot:nth-child(2){animation-delay:.2s}.dot:nth-child(3){animation-delay:.4s}@keyframes dotBounce{0%,60%,to{opacity:1;transform:translateY(0) scale(1)}30%{opacity:.8;transform:translateY(-20px) scale(1.2)}}.loading-text{animation:textPulse 2s ease-in-out infinite;color:#666;font-size:14px;margin:30px 0 0}@keyframes textPulse{0%,to{opacity:.6}50%{opacity:1}}.book-title-display{align-items:center;color:#6366f1;display:flex;font-size:.95rem;font-weight:500;gap:10px;margin:18px 0 10px 5px;padding:12px 0;text-align:left}.books-loaded-indicator{align-items:center;display:flex;gap:12px;margin-bottom:16px;padding:8px 0}.book-icon-small{transition:all .3s ease}.book-icon-small,.checkmark-icon-small{color:#6366f1;flex-shrink:0;height:20px;width:20px}.checkmark-icon-small{animation:checkmarkAppear 1.2s cubic-bezier(.34,1.56,.64,1)}@keyframes checkmarkAppear{0%{opacity:0;transform:scale(0) rotate(-180deg)}60%{transform:scale(1.15) rotate(5deg)}to{opacity:1;transform:scale(1) rotate(0deg)}}.book-icon-open{animation:openBookAppear .8s cubic-bezier(.34,1.56,.64,1);color:#6366f1;flex-shrink:0;height:20px;width:20px}@keyframes openBookAppear{0%{opacity:0;transform:scale(.8) rotateY(-90deg)}60%{transform:scale(1.08) rotateY(5deg)}to{opacity:1;transform:scale(1) rotateY(0deg)}}.book-name{color:#1e293b;font-weight:600}.book-author{color:#64748b;font-size:.9em;font-weight:400}.book-label{color:#94a3b8;font-weight:400;margin-right:4px}.main-title-section{margin-bottom:40px;padding:40px 0 0;text-align:center}.main-title{color:#6366f1;font-size:1.8rem;font-weight:600;line-height:1.3;margin:0}.search-form{margin-bottom:20px}.form-group{margin:5px 0}.query-input-group{align-items:stretch;display:flex;gap:12px;margin:0}.query-input-group .search-input{flex:1 1}.send-button{align-items:center;background:#6366f1;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:500;gap:8px;height:52px;justify-content:center;padding:0 20px;transition:all .2s ease;white-space:nowrap}.send-button:hover:not(:disabled){background:#4f46e5;box-shadow:0 4px 12px #6366f14d;transform:translateY(-1px)}.send-button:active:not(:disabled){transform:translateY(0)}.send-button:disabled{background:#cbd5e1;cursor:not-allowed;opacity:.6}.paper-plane-icon{height:18px;transition:transform .2s ease;width:18px}.send-button:hover:not(:disabled) .paper-plane-icon{transform:translateX(2px) translateY(-2px)}.send-text{font-weight:500}.input-group{display:flex;gap:10px}.search-input{border:2px solid #e0e0e0;border-radius:8px;font-size:16px;outline:none;padding:12px 16px;transition:all .3s cubic-bezier(.34,1.56,.64,1);width:100%}.search-input:focus{border-color:#142f4d;box-shadow:0 0 0 3px #6366f11a;transform:translateY(-1px)}.search-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.query-input{border-width:2px;font-size:16px;padding:14px 12px}.query-input::placeholder{text-align:left}.search-button{background-color:#6366f1;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;margin:20px 0 0;padding:12px 24px;transition:all .3s cubic-bezier(.34,1.56,.64,1);white-space:nowrap;width:100%}.search-button:hover:not(:disabled){background-color:#4f46e5;box-shadow:0 4px 12px #6366f166;transform:translateY(-2px)}.search-button:active:not(:disabled){box-shadow:0 2px 6px #6366f14d;transform:translateY(0)}.search-button:disabled{background-color:#a0a0a0;cursor:not-allowed}.message{animation:slideInUp .5s cubic-bezier(.34,1.56,.64,1);border-radius:8px;margin-top:20px;padding:16px}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.error-message{background-color:#fee;border:1px solid #fcc;color:#c33}.response-message{background-color:#eef2ff;border:1px solid #c7d2fe;color:#333}.response-message h3{color:#132539;font-size:1.1rem;margin-bottom:12px}.response-message pre{background-color:#f8f9fa;border-radius:6px;color:#333;font-size:14px;line-height:1.5;overflow-x:auto;padding:12px}.results-container{animation:fadeInScale .6s cubic-bezier(.34,1.56,.64,1);margin-top:20px}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.results-container h3{animation:fadeIn .4s ease-out;color:#333;font-size:1.2rem;font-weight:600;margin-bottom:32px;text-align:center}.result-card{animation:cardSlideIn .5s ease-out backwards;background-color:#f8f9fa;border:1px solid #e0e0e0;border-radius:12px;margin-bottom:24px;padding:28px;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.result-card:nth-child(2){animation-delay:.1s}.result-card:nth-child(3){animation-delay:.2s}.result-card:nth-child(4){animation-delay:.3s}@keyframes cardSlideIn{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}.result-card:hover{box-shadow:0 4px 12px #0000001f;transform:translateY(-2px)}.result-header{align-items:flex-start;border-bottom:2px solid #e0e0e0;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:16px;padding-bottom:16px}.chapter-info{color:#6366f1;flex:1 1;font-size:14px;font-weight:600}.badges-container{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.score-badge{background-color:#111a25;color:#fff}.progress-badge,.score-badge{border-radius:11px;font-size:12px;font-weight:600;padding:4px 12px;white-space:nowrap}.progress-badge{align-items:center;background-color:#e9e9e9;color:#000;display:flex;gap:4px}.location-icon{stroke-width:2.5;height:12px;width:12px}.result-text{color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:15px;line-height:1.8;white-space:pre-wrap}.highlight-match{background:linear-gradient(135deg,#6366f126,#8b5cf626);border-bottom:1px solid #6366f166;border-radius:2px;color:#4338ca;font-weight:600;padding:2px 0}.keyword-highlight{background:linear-gradient(135deg,#6366f14d,#8b5cf64d);border-radius:2px;color:#3730a3;font-weight:800;padding:1px 3px}.ellipsis-text{color:#94a3b8;font-style:italic;opacity:.7}.view-in-book-button{background:#0000;border:1px solid #6366f14d;border-radius:8px;color:#6366f1;cursor:pointer;font-size:.875rem;font-weight:500;margin-top:12px;padding:8px 16px;transition:all .2s ease}.view-in-book-button:hover{background:#6366f114;border-color:#6366f180;color:#4f46e5}.view-in-book-button:active{transform:scale(.98)}@media (max-width:600px){.container{max-width:100%;padding:20px}h1{font-size:1.5rem}h2{font-size:1.2rem}.header{align-items:flex-start;flex-direction:column;gap:15px}.container.minimal{max-width:100%}.landing-slogan{font-size:1.5rem;margin:0 0 20px}.landing-controls{flex-direction:column;gap:12px}.dev-toggle-query{right:-10px;top:-30px}.query-input{font-size:16px;padding:14px 16px}.send-button{padding:12px 16px}.send-text{display:none}.paper-plane-icon{height:20px;width:20px}.step-header{align-items:flex-start;flex-direction:column;gap:10px}.reset-button,.search-button{width:100%}.toggle-text{font-size:12px}.result-header{align-items:flex-start;flex-direction:column}.score-badge{align-self:flex-start}.result-text{font-size:14px}.main-title{font-size:1.4rem;line-height:1}.comparison-container{gap:16px;grid-template-columns:1fr}}.book-urls-textarea{font-family:inherit;line-height:1.5;min-height:100px;resize:vertical;width:100%}.url-input-row{align-items:center;display:flex;gap:8px;margin-bottom:8px}.url-input-row .search-input{flex:1 1;margin-bottom:0}.remove-url-button{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#94a3b8;cursor:pointer;display:flex;font-size:24px;height:36px;justify-content:center;line-height:1;min-width:36px;padding:0;transition:all .2s ease;width:36px}.remove-url-button:hover{background:#fee;border-color:#fca5a5;color:#ef4444}.remove-url-button:disabled{cursor:not-allowed;opacity:.5}.add-url-button{background:#0000;border:2px dashed #c7d2fe;border-radius:8px;color:#6366f1;cursor:pointer;font-size:14px;font-weight:500;margin-bottom:8px;margin-top:8px;padding:10px 16px;transition:all .2s ease;width:100%}.add-url-button:hover{background:#eef2ff;border-color:#6366f1}.add-url-button:disabled{cursor:not-allowed;opacity:.5}.books-progress-container{display:flex;flex-direction:column;gap:12px;margin-top:20px}.book-progress-item{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:12px 16px}.book-progress-header{align-items:center;display:flex;justify-content:space-between}.book-progress-label{color:#1e293b;font-size:14px;font-weight:500}.book-status{border-radius:4px;font-size:13px;font-weight:500;padding:4px 8px}.book-status.pending{background:#f1f5f9;color:#64748b}.book-status.processing{background:#dbeafe;color:#2563eb}.book-status.complete{background:#dcfce7;color:#16a34a}.book-status.error{background:#fee2e2;color:#dc2626}.book-error-text{color:#dc2626;font-size:12px;margin-bottom:0;margin-top:8px}.books-list-display{align-items:flex-start;animation:slideInFromTop .6s cubic-bezier(.34,1.56,.64,1);background:#fff;border:1px solid #e2e8f0;border-radius:12px;display:flex;gap:12px;margin:24px 0;padding:16px}@keyframes slideInFromTop{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.books-names{display:flex;flex:1 1;flex-direction:column;gap:8px}.book-item{align-items:center;display:flex}.book-item .book-name{font-size:15px}.book-title-display,.books-list-display{box-shadow:0 1px 3px #0000000d}@media (max-width:600px){.url-input-row{flex-direction:column;gap:8px}.remove-url-button{width:100%}.books-list-display{flex-direction:column;gap:12px}.book-item .book-name{font-size:14px}}.book-source-badge{background:#eef2ff;border-radius:6px;color:#6366f1;display:inline-block;font-size:12px;font-weight:600;margin-right:8px;padding:4px 10px}.chapter-info{align-items:center;display:flex;flex-wrap:wrap;gap:4px}.add-books-button-container{display:flex;justify-content:center;margin-bottom:24px}.add-books-toggle-button{align-items:center;background:#6366f1;border:none;border-radius:12px;box-shadow:0 2px 8px #6366f133;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:8px;padding:12px 24px;transition:all .2s ease}.add-books-toggle-button:hover{background:#4f46e5;box-shadow:0 4px 12px #6366f14d;transform:translateY(-1px)}.add-books-toggle-button:disabled{cursor:not-allowed;opacity:.5;transform:none}.plus-icon{height:20px;width:20px}.book-upload-form{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #0000000d;margin-bottom:24px;padding:20px}.book-input-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.collapse-button{background:#0000;border:1px solid #e2e8f0;border-radius:6px;color:#64748b;cursor:pointer;font-size:13px;padding:6px 12px;transition:all .2s ease}.collapse-button:hover{background:#f1f5f9;border-color:#cbd5e1}.collapse-button:disabled{cursor:not-allowed;opacity:.5}.query-form-main{align-items:center;display:flex;gap:12px;margin-top:0}.query-input-group{flex:1 1;position:relative}.query-input-group .query-input{padding-right:52px}.topk-input-below{display:flex;flex-direction:column;gap:6px;margin-top:16px}.topk-label{color:#64748b;font-size:13px;font-weight:500}.topk-input{background:#fff;border:2px solid #e2e8f0;border-radius:8px;font-size:15px;padding:10px 12px;transition:all .3s ease}.topk-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.topk-input:disabled{background:#f8fafc;cursor:not-allowed;opacity:.6}.plus-button-inline{align-items:center;background:#6366f1;border:none;border-radius:50%;cursor:pointer;display:flex;flex-shrink:0;height:32px;justify-content:center;padding:0;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:all .2s ease;width:32px;z-index:2}.plus-button-inline:hover{background:#4f46e5;transform:translateY(-50%) scale(1.1)}.plus-button-inline:disabled{cursor:not-allowed;opacity:.5;transform:translateY(-50%)}.plus-button-inline .plus-icon{color:#fff;height:20px;width:20px}.add-books-tooltip{background:#000000d9;border-radius:8px;bottom:calc(100% + 12px);box-shadow:0 2px 8px #0003;color:#fff;font-size:13px;font-weight:500;opacity:0;padding:8px 14px;pointer-events:none;transition:opacity .2s ease,visibility .2s ease;visibility:hidden;white-space:nowrap;z-index:3}.add-books-tooltip,.add-books-tooltip:after{left:50%;position:absolute;transform:translateX(-50%)}.add-books-tooltip:after{border-left:6px solid #0000;border-right:6px solid #0000;border-top:6px solid #000000d9;content:"";height:0;top:100%;width:0}.add-books-tooltip.show,.plus-button-inline:hover .add-books-tooltip{opacity:1;visibility:visible}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.query-input-group .query-input{padding-left:16px}.book-modal-content{max-height:80vh;max-width:650px;overflow-y:auto}.book-upload-form{margin-top:20px}.book-upload-form .form-group{margin-bottom:16px}.book-upload-form .search-button{margin-top:8px;width:100%}.inline-books-progress{animation:fadeInUp .3s ease;background:#0000;border:none;border-radius:8px;margin:0 0 24px;max-width:100%;padding:0}.inline-books-progress.fade-out{animation:fadeOutDown .5s ease forwards}@keyframes fadeOutDown{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(20px)}}.inline-progress-list{display:flex;flex-direction:column;gap:8px}.inline-book-item{align-items:center;background:#0000;border:none;border-radius:6px;display:flex;gap:10px;min-height:40px;padding:8px 6px;transition:all .3s ease}.inline-book-number{color:#64748b;font-size:14px;font-weight:500;min-width:60px}.inline-book-status-icon{align-items:center;display:flex;height:24px;justify-content:center;width:24px}.floating-book-icon{animation:bookFloat 2s ease-in-out infinite;height:24px;position:relative;width:18px}@keyframes bookFloat{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-4px) rotate(2deg)}}.floating-book-icon .book-cover{background:linear-gradient(135deg,#6366f1,#4f46e5);border-radius:1.5px;box-shadow:0 2px 6px #6366f140;height:24px;left:2px;position:absolute;width:14px}.floating-book-icon .book-spine{background:linear-gradient(180deg,#4338ca,#3730a3);border-radius:1.5px 0 0 1.5px;height:24px;left:0;position:absolute;width:2px}.check-icon-container{align-items:center;background:#0000;border-radius:0;display:flex;height:24px;justify-content:center;width:24px}.check-icon{stroke-width:3;stroke-dasharray:20;stroke-dashoffset:20;animation:checkDraw .5s ease forwards,checkPop .3s ease forwards;color:#6366f1;height:24px;width:24px}@keyframes checkDraw{to{stroke-dashoffset:0}}@keyframes checkPop{0%{transform:scale(.8)}50%{transform:scale(1.15)}to{transform:scale(1)}}.static-book-icon{animation:bookFadeIn .5s ease .3s both;height:24px;position:relative;width:18px}@keyframes bookFadeIn{0%{opacity:0;transform:scale(.8) rotate(-90deg)}to{opacity:1;transform:scale(1) rotate(0deg)}}.static-book-icon .book-cover{background:linear-gradient(135deg,#6366f1,#4f46e5);border-radius:1.5px;box-shadow:0 2px 6px #6366f140;height:24px;left:2px;position:absolute;width:14px}.static-book-icon .book-spine{background:linear-gradient(180deg,#4338ca,#3730a3);border-radius:1.5px 0 0 1.5px;height:24px;left:0;position:absolute;width:2px}.error-icon-container{align-items:center;animation:errorShake .4s ease;background:#ef4444;border-radius:50%;display:flex;height:24px;justify-content:center;width:24px}@keyframes errorShake{0%,to{transform:translateX(0)}25%{transform:translateX(-3px)}75%{transform:translateX(3px)}}.error-icon{color:#fff;height:14px;width:14px}.inline-error-text{color:#ef4444;flex:1 1;font-size:12px;font-weight:500}.loading-notification{align-items:center;animation:notificationSlideIn .4s ease;background:linear-gradient(135deg,#6366f114,#4f46e51f);border:1px solid #6366f133;border-radius:12px;box-shadow:0 1px 3px #0000000d;display:flex;gap:12px;margin:10px 0 25px;max-width:100%;padding:12px 16px}.loading-notification.fade-out{animation:fadeOutUp .5s ease forwards}@keyframes fadeOutUp{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}@keyframes notificationSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.loading-notification .loading-spinner{animation:spin .8s linear infinite;border:2.5px solid #6366f133;border-radius:50%;border-top-color:#6366f1;flex-shrink:0;height:18px;width:18px}.loading-notification .encouraging-message{animation:messageFade .5s ease;color:#4338ca;font-size:14px;font-weight:500;margin:0}@keyframes spin{to{transform:rotate(1turn)}}@keyframes messageFade{0%{opacity:0;transform:translateX(-5px)}to{opacity:1;transform:translateX(0)}}.password-gate{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:9999}.password-container{animation:fadeInUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;max-width:400px;padding:40px;text-align:center;width:100%}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.password-container h1{color:#333;font-size:1.8rem;font-weight:600;margin-bottom:10px}.password-container p{color:#666;font-size:1rem;margin-bottom:30px}.password-form{display:flex;flex-direction:column;gap:12px}.password-input{border:2px solid #e0e0e0;border-radius:8px;font-size:16px;letter-spacing:2px;outline:none;padding:12px 16px;text-align:center;transition:border-color .3s}.password-input:focus{border-color:#6366f1}.password-button{background-color:#6366f1;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;padding:12px 24px;transition:background-color .3s}.password-button:hover{background-color:#4f46e5}.password-button:active{transform:scale(.98)}.password-error{animation:shake .5s;background-color:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;font-size:14px;margin-top:15px;padding:12px}@keyframes shake{0%,to{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-5px)}20%,40%,60%,80%{transform:translateX(5px)}}@media (max-width:600px){.password-container{padding:30px 20px}.password-container h1{font-size:1.5rem}}
/*# sourceMappingURL=main.d5889248.css.map*/