@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:"Lato","Helvetica Neue",Helvetica,Arial,sans-serif;--font-serif:"Merriweather",Georgia,serif;--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--ease-in-out:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-vintage-leather:#3d2317;--color-parchment-light:#fbf6ef;--color-parchment:#f5ede0;--color-parchment-dark:#ede4d3;--color-parchment-cream:#ddd3c1;--color-accent-orange:#8b3a3a;--color-accent-orange-dark:#6d2c2c;--color-accent-star:#daa520;--color-ink-dark:#2c2416;--color-ink-light:#6b5d4d;--shadow-vintage:0 2px 8px #38211026;--shadow-vintage-lg:0 4px 16px #38211033;--shadow-card:0 1px 3px #0000001a;--shadow-card-hover:0 4px 12px #00000026;--radius-vintage:4px;--radius-pill:50px;--animate-float:float 3s ease-in-out infinite}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--color-ink-dark);background:var(--color-parchment-dark);line-height:1.5}h1,h2,h3,h4,h5,h6{font-family:var(--font-serif);font-weight:700}#root{min-height:100vh}}@layer components{.btn-vintage{border-radius:var(--radius-pill);cursor:pointer;box-shadow:var(--shadow-vintage);padding:.625rem 1.5rem;font-size:.875rem;font-weight:600;transition:all .3s}.btn-primary{background:var(--color-accent-orange);color:#fff}.btn-primary:hover{background:var(--color-accent-orange-dark);box-shadow:var(--shadow-vintage-lg);transform:translateY(-2px)}.btn-secondary{background:var(--color-parchment);color:var(--color-vintage-leather);border:1px solid var(--color-parchment-cream)}.btn-secondary:hover{background:#fff;transform:translateY(-2px)}.card-vintage{background:var(--color-parchment);border-radius:var(--radius-vintage);border:1px solid var(--color-parchment-cream);box-shadow:var(--shadow-card);transition:box-shadow .2s}.card-vintage:hover{box-shadow:var(--shadow-card-hover)}.input-vintage{border:1px solid var(--color-parchment-cream);border-radius:var(--radius-pill);width:100%;color:var(--color-ink-dark);background:#fff;padding:.75rem 1rem;transition:all .2s}.input-vintage::placeholder{color:var(--color-ink-light)}.input-vintage:focus{border-color:var(--color-accent-orange);outline:none;box-shadow:0 0 0 3px #d6491a1a}}@layer utilities{.flex{display:flex}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.text-shadow-vintage{text-shadow:2px 2px 4px #0000004d}.bg-leather{background:linear-gradient(135deg,#3d2317,#5d4037 40%,#4e342e,#3d2317)}.bg-parchment-texture{background:linear-gradient(#fff8f0,#f4f1ea)}.shadow-book-spine{box-shadow:3px 0 8px #0003}.animate-float{animation:var(--animate-float)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--color-parchment)}::-webkit-scrollbar-thumb{background:#d8d8d8;border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#999}::selection{background:var(--color-accent-orange);color:#fff}:focus-visible{outline:2px solid var(--color-accent-orange);outline-offset:2px}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}.navbar{position:sticky;top:0;z-index:1000;border-bottom:4px solid var(--color-parchment-cream);box-shadow:var(--shadow-vintage-lg);background:linear-gradient(135deg,#3d2317,#5d4037 40%,#4e342e,#3d2317)}.navbar-container{max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.navbar-brand{display:flex;align-items:center;gap:.75rem;text-decoration:none;transition:transform .2s ease}.navbar-brand:hover{transform:scale(1.02)}.navbar-title{font-size:1.75rem;font-weight:700;color:#fff;margin:0;font-family:var(--font-serif);text-shadow:2px 2px 4px rgba(0,0,0,.3)}.navbar-actions{display:flex;align-items:center;gap:1rem}.navbar-link{display:flex;align-items:center;gap:.4rem;color:#fff;text-decoration:none;font-weight:500;font-size:.9rem;padding:.5rem 1rem;background:#ffffff1a;border-radius:50px;transition:all .3s ease}.navbar-link:hover{background:#fff3;transform:translateY(-2px)}.nav-icon{font-size:1rem}.navbar-user{display:flex;align-items:center;gap:.5rem;color:#fff;font-weight:500;font-size:.875rem;padding:.5rem 1rem;background:#ffffff1a;border-radius:50px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.user-icon{font-size:1.2rem}.navbar-btn{padding:.625rem 1.5rem;border:none;border-radius:50px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .3s ease;font-family:var(--font-sans);box-shadow:var(--shadow-vintage)}.signin-btn{background:linear-gradient(135deg,#f4f1ea,#e8e3d6);color:var(--color-vintage-leather);text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.signin-btn:hover{background:linear-gradient(135deg,#fff,#f4f1ea);transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.logout-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3)}.logout-btn:hover{background:#ffffff4d;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.navbar-loading{display:flex;align-items:center;gap:.5rem;color:#fff;font-size:1.125rem}.navbar-loading .loading-spinner{animation:spin 1s linear infinite}@media(max-width:768px){.navbar-container{padding:1rem}.navbar-title{font-size:1.25rem}.navbar-icon{font-size:1.5rem}.navbar-user{font-size:.8rem;padding:.4rem .8rem}.navbar-btn{padding:.5rem 1rem;font-size:.85rem}}.search-bar-container{width:100%;padding:2rem}.search-form{width:100%;max-width:800px;margin:0 auto}.search-input-wrapper{display:flex;align-items:stretch;gap:0;background:#fff;border:2px solid var(--color-parchment-cream);border-radius:50px;overflow:hidden;box-shadow:var(--shadow-card);transition:all .2s ease}.search-input-wrapper:focus-within{border-color:var(--color-accent-orange);box-shadow:0 0 0 3px #d6491a26}.search-icon{font-size:1.2rem;padding:0 1rem;display:flex;align-items:center;color:var(--color-ink-light)}.search-input{flex:1;background:transparent;border:none;outline:none;color:var(--color-ink-dark);font-size:1rem;padding:.875rem .5rem;font-family:var(--font-sans)}.search-input::placeholder{color:var(--color-ink-light)}.search-input:disabled{opacity:.5;cursor:not-allowed}.search-button{color:#fff;border:none;padding:.875rem 2rem;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s ease;white-space:nowrap;font-family:var(--font-sans);background:linear-gradient(135deg,#d6491a,#b8401a)}.search-button:hover:not(:disabled){background:linear-gradient(135deg,#b8401a,#9a3615)}.search-button:active:not(:disabled){transform:scale(.98)}.search-button:disabled{opacity:.6;cursor:not-allowed}.loading-spinner{display:inline-block;animation:spin 1s linear infinite}@media(max-width:768px){.search-bar-container{padding:1rem}.search-input{font-size:.95rem;padding:.75rem .5rem}.search-button{padding:.75rem 1.5rem;font-size:.95rem}}.carousel-container{border-radius:12px;padding:2rem;margin:2rem;max-width:900px;margin-left:auto;margin-right:auto;background:linear-gradient(135deg,#fff8f0,#f9f7f4);border:2px solid #E8E2D5;box-shadow:0 4px 20px #3821101f}.carousel-title{text-align:center;font-size:1.25rem;font-weight:600;color:var(--color-vintage-leather);margin:0 0 1.5rem;font-family:var(--font-serif)}.carousel-wrapper{display:flex;align-items:center;gap:1.5rem;position:relative}.carousel-nav-btn{background:linear-gradient(135deg,#382110,#5c4033);color:#fff;border:none;border-radius:50%;width:50px;height:50px;font-size:2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 4px 12px #0003;flex-shrink:0;opacity:.7}.carousel-nav-btn:hover{opacity:1;transform:scale(1.1);box-shadow:0 6px 16px #0000004d}.carousel-nav-btn:active{transform:scale(.95)}.carousel-book-display{flex:1;display:flex;gap:2rem;align-items:flex-start;min-height:400px}.book-cover-wrapper{flex-shrink:0;width:250px;height:375px;border-radius:4px;overflow:hidden;box-shadow:5px 5px 15px #0000004d;transition:transform .3s ease;position:relative}.book-cover-wrapper:hover{transform:scale(1.05);box-shadow:8px 8px 25px #00000059}.carousel-book-cover{width:100%;height:100%;object-fit:cover;display:block}.carousel-book-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#f9f7f4,#f4f1ea);display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--color-ink-light)}.placeholder-icon{font-size:4rem;margin-bottom:1rem}.carousel-book-info{flex:1;display:flex;flex-direction:column;gap:1rem}.carousel-book-title{font-size:1.75rem;font-weight:700;color:var(--color-vintage-leather);margin:0;font-family:var(--font-serif);line-height:1.3}.carousel-book-author{font-size:1.1rem;color:var(--color-ink-light);margin:0;font-style:italic}.carousel-rating{display:flex;align-items:center;gap:.5rem;font-size:1.1rem}.rating-stars{font-size:1.25rem}.rating-value{font-weight:600;color:var(--color-vintage-leather)}.carousel-description{font-size:.95rem;color:var(--color-ink-dark);line-height:1.6;margin:0}.carousel-indicators{display:flex;justify-content:center;gap:.5rem;margin-top:1.5rem;flex-wrap:wrap}.indicator-dot{width:10px;height:10px;border-radius:50%;background:#d8d8d8;border:none;cursor:pointer;transition:all .3s ease;padding:0}.indicator-dot:hover{background:#767676;transform:scale(1.2)}.indicator-dot.active{background:var(--color-vintage-leather);transform:scale(1.3)}@media(max-width:768px){.carousel-container{padding:1.5rem;margin:1rem}.carousel-wrapper{flex-direction:column;gap:1rem}.carousel-nav-btn{width:40px;height:40px;font-size:1.5rem}.prev-btn{order:2}.next-btn{order:3}.carousel-book-display{flex-direction:column;align-items:center;gap:1.5rem;min-height:auto;order:1}.book-cover-wrapper{width:200px;height:300px}.carousel-book-info{text-align:center}.carousel-book-title{font-size:1.5rem}.carousel-book-author{font-size:1rem}.carousel-rating{justify-content:center}}.emotion-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .7rem;border-radius:50px;font-size:.8rem;font-weight:500;background:linear-gradient(135deg,#fff8f0,#f4f1ea);border:1px solid #E8E2D5;color:var(--color-ink-dark);transition:all .2s ease}.emotion-badge:hover{transform:translateY(-2px);border-color:var(--color-accent-orange);box-shadow:0 2px 6px #d6491a26}.emotion-emoji{font-size:1rem;line-height:1}.emotion-name{text-transform:capitalize;letter-spacing:.2px}.emotion-value{font-weight:600;margin-left:.15rem;color:var(--color-ink-light)}.book-card{border-radius:8px;overflow:hidden;transition:all .2s ease;border:2px solid #E8E2D5;background:linear-gradient(135deg,#fff8f0,#f9f7f4);box-shadow:0 2px 8px #3821101a}.book-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #38211026}.book-card-inner{display:flex;gap:1.5rem;padding:1.5rem}.book-thumbnail{flex-shrink:0;width:120px;height:180px;border-radius:4px;overflow:hidden;box-shadow:3px 3px 10px #00000040}.book-thumbnail img{width:100%;height:100%;object-fit:cover}.book-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:3rem;background:linear-gradient(135deg,#e8e2d5,#d8d2c5);color:var(--color-ink-light)}.book-content{flex:1;display:flex;flex-direction:column;gap:.75rem;min-width:0}.book-title{font-size:1.3rem;font-weight:700;color:var(--color-vintage-leather);margin:0;line-height:1.3;font-family:var(--font-serif);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;cursor:pointer;transition:color .2s ease}.book-title:hover{color:var(--color-accent-orange)}.book-authors{display:flex;align-items:center;gap:.5rem;font-size:.95rem;color:var(--color-ink-dark);margin:0}.book-authors .icon{color:var(--color-ink-light)}.book-category{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--color-ink-light);margin:0}.icon{font-size:.9rem}.book-meta{display:flex;flex-wrap:wrap;gap:1rem;padding:.5rem 0;border-top:1px solid #E8E2D5;border-bottom:1px solid #E8E2D5}.meta-item{font-size:.875rem;color:var(--color-ink-dark);display:flex;align-items:center;gap:.3rem}.star-rating{display:flex;align-items:center;gap:.3rem;color:var(--color-accent-star);font-weight:700}.book-description{font-size:.95rem;line-height:1.6;color:var(--color-ink-dark);margin:0;flex:1}.emotion-container{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.relevance-score{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:4px;margin-top:.5rem;align-self:flex-start;background:linear-gradient(135deg,#f4f1ea,#e8e2d5)}.score-label{font-size:.875rem;color:var(--color-ink-light);font-weight:400}.score-value{font-size:1rem;font-weight:700;color:var(--color-accent-orange)}@media(max-width:768px){.book-card-inner{flex-direction:column;padding:1rem;gap:1rem}.book-thumbnail{width:100px;height:150px}.book-title{font-size:1.1rem}.book-meta{gap:.75rem}}.auth-page{min-height:100vh;background:linear-gradient(135deg,#382110,#5c4033,#4a3728);display:flex;align-items:center;justify-content:center;padding:2rem}.auth-page-container{width:100%;max-width:500px}.auth-page-header{margin-bottom:2rem}.auth-back-link{display:inline-flex;align-items:center;gap:.5rem;color:#fff;text-decoration:none;font-size:.95rem;font-weight:500;padding:.5rem 1rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;transition:all .3s ease}.auth-back-link:hover{background:#fff3;transform:translate(-4px)}.auth-back-link:hover .back-arrow{transform:translate(-4px)}.auth-form-wrapper{background:linear-gradient(180deg,#fff8f0,#f9f7f4);border-radius:24px;border:2px solid #E8E2D5;box-shadow:0 20px 60px #38211059;animation:slideUp .5s ease}.auth-form{padding:3rem}.auth-title{font-size:2rem;font-weight:700;color:var(--color-vintage-leather, #382110);margin:0 0 .5rem;text-align:center;font-family:var(--font-serif, "Merriweather", Georgia, serif)}.auth-subtitle{font-size:1rem;color:var(--color-ink-light, #767676);margin:0 0 2rem;text-align:center}.form-group{margin-bottom:1.5rem}.form-group input{width:100%;padding:.875rem 1rem;font-size:1rem;border:2px solid #E8E2D5;border-radius:12px;transition:all .3s ease;background:#f8f9fa}.form-group input:focus{outline:none;border-color:var(--color-accent-orange, #D6491A);background:#fff;box-shadow:0 0 0 4px #d6491a1a}.form-group input:disabled{opacity:.6;cursor:not-allowed}.auth-error{background:linear-gradient(135deg,#d6491a,#b8401a);color:#fff;padding:1rem;border-radius:12px;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem;font-size:.9rem;box-shadow:0 4px 12px #d6491a40}.auth-submit-btn{width:100%;padding:1rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#382110,#5c4033);border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 4px 15px #3821104d}.auth-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #38211066}.auth-submit-btn:active:not(:disabled){transform:translateY(0)}.auth-submit-btn:disabled{opacity:.7;cursor:not-allowed}.auth-footer{margin-top:2rem;text-align:center}.auth-footer p{color:var(--color-ink-light, #767676);font-size:.95rem}.auth-link{color:var(--color-accent-orange, #D6491A);text-decoration:none;font-weight:600;transition:color .2s ease}.auth-link:hover{color:var(--color-accent-orange-dark, #B8401A);text-decoration:underline}.password-strength{margin-top:.75rem}.strength-bar{height:4px;background:#e8e2d5;border-radius:2px;overflow:hidden;margin-bottom:.5rem}.strength-fill{height:100%;transition:all .3s ease;border-radius:2px}.strength-fill.strength-1{background:linear-gradient(90deg,#d6491a,#b8401a)}.strength-fill.strength-2{background:linear-gradient(90deg,#c9a961,#d4b86a)}.strength-fill.strength-3{background:linear-gradient(90deg,#48a965,#2d8a4e)}.strength-label{font-size:.85rem;font-weight:600}.strength-fill.strength-1+.strength-label{color:#d6491a}.strength-fill.strength-2+.strength-label{color:#c9a961}.strength-fill.strength-3+.strength-label{color:#2d8a4e}.success-message{text-align:center;padding:2rem 0}.success-message h2{font-size:1.75rem;color:var(--color-vintage-leather, #382110);margin:0 0 .5rem;font-family:var(--font-serif, "Merriweather", Georgia, serif)}.success-message p{color:var(--color-ink-light, #767676);font-size:1rem}@media(max-width:600px){.auth-page{padding:1rem}.auth-form{padding:2rem 1.5rem}.auth-title{font-size:1.75rem}.auth-page-header{margin-bottom:1.5rem}}.add-book-page{min-height:100vh;background:linear-gradient(135deg,#382110,#5c4033,#4a3728);display:flex;align-items:flex-start;justify-content:center;padding:2rem}.add-book-container{width:100%;max-width:700px;padding-top:2rem}.add-book-header{margin-bottom:2rem}.add-book-back-link{display:inline-flex;align-items:center;gap:.5rem;color:#fff;text-decoration:none;font-size:.95rem;font-weight:500;padding:.5rem 1rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;transition:all .3s ease}.add-book-back-link:hover{background:#fff3;transform:translate(-4px)}.back-arrow{font-size:1.2rem;transition:transform .3s ease}.add-book-back-link:hover .back-arrow{transform:translate(-4px)}.add-book-form-wrapper{background:linear-gradient(180deg,#fff8f0,#f9f7f4);border-radius:24px;border:2px solid #E8E2D5;box-shadow:0 20px 60px #38211059;animation:slideUp .5s ease}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.add-book-form{padding:2.5rem}.add-book-title{font-size:2rem;font-weight:700;color:var(--color-vintage-leather, #382110);margin:0 0 .5rem;text-align:center;font-family:var(--font-serif, "Merriweather", Georgia, serif)}.add-book-subtitle{font-size:1rem;color:var(--color-ink-light, #767676);margin:0 0 2rem;text-align:center}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.form-row.three-cols{grid-template-columns:1fr 1fr 1fr}.form-group,.form-group.full-width{margin-bottom:1rem}.form-group label{display:block;font-size:.9rem;font-weight:600;color:var(--color-vintage-leather, #382110);margin-bottom:.5rem}.form-group input,.form-group textarea{width:100%;padding:.875rem 1rem;font-size:1rem;border:2px solid #E8E2D5;border-radius:12px;transition:all .3s ease;background:#f8f9fa;font-family:inherit}.form-group textarea{resize:vertical;min-height:100px}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-accent-orange, #8B3A3A);background:#fff;box-shadow:0 0 0 4px #8b3a3a1a}.form-group input:disabled,.form-group textarea:disabled{opacity:.6;cursor:not-allowed}.add-book-error{background:linear-gradient(135deg,#8b3a3a,#6d2c2c);color:#fff;padding:1rem;border-radius:12px;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem;font-size:.9rem;box-shadow:0 4px 12px #8b3a3a40}.error-icon{font-size:1.2rem}.add-book-submit-btn{width:100%;padding:1rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#382110,#5c4033);border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 4px 15px #3821104d;margin-top:1rem}.add-book-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #38211066}.add-book-submit-btn:active:not(:disabled){transform:translateY(0)}.add-book-submit-btn:disabled{opacity:.7;cursor:not-allowed}.btn-icon{font-size:1.2rem}.loading-spinner{animation:spin 1s linear infinite}.add-book-success{padding:3rem;text-align:center}.success-icon{font-size:4rem;display:block;margin-bottom:1rem}.add-book-success h2{font-size:1.75rem;color:var(--color-vintage-leather, #382110);margin:0 0 .5rem;font-family:var(--font-serif, "Merriweather", Georgia, serif)}.add-book-success p{color:var(--color-ink-light, #767676);font-size:1rem;margin:0 0 2rem}.add-another-btn{padding:.875rem 2rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#382110,#5c4033);border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #3821104d}.add-another-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #38211066}.add-book-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;color:#fff}.loading-spinner-large{font-size:3rem;animation:spin 1.5s linear infinite}.add-book-loading p{margin-top:1rem;font-size:1.1rem}@media(max-width:600px){.add-book-page{padding:1rem}.add-book-container{padding-top:1rem}.add-book-form{padding:1.5rem}.add-book-title{font-size:1.5rem}.form-row,.form-row.three-cols{grid-template-columns:1fr}.add-book-header{margin-bottom:1.5rem}}.app{min-height:100vh;background:var(--color-parchment-dark)}.app-container{max-width:1200px;margin:0 auto}.app-header{background:var(--color-parchment);border-bottom:1px solid var(--color-parchment-cream);padding:2rem;margin-bottom:1rem;text-align:center}.app-title{font-size:2rem;font-weight:700;color:var(--color-vintage-leather);margin:0 0 .5rem;display:flex;align-items:center;justify-content:center;gap:.75rem;font-family:var(--font-serif)}.title-icon{font-size:2rem}.app-subtitle{font-size:1rem;color:var(--color-ink-light);margin:0;font-weight:400;font-family:var(--font-sans)}.results-header{margin:0 2rem 1.5rem}.results-title{font-size:1.5rem;font-weight:700;color:var(--color-vintage-leather);margin:0;font-family:var(--font-serif)}.books-grid{display:flex;flex-direction:column;gap:1.5rem;padding:0 2rem 2rem}.error-message{background:#fff3cd;border:1px solid #FFC107;border-radius:var(--radius-vintage);padding:1rem 1.5rem;margin:2rem;display:flex;align-items:center;gap:1rem;color:#856404}.error-icon{font-size:1.5rem;flex-shrink:0}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem}.loading-spinner-large{font-size:3rem;animation:spin 1.5s linear infinite;color:var(--color-accent-orange)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-text{font-size:1.1rem;color:var(--color-ink-light);margin-top:1rem}.no-results{text-align:center;padding:4rem 2rem}.no-results-icon{font-size:3rem;display:block;margin-bottom:1rem}.no-results p{font-size:1.1rem;color:var(--color-ink-light);margin:0}.welcome-message{text-align:center;padding:6rem 2rem;background:var(--color-parchment-light);margin:2rem;border-radius:var(--radius-vintage);box-shadow:var(--shadow-card);position:relative;overflow:hidden;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23382110' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}.welcome-icon{font-size:4rem;margin-bottom:1.5rem}.welcome-message h2{font-size:2rem;font-weight:700;color:var(--color-vintage-leather);margin:0 0 1rem;font-family:var(--font-serif)}.welcome-message p{font-size:1.1rem;color:var(--color-ink-light);margin:0}@media(max-width:768px){.app-header{padding:1rem}.app-title,.title-icon{font-size:1.5rem}.app-subtitle{font-size:.9rem}.books-grid{padding:0 1rem 2rem;gap:1rem}.results-header{margin:0 1rem 1rem}.welcome-message{padding:3rem 1rem;margin:1rem}.welcome-message h2{font-size:1.5rem}}
