:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}*{box-sizing:border-box;margin:0;padding:0}body{color:#333;background-color:#f5f7fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;line-height:1.5}.container{max-width:1200px;margin:0 auto;padding:2rem}.title{color:#4a90e2;border-bottom:1px solid #4a90e2;margin-bottom:1.5rem;padding-bottom:.5rem;font-size:2.5rem;display:inline-block}.loading,.error{text-align:center;padding:2rem;font-size:1.2rem}.error{color:#e53935;background-color:#ffebee;border-radius:8px}.books-container{flex-wrap:wrap;margin:-10px;display:flex}.book-card{background-color:#fff;border-radius:8px;flex-direction:column;flex:0 0 calc(33.333% - 20px);margin:10px;transition:all .3s;display:flex;overflow:hidden;box-shadow:0 2px 8px #0000001a}.book-card:hover{transform:translateY(-5px);box-shadow:0 8px 16px #00000026}@media (width<=1024px){.book-card{flex:0 0 calc(50% - 20px)}}@media (width<=600px){.book-card{flex:0 0 calc(100% - 20px)}}.book-header{border-bottom:1px solid #eee;padding:1.5rem}.book-genre{color:#fff;background-color:#4a90e2;border-radius:50px;margin-bottom:.75rem;padding:.25rem .75rem;font-size:.75rem;font-weight:500;display:inline-block}.book-title{color:#333;margin-bottom:.5rem;font-size:1.5rem;font-weight:600}.book-author{color:#666;font-size:1rem}.book-details{flex-direction:column;flex-grow:1;padding:1.5rem;display:flex}.book-meta{color:#666;border-bottom:1px solid #eee;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem;font-size:.9rem;display:flex}.book-description{color:#333;font-size:.95rem}.recommendation-container{background-color:#fff;border-radius:8px;margin-bottom:2rem;padding:2rem;box-shadow:0 2px 10px #00000014}.recommendation-title{color:#4a90e2;margin-bottom:1.2rem;font-size:1.8rem;font-weight:600}.recommendation-form{flex-direction:column;gap:1.2rem;display:flex}.recommendation-input-container{flex-direction:column;gap:.7rem;display:flex}.recommendation-input-container label{color:#555;font-size:1rem;font-weight:500}.recommendation-input{resize:vertical;background-color:#fafafa;border:1px solid #e0e0e0;border-radius:6px;min-height:100px;padding:1rem;font-family:inherit;font-size:1rem;transition:all .3s}.recommendation-input:focus{background-color:#fff;border-color:#4a90e2;outline:none;box-shadow:0 0 0 3px #4a90e21a}.recommendation-button{color:#fff;cursor:pointer;background-color:#4a90e2;border:none;border-radius:6px;align-self:flex-start;min-width:200px;padding:.9rem;font-size:1.05rem;font-weight:600;transition:all .3s;box-shadow:0 2px 6px #4a90e233}.recommendation-button:hover{background-color:#3a80d2;transform:translateY(-2px);box-shadow:0 4px 10px #4a90e24d}.recommendation-button:disabled{cursor:not-allowed;box-shadow:none;background-color:#9fc6f0;transform:none}.recommendations-result{flex-direction:column;gap:1.5rem;display:flex}.recommendations-header{flex-direction:column;gap:.8rem;margin-bottom:.5rem;display:flex}.recommendations-header h3{color:#333;margin:0;font-size:1.4rem}.recommendation-query{color:#666;background-color:#f5f7fa;border-left:3px solid #4a90e2;border-radius:0 4px 4px 0;margin:0;padding:.5rem .8rem;font-style:italic}.reset-button{color:#4a90e2;cursor:pointer;background-color:#f5f7fa;border:1px solid #4a90e2;border-radius:6px;align-self:flex-start;padding:.6rem 1rem;font-size:.95rem;font-weight:500;transition:all .2s}.reset-button:hover{color:#fff;background-color:#4a90e2}.section-title{color:#333;margin:2rem 0 1.5rem;font-size:1.8rem;font-weight:600}.recommended-book{border:2px solid #4a90e2;position:relative}.recommended-badge{color:#fff;background-color:#4a90e2;border-radius:50px;padding:.25rem .75rem;font-size:.75rem;font-weight:500;position:absolute;top:1rem;right:1rem}.no-recommendations{text-align:center;color:#666;background-color:#f5f7fa;border-radius:6px;padding:2rem;font-size:1.1rem}.similarity-score{color:#1e88e5;background-color:#e3f2fd;border-radius:50px;padding:.3rem .7rem;font-size:.85rem;font-weight:600}body{background-color:#f5f7fa;min-height:100vh;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}#root{flex-direction:column;min-height:100vh;display:flex}*{transition:background-color .2s,color .2s,border-color .2s,box-shadow .2s}.auth-container{background-color:#fff;border-radius:8px;width:100%;max-width:480px;margin:4rem auto;padding:2.5rem;box-shadow:0 4px 20px #00000014}.auth-title{color:#4a90e2;text-align:center;margin-bottom:1.8rem;font-size:2rem;font-weight:600}.auth-error{color:#e53935;background-color:#ffebee;border-radius:6px;margin-bottom:1.5rem;padding:.85rem;font-size:.95rem;box-shadow:0 2px 5px #e539351a}.auth-form{flex-direction:column;gap:1.25rem;display:flex}.form-group{flex-direction:column;gap:.6rem;display:flex}.form-group label{color:#444;margin-left:.2rem;font-size:.95rem;font-weight:500}.form-group input{background-color:#fafafa;border:1px solid #e0e0e0;border-radius:6px;padding:.9rem 1rem;font-size:1rem;transition:all .3s}.form-group input:focus{background-color:#fff;border-color:#4a90e2;outline:none;box-shadow:0 0 0 3px #4a90e21a}.auth-button{color:#fff;cursor:pointer;background-color:#4a90e2;border:none;border-radius:6px;margin-top:1rem;padding:.9rem;font-size:1.05rem;font-weight:600;transition:all .3s;box-shadow:0 2px 6px #4a90e233}.auth-button:hover{background-color:#3a80d2;transform:translateY(-1px);box-shadow:0 4px 8px #4a90e240}.auth-button:disabled{cursor:not-allowed;box-shadow:none;background-color:#9fc6f0;transform:none}.auth-link{text-align:center;color:#555;margin-top:2rem;font-size:.95rem}.auth-link a{color:#4a90e2;margin-left:.3rem;font-weight:600;text-decoration:none;transition:all .2s}.auth-link a:hover{color:#2b6cb0;text-decoration:underline}.navbar{z-index:100;background-color:#fff;justify-content:space-between;align-items:center;width:100%;padding:1.2rem 2.5rem;display:flex;position:sticky;top:0;box-shadow:0 2px 10px #00000014}.navbar-logo a{color:#4a90e2;letter-spacing:-.5px;font-size:1.6rem;font-weight:700;text-decoration:none;transition:color .2s}.navbar-logo a:hover{color:#2b6cb0}.navbar-links{align-items:center;gap:2rem;display:flex}.nav-link{color:#444;border-radius:4px;padding:.5rem .8rem;font-size:1.05rem;font-weight:500;text-decoration:none;transition:all .2s}.nav-link:hover{color:#4a90e2;background-color:#4a90e214}button.nav-link{cursor:pointer;background:0 0;border:none;padding:.5rem .8rem;font-size:1.05rem}.active-link{background-color:#4a90e214;font-weight:600;position:relative;color:#4a90e2!important}.active-link:after{content:"";background-color:#4a90e2;border-radius:1px;height:2px;position:absolute;bottom:-2px;left:.8rem;right:.8rem}.logout-button{color:#e53935}.logout-button:hover{color:#d32f2f;background-color:#e5393514}
