:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}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:#f9f9f9;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background-color:#f5f7fa;color:#333;line-height:1.5}.container{max-width:1200px;margin:0 auto;padding:2rem}.title{color:#4a90e2;font-size:2.5rem;margin-bottom:1.5rem;border-bottom:1px solid #4a90e2;padding-bottom:.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{display:flex;flex-wrap:wrap;margin:-10px}.book-card{flex:0 0 calc(33.333% - 20px);margin:10px;background-color:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;transition:all .3s ease}.book-card:hover{transform:translateY(-5px);box-shadow:0 8px 16px #00000026}@media (max-width: 1024px){.book-card{flex:0 0 calc(50% - 20px)}}@media (max-width: 600px){.book-card{flex:0 0 calc(100% - 20px)}}.book-header{padding:1.5rem;border-bottom:1px solid #eee}.book-genre{display:inline-block;background-color:#4a90e2;color:#fff;padding:.25rem .75rem;border-radius:50px;font-size:.75rem;margin-bottom:.75rem;font-weight:500}.book-title{font-size:1.5rem;margin-bottom:.5rem;color:#333;font-weight:600}.book-author{color:#666;font-size:1rem}.book-details{padding:1.5rem;display:flex;flex-direction:column;flex-grow:1}.book-meta{display:flex;justify-content:space-between;color:#666;font-size:.9rem;margin-bottom:1rem;border-bottom:1px solid #eee;padding-bottom:1rem}.book-description{font-size:.95rem;color:#333}.recommendation-container{background-color:#fff;border-radius:8px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 10px #00000014}.recommendation-title{color:#4a90e2;font-size:1.8rem;margin-bottom:1.2rem;font-weight:600}.recommendation-form{display:flex;flex-direction:column;gap:1.2rem}.recommendation-input-container{display:flex;flex-direction:column;gap:.7rem}.recommendation-input-container label{font-weight:500;color:#555;font-size:1rem}.recommendation-input{padding:1rem;border:1px solid #e0e0e0;border-radius:6px;font-size:1rem;font-family:inherit;resize:vertical;min-height:100px;background-color:#fafafa;color:#333;transition:all .3s ease}.recommendation-input:focus{outline:none;border-color:#4a90e2;background-color:#fff;box-shadow:0 0 0 3px #4a90e21a}.recommendation-button{background-color:#4a90e2;color:#fff;padding:.9rem;border:none;border-radius:6px;font-size:1.05rem;font-weight:600;cursor:pointer;transition:all .3s ease;align-self:flex-start;min-width:200px;box-shadow:0 2px 6px #4a90e233}.recommendation-button:hover{background-color:#3a80d2;transform:translateY(-2px);box-shadow:0 4px 10px #4a90e24d}.recommendation-button:disabled{background-color:#9fc6f0;cursor:not-allowed;transform:none;box-shadow:none}.recommendations-result{display:flex;flex-direction:column;gap:1.5rem}.recommendations-header{display:flex;flex-direction:column;gap:.8rem;margin-bottom:.5rem}.recommendations-header h3{font-size:1.4rem;color:#333;margin:0}.recommendation-query{color:#666;font-style:italic;margin:0;padding:.5rem .8rem;background-color:#f5f7fa;border-left:3px solid #4a90e2;border-radius:0 4px 4px 0}.reset-button{background-color:#f5f7fa;color:#4a90e2;border:1px solid #4a90e2;padding:.6rem 1rem;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;align-self:flex-start}.reset-button:hover{background-color:#4a90e2;color:#fff}.section-title{color:#333;font-size:1.8rem;margin:2rem 0 1.5rem;font-weight:600}.recommended-book{border:2px solid #4a90e2;position:relative}.recommended-badge{position:absolute;top:1rem;right:1rem;background-color:#4a90e2;color:#fff;padding:.25rem .75rem;border-radius:50px;font-size:.75rem;font-weight:500}.no-recommendations{padding:2rem;text-align:center;background-color:#f5f7fa;border-radius:6px;color:#666;font-size:1.1rem}.similarity-score{background-color:#e3f2fd;color:#1e88e5;padding:.3rem .7rem;border-radius:50px;font-size:.85rem;font-weight:600}body{margin:0;padding:0;min-height:100vh;background-color:#f5f7fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}#root{display:flex;flex-direction:column;min-height:100vh}*{transition:background-color .2s ease,color .2s ease,border-color .2s ease,box-shadow .2s ease}.auth-container{max-width:480px;margin:4rem auto;padding:2.5rem;background-color:#fff;border-radius:8px;box-shadow:0 4px 20px #00000014;width:100%}.auth-title{color:#4a90e2;font-size:2rem;margin-bottom:1.8rem;text-align:center;font-weight:600}.auth-error{background-color:#ffebee;color:#e53935;padding:.85rem;border-radius:6px;margin-bottom:1.5rem;font-size:.95rem;box-shadow:0 2px 5px #e539351a}.auth-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.6rem}.form-group label{font-weight:500;font-size:.95rem;color:#444;margin-left:.2rem}.form-group input{padding:.9rem 1rem;border:1px solid #e0e0e0;border-radius:6px;font-size:1rem;transition:all .3s ease;background-color:#fafafa}.form-group input:focus{outline:none;border-color:#4a90e2;background-color:#fff;box-shadow:0 0 0 3px #4a90e21a}.auth-button{background-color:#4a90e2;color:#fff;padding:.9rem;border:none;border-radius:6px;font-size:1.05rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:1rem;box-shadow:0 2px 6px #4a90e233}.auth-button:hover{background-color:#3a80d2;transform:translateY(-1px);box-shadow:0 4px 8px #4a90e240}.auth-button:disabled{background-color:#9fc6f0;cursor:not-allowed;transform:none;box-shadow:none}.auth-link{text-align:center;margin-top:2rem;font-size:.95rem;color:#555}.auth-link a{color:#4a90e2;text-decoration:none;font-weight:600;margin-left:.3rem;transition:all .2s ease}.auth-link a:hover{color:#2b6cb0;text-decoration:underline}.navbar{display:flex;justify-content:space-between;align-items:center;padding:1.2rem 2.5rem;background-color:#fff;box-shadow:0 2px 10px #00000014;position:sticky;top:0;z-index:100;width:100%}.navbar-logo a{color:#4a90e2;font-size:1.6rem;font-weight:700;text-decoration:none;letter-spacing:-.5px;transition:color .2s ease}.navbar-logo a:hover{color:#2b6cb0}.navbar-links{display:flex;gap:2rem;align-items:center}.nav-link{color:#444;text-decoration:none;font-weight:500;transition:all .2s ease;font-size:1.05rem;padding:.5rem .8rem;border-radius:4px}.nav-link:hover{color:#4a90e2;background-color:#4a90e214}button.nav-link{background:none;border:none;cursor:pointer;font-size:1.05rem;padding:.5rem .8rem}.active-link{color:#4a90e2!important;font-weight:600;background-color:#4a90e214;position:relative}.active-link:after{content:"";position:absolute;bottom:-2px;left:.8rem;right:.8rem;height:2px;background-color:#4a90e2;border-radius:1px}.logout-button{color:#e53935}.logout-button:hover{color:#d32f2f;background-color:#e5393514}.form-group input{color:#333!important}.form-group input::placeholder{color:#757575!important}input[type=text],input[type=email],input[type=password],textarea{color:#333!important}input[type=text]::placeholder,input[type=email]::placeholder,input[type=password]::placeholder,textarea::placeholder{color:#757575!important}
