@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg:#000;--surface:#0d0d0d;--surface-soft:#101010;--border:#ffffff14;--text:#f5f5f5;--text-muted:#ffffff8f;--success:#8ac68d;--danger:#ff7b7b;--max-width:1320px;--quotes-height:8.5rem;font-family:Inter,system-ui,sans-serif;font-weight:400;line-height:1.4}*{box-sizing:border-box;min-width:0}html,body,#root{min-height:100%}body{background:var(--bg);min-width:320px;color:var(--text);margin:0}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{cursor:pointer}img{max-width:100%;display:block}#root,.app-shell{background:var(--bg);min-height:100vh}.page-shell{width:min(100%, var(--max-width));margin:0 auto;padding:.5rem}.panel,.book-card,.input,.select,.textarea,.file-input,.status,.button,.tab-button,.quote-card,.sticky-quotes,.admin-table,.reader-toolbar,.icon-button,.quotes-back{background:var(--surface);border:1px solid var(--border);box-shadow:none;border-radius:0}.truncate-single{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.truncate-double{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.search-highlight{color:#fff;background:#222}.button,.tab-button,.icon-button{min-height:2.35rem;color:var(--text);background:var(--surface);border:1px solid var(--border);justify-content:center;align-items:center;padding:.5rem .72rem;transition:opacity .12s;display:inline-flex}.icon-button{width:2.35rem;padding:0}.button:hover,.tab-button:hover,.book-card:hover,.icon-button:hover,.quotes-back:hover{opacity:.82}.button:disabled,.tab-button:disabled,.icon-button:disabled{opacity:.45;cursor:not-allowed}.section-title,.library-title{letter-spacing:.01em;margin:0;font-size:1rem;font-weight:600}.field{gap:.35rem;display:grid}.field label{color:var(--text-muted);font-size:.74rem}.input,.select,.textarea,.file-input{width:100%;min-height:2.3rem;color:var(--text);background:var(--surface);border:1px solid var(--border);outline:0;padding:.5rem .6rem}.select{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.textarea{resize:vertical;min-height:7rem}.input:focus,.select:focus,.textarea:focus,.file-input:focus{border-color:#ffffff2e}.status{color:var(--text-muted);margin-top:.5rem;padding:.7rem;font-size:.82rem}.status-success{color:var(--success)}.status-error{color:var(--danger)}.badge{min-height:1.55rem;color:var(--text-muted);border:1px solid var(--border);align-items:center;padding:.15rem .42rem;font-size:.68rem;display:inline-flex}.home-page{padding-bottom:calc(var(--quotes-height) + 1rem)}.home-content{gap:.45rem;max-width:22rem;margin:0 auto;display:grid}.home-header{z-index:100;background:#000;position:sticky;top:0}.home-header-inner{max-width:1024px;margin:0 auto;padding:0 12px 10px}.home-header-title-row{justify-content:center;align-items:center;margin-bottom:8px;padding-top:8px;display:flex;position:relative}.home-header-title{text-align:center;font-size:.96rem}.home-header-github{width:2rem;height:2rem;color:var(--text-muted);justify-content:center;align-items:center;display:inline-flex;position:absolute;right:0}.home-header-github:hover{color:var(--text)}.home-header-controls-row{justify-content:space-between;align-items:center;gap:10px;display:flex}.home-header-search{width:65%}.home-header-filter{width:35%}.library-search,.library-filter{border-radius:6px;width:100%;height:40px;min-height:40px;padding:10px;font-size:14px}.library-filter{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.book-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.35rem;display:grid}.book-card{overflow:hidden}.book-card-link{display:grid}.book-cover{aspect-ratio:2/3;object-fit:cover;background:#121212;width:100%}.book-cover-fallback{background:#111}.book-body{gap:.28rem;padding:.38rem;display:grid}.book-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.78rem;font-weight:600;line-height:1.18;display:-webkit-box;overflow:hidden}.book-meta-row{justify-content:space-between;align-items:center;gap:.35rem;display:flex}.book-author{min-width:0;color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:.64rem;overflow:hidden}.book-category-badge{border:1px solid var(--border);max-width:48%;color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;flex-shrink:1;padding:.08rem .3rem;font-size:.58rem;overflow:hidden}.load-more-button{width:100%;margin-top:.5rem}.sticky-quotes{z-index:20;width:auto;max-width:min(calc(var(--max-width) - 1rem), 21rem);height:var(--quotes-height);gap:.35rem;margin-inline:auto;padding:.45rem;display:grid;position:fixed;bottom:.5rem;left:.5rem;right:.5rem}.sticky-quotes-header{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.sticky-quotes-link{color:var(--text-muted);font-size:.66rem}.sticky-quotes-list{gap:.45rem;padding-right:.1rem;display:grid;overflow:auto}.sticky-quote-item{border-bottom:1px solid var(--border);padding-bottom:.35rem}.sticky-quote-item:last-child{border-bottom:0;padding-bottom:0}.sticky-quote-text,.quote-text{text-align:center;margin:0;font-size:.78rem;line-height:1.45}.sticky-quote-writer,.quote-writer{color:var(--text-muted);text-align:center;margin:.3rem 0 0;font-size:.64rem}.quotes-page{padding-top:.5rem}.quotes-page-header{align-items:center;gap:.6rem;margin-bottom:.5rem;display:flex}.quotes-back{justify-content:center;align-items:center;width:2rem;height:2rem;display:inline-flex}.quotes-list{gap:.5rem;display:grid}.quote-card{padding:1rem .8rem}.quote-share-card{border:1px solid var(--border);gap:.9rem;width:min(100%,32rem);padding:2rem 1.6rem;display:grid}.quote-share-card.is-black{color:#fff;background:#050505}.quote-share-card.is-white{color:#111;background:#fff;border-color:#11111124}.quote-share-text,.quote-share-author,.quote-share-credit,.quote-share-book,.quote-share-branding{text-align:center;margin:0}.quote-share-text{white-space:pre-wrap;font-size:1.35rem;line-height:1.5}.quote-share-author{opacity:.84;font-size:.88rem}.quote-share-credit{opacity:.68;margin-top:-.25rem;font-size:.74rem}.quote-share-book{text-transform:uppercase;letter-spacing:.12em;opacity:.72;font-size:.78rem}.quote-share-branding{letter-spacing:.08em;opacity:.48;margin-top:.25rem;font-size:.72rem}.empty-state{padding:.75rem}.login-page{place-items:center;min-height:100vh;display:grid}.login-panel{border:1px solid var(--border);width:min(100%,24rem);padding:.85rem}.auth-form,.upload-form{gap:.75rem;margin-top:.7rem;display:grid}.admin-page,.upload-layout{gap:.5rem;padding-top:.5rem;display:grid}.admin-columns{gap:.5rem;display:grid}.admin-section,.upload-panel{padding:.65rem}.admin-section-header,.upload-header,.upload-book-header,.tabs-row,.category-create-row,.table-actions,.edit-actions,.table-pagination{flex-wrap:wrap;align-items:center;gap:.45rem;display:flex}.admin-section-header,.upload-book-header{justify-content:space-between}.category-create-row .input{flex:1;min-width:10rem}.admin-table-wrap{margin-top:.5rem;overflow-x:auto}.admin-table{border-collapse:collapse;table-layout:fixed;width:100%;min-width:34rem}.books-table{min-width:42rem}.admin-table th,.admin-table td{border-bottom:1px solid var(--border);text-align:left;vertical-align:middle;padding:.55rem;font-size:.78rem}.admin-table th{color:var(--text-muted);font-weight:500}.admin-table tbody:last-child tr:last-child td{border-bottom:0}.table-cell-text{overflow:hidden}.table-actions{justify-content:flex-start}.table-actions-icons{justify-content:center;align-items:center;gap:.625rem}.table-button{min-height:2rem;padding:.35rem .55rem;font-size:.75rem}.table-page-label{color:var(--text-muted);font-size:.74rem}.table-cover{aspect-ratio:2/3;object-fit:cover;background:#111;width:2.6rem}.table-input{min-height:2rem}.edit-row td{vertical-align:top;background:#090909}.admin-edit-grid{gap:.7rem;display:grid}.admin-edit-wide,.upload-file-field{grid-column:1/-1}.edit-actions{margin-top:.7rem}.upload-book{padding:.7rem}.upload-book-grid{gap:.7rem;margin-top:.65rem;display:grid}.tab-button.is-active{border-color:#ffffff38}.reader-page,.reader-full{background:#000;width:100%;max-width:none;min-height:100vh;padding:0}.reader-toolbar{z-index:10;border-top:0;background:#000;border-inline:0;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:.5rem;padding:.55rem .65rem;display:grid;position:sticky;top:0}.reader-back{background:0 0;border:0;justify-content:center;align-items:center;min-height:auto;padding:0;display:inline-flex}.reader-title{white-space:nowrap;text-overflow:ellipsis;min-width:0;font-size:.82rem;font-weight:500;overflow:hidden}.reader-actions{align-items:center;gap:.35rem;display:inline-flex;position:relative}.reader-control{min-height:2rem;color:var(--text-muted);background:var(--surface);border:1px solid var(--border);padding:.3rem .5rem}.reader-zoom-wrap{position:relative}.reader-menu{border:1px solid var(--border);background:#000;min-width:4.6rem;display:grid;position:absolute;top:calc(100% + .25rem);right:0}.reader-menu-item{min-height:2rem;color:var(--text-muted);border:0;border-bottom:1px solid var(--border);text-align:right;background:#000;padding:.35rem .5rem}.reader-menu-item:last-child{border-bottom:0}.reader-menu-item.is-active,.reader-menu-item:hover,.reader-control:hover{color:var(--text)}.reader-layout{margin-top:.5rem}.reader-stage{background:#000;justify-content:center;padding:.75rem .25rem 1.5rem;display:flex}.pdf-scroll{justify-items:center;gap:.75rem;width:100%;display:grid}.pdf-page canvas{max-width:100%;display:block;height:auto!important}.pdf-page .react-pdf__Page__textContent{-webkit-user-select:text;user-select:text}.pdf-page .react-pdf__Page__textContent ::selection{background:#ffffff47}.pdf-page-fallback{width:min(100%,42rem);min-height:3rem;color:var(--text-muted);border:1px solid var(--border);background:#050505;place-items:center;font-size:.78rem;display:grid}.quote-selection-action{z-index:30;color:#fff;background:#000000eb;border:1px solid #ffffff24;min-height:2.2rem;padding:.45rem .75rem;position:fixed;transform:translate(-50%,-100%)}.modal-backdrop{z-index:40;background:#000000c2;place-items:center;padding:1rem;display:grid;position:fixed;inset:0}.modal-panel{border:1px solid var(--border);background:#050505;width:min(100%,48rem);max-height:calc(100vh - 2rem);padding:1rem;overflow:auto}.modal-header,.modal-actions,.quote-output-actions{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.6rem;display:flex}.modal-subtitle{color:var(--text-muted);margin:.3rem 0 0;font-size:.78rem}.quote-modal-grid{gap:.85rem;margin-top:.9rem;display:grid}.quote-modal-stage{min-height:18rem;position:relative}.quote-stage-panel{animation:.24s quoteFadeIn}.quote-modal-meta{gap:.85rem;display:grid}.quote-modal-value{align-items:center;min-height:2.6rem;padding:.7rem;display:flex}.quote-style-fieldset{border:0;gap:.45rem;margin:0;padding:0;display:grid}.quote-style-fieldset legend{color:var(--text-muted);padding:0;font-size:.74rem}.quote-style-options{flex-wrap:wrap;gap:.45rem;display:flex}.quote-style-option{border:1px solid var(--border);background:var(--surface);align-items:center;gap:.35rem;padding:.45rem .6rem;display:inline-flex}.quote-preview-wrap{justify-content:center;margin-top:.9rem;display:flex}.quote-output{justify-items:center;gap:.75rem;padding:.75rem 0;display:grid}.quote-output-image{border:1px solid var(--border);width:100%;max-width:26rem;margin:0 auto}.quote-capture-surface{opacity:1;pointer-events:none;position:fixed;top:-10000px;left:-10000px}.quote-output-actions{justify-content:center;width:100%}.quote-output-actions .button{min-width:10rem}@keyframes quoteFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (width>=640px){.page-shell{padding:.75rem}.sticky-quotes{max-width:min(calc(var(--max-width) - 1.5rem), 25rem);left:.75rem;right:.75rem}.upload-book-grid,.admin-edit-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.quote-modal-grid{grid-template-columns:minmax(0,1.25fr) minmax(16rem,.75fr);align-items:start}}@media (width<=639px){.quote-output-actions,.modal-actions{grid-template-columns:1fr;width:100%;display:grid}.quote-output-actions .button,.modal-actions .button{width:100%}}@media (width>=768px) and (width<=1024px){.home-content{max-width:100%}.home-header-inner{padding-inline:16px}.home-header-search{width:70%}.home-header-filter{width:30%}}@media (width>=1024px){.book-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.admin-columns{grid-template-columns:minmax(18rem,.7fr) minmax(0,1.3fr);align-items:start}.home-content{max-width:100%}.quotes-list{width:min(100%,52rem);margin-inline:auto}}
