:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:#2d1f16;background:radial-gradient(circle at 12% 14%,rgba(248,226,190,.55),transparent 30%),radial-gradient(circle at 88% 80%,rgba(229,197,140,.35),transparent 32%),linear-gradient(135deg,#f9f1e5,#f4e7d1 58%,#f8f0e3)}*{box-sizing:border-box}body{margin:0}.page{max-width:1100px;margin:0 auto;padding:1rem;display:grid;gap:1rem}.hero{background:linear-gradient(135deg,#5f3f2d,#7e573f);color:#fff6ea;padding:1.2rem;border-radius:.8rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}.hero h1{margin:0 0 .25rem}.panel{background:#fffbf4;border-radius:.8rem;padding:1rem;border:1px solid #e5d2b4;box-shadow:0 8px 16px #492f1c14}.error{margin:0;color:#7d1010;background:#ffe7e7;border:1px solid #ffc7c7;border-radius:.6rem;padding:.75rem}.grid-form{display:grid;gap:.8rem;grid-template-columns:1fr}label{display:grid;gap:.35rem;font-size:.95rem}input,textarea,select,button{font:inherit}input,textarea,select{border:1px solid #ccb089;border-radius:.45rem;padding:.55rem;width:100%;background:#fffdfa}.checkbox{grid-auto-flow:column;justify-content:start;align-items:center;gap:.55rem}.checkbox input{width:auto}.form-actions,.filter-actions,.card-actions{display:flex;gap:.6rem;flex-wrap:wrap}button{background:#7d5236;color:#fff;border:none;border-radius:.45rem;padding:.55rem .9rem;cursor:pointer}button:hover{filter:brightness(.95)}button:disabled{opacity:.65;cursor:not-allowed}button.ghost{background:#efe2cc;color:#4a2f1f}.filters{display:grid;grid-template-columns:1fr;gap:.6rem}.book-list{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.book-card.redesigned{border:1px solid #dbc8ab;border-radius:.9rem;overflow:hidden;background:linear-gradient(180deg,#fffaf2,#fdf5e7);box-shadow:0 6px 18px #5336221f;display:flex;flex-direction:column;transition:transform .2s ease,box-shadow .2s ease}.book-card.redesigned:hover{transform:translateY(-2px);box-shadow:0 12px 24px #53362229}.card-spine{height:6px;background:linear-gradient(90deg,#a66b3b,#d39a56)}.card-body{padding:1rem 1rem .2rem;display:flex;gap:.9rem;align-items:flex-start}.book-thumb{width:76px;height:108px;border-radius:.45rem;background:#e9d7bd;border:1px solid #d5bf9b;overflow:hidden;display:flex;justify-content:center;align-items:center;flex-shrink:0}.book-thumb img{width:100%;height:100%;object-fit:cover}.book-thumb span{font-size:1.4rem}.cover-button{padding:0;cursor:pointer}.cover-button:disabled{opacity:1;cursor:default}.card-info{min-width:0;flex:1}.card-info h3{margin:0;font-size:1.1rem;line-height:1.3}.muted{color:#664a36;margin-top:.2rem;font-size:.83rem;letter-spacing:.35px;text-transform:uppercase}.pill-row{display:flex;flex-wrap:wrap;gap:.45rem;margin:.7rem 0 .25rem}.pill{padding:.2rem .65rem;border-radius:999px;font-size:.75rem;font-weight:600;border:1px solid transparent}.pill-genre{color:#5f3e28;background:#f1e4d0;border-color:#ddc4a0}.pill-read{color:#31583d;background:#d8ebdc;border-color:#b6d8be}.pill-unread{color:#6d5950;background:#ebe3de;border-color:#d4c7be}.pill-score{color:#8f5f13;background:#ffe9c8;border-color:#edcc90}.meta-stack{margin:.7rem 1rem 0;border-top:1px solid #ddccb1}.meta-stack.compact{border-bottom:1px solid #ddccb1;padding-bottom:.35rem}.meta-row{display:grid;gap:.15rem;padding:.45rem 0}.meta-label{text-transform:uppercase;letter-spacing:.8px;color:#866850;font-size:.67rem;margin-bottom:.15rem}.meta-value{color:#352216;font-weight:600;font-size:.82rem}.meta-value.empty{color:#8f7769;font-style:italic;font-weight:500}.stars{color:#b77c1f;font-size:.95rem;display:inline-flex;align-items:center;gap:.25rem}.stars-empty{color:#ceb89f}.score-value{color:#7f5a36;font-size:.75rem;font-weight:700}.expand-row{margin:.35rem 1rem 0}.expand-btn{width:100%;text-align:center;padding:.4rem .6rem}.book-extra{max-height:0;overflow:hidden;transition:max-height .25s ease}.book-card.redesigned:hover .book-extra,.book-card.redesigned.is-expanded .book-extra{max-height:360px}.comment-strip{display:flex;gap:.45rem;margin:0 1rem;padding:.7rem 0;color:#5d4230}.comment-icon{font-size:.87rem;margin-top:.08rem}.comment-text{font-size:.83rem}.comment-text.empty{color:#8f7769;font-style:italic}.card-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:.75rem 1rem 1rem;background:linear-gradient(to bottom,transparent,rgba(234,216,188,.35))}.cover-modal{position:fixed;inset:0;background:#19110cc7;display:grid;place-items:center;padding:1rem;z-index:1000}.cover-modal-content{background:#fff9ee;border:1px solid #ceb490;border-radius:.9rem;padding:.9rem;width:min(520px,100%);text-align:center}.cover-modal-content img{width:100%;max-height:75vh;object-fit:contain;border-radius:.6rem}.cover-close{margin-left:auto;margin-bottom:.6rem;display:inline-block}.cover-preview{display:flex;align-items:flex-end;gap:.7rem}.cover-preview img{width:120px;border-radius:.5rem;border:1px solid #d7e1ec}.cover-actions{display:flex;gap:.6rem;flex-wrap:wrap}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.helper-text{color:#6a4f39;font-size:.88rem}.loading-text{font-weight:600}.login-page{min-height:100vh;display:grid;place-items:center;padding:1.2rem;background:radial-gradient(circle at 15% 18%,rgba(247,232,200,.45),transparent 35%),radial-gradient(circle at 82% 78%,rgba(228,193,122,.28),transparent 32%),linear-gradient(180deg,#311e17,#4d2f22 42%,#65422d);position:relative;overflow:hidden}.login-shelves{position:absolute;inset:0;pointer-events:none}.shelf{position:absolute;left:0;right:0;height:36px;background:linear-gradient(180deg,#7a5339,#5d3c2a);box-shadow:inset 0 6px 10px #ffffff1f,0 6px 18px #00000040}.shelf:after{content:"";position:absolute;inset:-56px 0 auto;height:56px;background:repeating-linear-gradient(to right,#2f4a69 0 28px,#7a2f2f 28px 55px,#6e5a1f 55px 81px,#385c43 81px 112px,#4e2d53 112px 140px);border-bottom:6px solid #4a2f21;opacity:.8}.shelf-a{top:16%}.shelf-b{top:41%}.shelf-c{top:66%}.login-card{width:min(450px,100%);background:linear-gradient(165deg,#fffaf0,#f7ebd2);border:1px solid #d5bd90;border-radius:.9rem;padding:1.4rem;display:grid;gap:.9rem;position:relative;z-index:1;box-shadow:0 16px 36px #0d080666;font-family:Baskerville,Palatino Linotype,Book Antiqua,serif}.login-card h1{margin:0;color:#42281a}.login-card p{margin:0;color:#5a3b27}.login-quote{font-style:italic;font-size:.96rem;border-left:3px solid #8f6734;padding-left:.55rem;color:#6f4c2d}.quote-author{font-size:.86rem;color:#7b5734;margin-top:-.35rem}.login-form{display:grid;gap:.8rem}.login-form input{background:#fffdf8;border-color:#c7ac81}@media(min-width:768px){.page{padding:1.5rem}.grid-form{grid-template-columns:repeat(2,minmax(0,1fr))}.full{grid-column:span 2}.filters{grid-template-columns:repeat(3,minmax(0,1fr));align-items:end}.filter-actions{grid-column:span 3}.book-card{grid-template-columns:1fr}.login-card{padding:1.6rem}}@media(min-width:1200px){.book-list{grid-template-columns:repeat(3,minmax(0,1fr))}}
