:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color:#e8eaed;background-color:#1a1d29;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#1a1d29,#252a3a)}.login-card{background:#2d3344;padding:2rem;border-radius:12px;box-shadow:0 8px 32px #0000004d;width:100%;max-width:360px}.login-card h1{margin:0 0 .25rem;font-size:1.75rem;color:#e8eaed}.login-subtitle{margin:0 0 1.5rem;color:#9aa0a6;font-size:.9rem}.login-card input{width:100%;box-sizing:border-box;padding:.75rem 1rem;margin-bottom:.75rem;border:1px solid #4a5568;border-radius:8px;background:#1a1d29;color:#e8eaed;font-size:1rem}.login-card input::placeholder{color:#6b7280}.login-card button[type=submit]{width:100%;padding:.75rem 1rem;margin-top:.5rem;border:none;border-radius:8px;background:#5b7cff;color:#fff;font-size:1rem;font-weight:600;cursor:pointer}.login-card button[type=submit]:hover:not(:disabled){background:#4a6bf5}.login-card button[type=submit]:disabled{opacity:.7;cursor:not-allowed}.login-error{color:#f87171;font-size:.875rem;margin:0 0 .5rem}.login-toggle{display:block;width:100%;margin-top:1rem;padding:.5rem;border:none;background:none;color:#9aa0a6;font-size:.875rem;cursor:pointer}.login-toggle:hover{color:#c4c8cc}.book-tile{width:120px;flex-shrink:0;cursor:pointer;border-radius:8px;overflow:hidden;background:#2d3344;transition:transform .15s ease,box-shadow .15s ease}.book-tile:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000040}.book-tile--dragging{opacity:.6}.book-tile__cover{position:relative;aspect-ratio:3/4;background:#1a1d29;display:flex;align-items:center;justify-content:center;overflow:hidden}.book-tile__cover img{width:100%;height:100%;object-fit:cover}.book-tile__placeholder{width:100%;height:100%;background:linear-gradient(135deg,#3d4455,#2d3344)}.book-tile__edit{position:absolute;bottom:4px;right:4px;padding:.2rem .4rem;font-size:.65rem;background:#000000b3;color:#e8eaed;border:none;border-radius:4px;cursor:pointer}.book-tile__edit:hover{background:#5b7cff}.book-tile__actions{position:absolute;inset:0;display:flex;flex-wrap:wrap;align-content:flex-end;align-items:flex-end;gap:4px;padding:4px;background:linear-gradient(to top,rgba(0,0,0,.75) 0%,transparent 50%);opacity:0;transition:opacity .15s ease}.book-tile:hover .book-tile__actions{opacity:1}.book-tile__action{padding:.2rem .4rem;font-size:.6rem;background:#000c;color:#e8eaed;border:none;border-radius:4px;cursor:pointer}.book-tile__action:hover{background:#5b7cff}.book-tile__check-in{margin-left:auto}.book-tile--currently-reading .book-tile__cover{box-shadow:inset 0 0 0 2px #5b7cff}.book-tile__progress{margin-top:.35rem}.book-tile__progress-text,.book-tile__last-read{display:block;font-size:.65rem;color:#9aa0a6}.book-tile__last-read{margin-top:.1rem}.book-tile__progress-bar{height:4px;margin-top:.25rem;background:#3d4455;border-radius:2px;overflow:hidden}.book-tile__progress-fill{height:100%;background:#5b7cff;border-radius:2px;transition:width .2s ease}.book-tile__info{padding:.5rem .5rem .6rem}.book-tile__title{display:block;font-size:.8rem;font-weight:600;color:#e8eaed;line-height:1.2}.book-tile__author{display:block;font-size:.7rem;color:#9aa0a6;margin-top:.15rem}.upload-modal__backdrop{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.upload-modal{background:#2d3344;padding:1.5rem;border-radius:12px;width:100%;max-width:400px}.upload-modal h2{margin:0 0 1rem;font-size:1.25rem;color:#e8eaed}.upload-modal label{display:block;margin-bottom:1rem;color:#9aa0a6;font-size:.875rem}.upload-modal__hint{font-weight:400;color:#6b7280}.upload-modal select,.upload-modal input[type=file],.upload-modal input[type=text]{display:block;width:100%;margin-top:.25rem;padding:.5rem;border:1px solid #4a5568;border-radius:6px;background:#1a1d29;color:#e8eaed}.upload-modal__error{color:#f87171;font-size:.875rem;margin:0 0 .5rem}.upload-modal__file-count{display:block;margin-top:.25rem;font-size:.8rem;color:#9aa0a6}.upload-modal__chunk-hint{display:block;margin-top:.15rem;font-size:.75rem;color:#6b7280}.upload-modal__progress{color:#9aa0a6;font-size:.875rem;margin:0 0 .5rem}.upload-modal__success{color:#34d399;font-size:.875rem;margin:0 0 .5rem}.upload-modal__errors{margin:0 0 .5rem;padding-left:1.25rem;font-size:.875rem;color:#f87171}.upload-modal__error-item{margin-bottom:.25rem}.upload-modal__actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem}.upload-modal__actions button{padding:.5rem 1rem;border:none;border-radius:6px;cursor:pointer;font-size:.9rem}.upload-modal__actions button[type=button]{background:#4a5568;color:#e8eaed}.upload-modal__actions button[type=submit]{background:#5b7cff;color:#fff}.upload-modal__actions button[type=submit]:disabled{opacity:.7}.edit-modal__backdrop{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.edit-modal{background:#2d3344;padding:1.5rem;border-radius:12px;width:100%;max-width:400px}.edit-modal h2{margin:0 0 1rem;font-size:1.25rem;color:#e8eaed}.edit-modal label{display:block;margin-bottom:1rem;color:#9aa0a6;font-size:.875rem}.edit-modal__hint{font-weight:400;color:#6b7280}.edit-modal input{display:block;width:100%;margin-top:.25rem;padding:.5rem;border:1px solid #4a5568;border-radius:6px;background:#1a1d29;color:#e8eaed}.edit-modal__error{color:#f87171;font-size:.875rem;margin:0 0 .5rem}.edit-modal__actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem}.edit-modal__actions button{padding:.5rem 1rem;border:none;border-radius:6px;cursor:pointer;font-size:.9rem}.edit-modal__actions button[type=button]{background:#4a5568;color:#e8eaed}.edit-modal__actions button[type=submit]{background:#5b7cff;color:#fff}.edit-modal__actions button[type=submit]:disabled{opacity:.7}.check-in-modal__backdrop{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.check-in-modal{background:#2d3344;padding:1.5rem;border-radius:12px;width:100%;max-width:360px}.check-in-modal h2{margin:0 0 .5rem;font-size:1.25rem;color:#e8eaed;line-height:1.3}.check-in-modal__hint{margin:0 0 1rem;font-size:.875rem;color:#9aa0a6}.check-in-modal__shelves{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.check-in-modal__shelf-btn{display:block;width:100%;padding:.6rem 1rem;text-align:left;font-size:.95rem;color:#e8eaed;background:#3d4455;border:1px solid #4a5568;border-radius:6px;cursor:pointer}.check-in-modal__shelf-btn:hover{background:#4a5568;border-color:#5b7cff}.check-in-modal__actions{margin-top:1rem;display:flex;justify-content:flex-end}.check-in-modal__actions button{padding:.5rem 1rem;border:none;border-radius:6px;background:#4a5568;color:#e8eaed;cursor:pointer;font-size:.9rem}.check-in-modal__actions button:hover{background:#5a6578}.shelf-view{min-height:100vh;background:#1a1d29;color:#e8eaed;padding-bottom:4rem}.shelf-view__loading{padding:3rem;text-align:center;color:#9aa0a6}.shelf-view__header{padding:1rem 1.5rem;display:flex;flex-wrap:wrap;align-items:center;gap:1rem;border-bottom:1px solid #2d3344}.shelf-view__header h1{margin:0;font-size:1.5rem}.shelf-view__actions{display:flex;gap:.5rem;margin-left:auto}.shelf-view__actions input[type=search]{padding:.5rem .75rem;border:1px solid #4a5568;border-radius:6px;background:#2d3344;color:#e8eaed;min-width:200px}.shelf-view__actions button{padding:.5rem 1rem;border:none;border-radius:6px;background:#5b7cff;color:#fff;cursor:pointer}.shelf-row{padding:1rem 1.5rem;border-bottom:1px solid #2d3344}.shelf-row[data-droppable=true]{background:#5b7cff14}.shelf-row__header{margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.shelf-row__drag-handle{cursor:grab;color:#6b7280;font-size:1rem;line-height:1;padding:.25rem;-webkit-user-select:none;user-select:none;border-radius:4px}.shelf-row__drag-handle:hover{color:#9aa0a6;background:#ffffff0f}.shelf-row__drag-handle:active{cursor:grabbing}.shelf-row__collapse{display:flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;padding:0;border:none;border-radius:4px;background:transparent;color:#9aa0a6;cursor:pointer;transition:color .15s,background .15s}.shelf-row__collapse:hover{color:#e8eaed;background:#ffffff14}.shelf-row__collapse-icon{font-size:.7rem;transition:transform .2s}.shelf-row--collapsed .shelf-row__header{margin-bottom:0}.shelf-row__count{font-size:.9rem;color:#9aa0a6;margin-left:.25rem}.shelf-row--dragging{opacity:.85;z-index:1}.shelf-row__title{margin:0;font-size:1.1rem;font-weight:600;color:#c4c8cc}.shelf-row__books{display:flex;flex-wrap:wrap;gap:1rem}.shelf-row__book-wrap{cursor:grab}.shelf-row__book-wrap:active{cursor:grabbing}.shelf-view__search-results{padding:1rem 1.5rem}.shelf-view__search-results h2{margin:0 0 1rem;font-size:1.1rem}.shelf-view__search-results .shelf-row__books{margin-bottom:1rem}.shelf-view__search-results button{padding:.5rem 1rem;border:none;border-radius:6px;background:#4a5568;color:#e8eaed;cursor:pointer}.shelf-view__add{position:fixed;bottom:1.5rem;right:1.5rem}.shelf-view__add button{padding:.75rem 1.25rem;border:none;border-radius:8px;background:#5b7cff;color:#fff;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #5b7cff59}.shelf-view__add button:hover{background:#4a6bf5}.shelf-view__user{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#9aa0a6}.shelf-view__manage{font-size:.875rem;color:#9aa0a6;text-decoration:none}.shelf-view__manage:hover{color:#e8eaed}.shelf-view__logout{padding:.35rem .6rem;font-size:.8rem;background:#3d4455;color:#c4c8cc;border:none;border-radius:4px;cursor:pointer}.shelf-view__logout:hover{background:#4a5568;color:#e8eaed}:root{--react-pdf-annotation-layer: 1;--annotation-unfocused-field-background: url("data:image/svg+xml;charset=UTF-8,<svg width='1px' height='1px' xmlns='http://www.w3.org/2000/svg'><rect width='100%' height='100%' style='fill:rgba(0, 54, 255, 0.13);'/></svg>");--input-focus-border-color: Highlight;--input-focus-outline: 1px solid Canvas;--input-unfocused-border-color: transparent;--input-disabled-border-color: transparent;--input-hover-border-color: black;--link-outline: none}@media screen and (forced-colors:active){:root{--input-focus-border-color: CanvasText;--input-unfocused-border-color: ActiveText;--input-disabled-border-color: GrayText;--input-hover-border-color: Highlight;--link-outline: 1.5px solid LinkText}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid selectedItem}.annotationLayer .linkAnnotation:hover{-webkit-backdrop-filter:invert(100%);backdrop-filter:invert(100%)}}.annotationLayer{position:absolute;top:0;left:0;pointer-events:none;transform-origin:0 0;z-index:3}.annotationLayer[data-main-rotation="90"] .norotate{transform:rotate(270deg) translate(-100%)}.annotationLayer[data-main-rotation="180"] .norotate{transform:rotate(180deg) translate(-100%,-100%)}.annotationLayer[data-main-rotation="270"] .norotate{transform:rotate(90deg) translateY(-100%)}.annotationLayer canvas{position:absolute;width:100%;height:100%}.annotationLayer section{position:absolute;text-align:initial;pointer-events:auto;box-sizing:border-box;margin:0;transform-origin:0 0}.annotationLayer .linkAnnotation{outline:var(--link-outline)}.textLayer.selecting~.annotationLayer section{pointer-events:none}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a{position:absolute;font-size:1em;top:0;left:0;width:100%;height:100%}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a:hover{opacity:.2;background:#ff0;box-shadow:0 2px 10px #ff0}.annotationLayer .textAnnotation img{position:absolute;cursor:pointer;width:100%;height:100%;top:0;left:0}.annotationLayer .textWidgetAnnotation :is(input,textarea),.annotationLayer .choiceWidgetAnnotation select,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{background-image:var(--annotation-unfocused-field-background);border:2px solid var(--input-unfocused-border-color);box-sizing:border-box;font:calc(9px * var(--total-scale-factor)) sans-serif;height:100%;margin:0;vertical-align:top;width:100%}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid red}.annotationLayer .choiceWidgetAnnotation select option{padding:0}.annotationLayer .buttonWidgetAnnotation.radioButton input{border-radius:50%}.annotationLayer .textWidgetAnnotation textarea{resize:none}.annotationLayer .textWidgetAnnotation :is(input,textarea)[disabled],.annotationLayer .choiceWidgetAnnotation select[disabled],.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input[disabled]{background:none;border:2px solid var(--input-disabled-border-color);cursor:not-allowed}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:hover{border:2px solid var(--input-hover-border-color)}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation.checkBox input:hover{border-radius:2px}.annotationLayer .textWidgetAnnotation :is(input,textarea):focus,.annotationLayer .choiceWidgetAnnotation select:focus{background:none;border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) :focus{background-image:none;background-color:transparent}.annotationLayer .buttonWidgetAnnotation.checkBox :focus{border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.radioButton :focus{border:2px solid var(--input-focus-border-color);outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after,.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{background-color:CanvasText;content:"";display:block;position:absolute}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{height:80%;left:45%;width:1px}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before{transform:rotate(45deg)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{transform:rotate(-45deg)}.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{border-radius:50%;height:50%;left:30%;top:20%;width:50%}.annotationLayer .textWidgetAnnotation input.comb{font-family:monospace;padding-left:2px;padding-right:0}.annotationLayer .textWidgetAnnotation input.comb:focus{width:103%}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{appearance:none}.annotationLayer .popupTriggerArea{height:100%;width:100%}.annotationLayer .fileAttachmentAnnotation .popupTriggerArea{position:absolute}.annotationLayer .popupWrapper{position:absolute;font-size:calc(9px * var(--total-scale-factor));width:100%;min-width:calc(180px * var(--total-scale-factor));pointer-events:none}.annotationLayer .popup{position:absolute;max-width:calc(180px * var(--total-scale-factor));background-color:#ff9;box-shadow:0 calc(2px * var(--total-scale-factor)) calc(5px * var(--total-scale-factor)) #888;border-radius:calc(2px * var(--total-scale-factor));padding:calc(6px * var(--total-scale-factor));margin-left:calc(5px * var(--total-scale-factor));cursor:pointer;font:message-box;white-space:normal;word-wrap:break-word;pointer-events:auto}.annotationLayer .popup>*{font-size:calc(9px * var(--total-scale-factor))}.annotationLayer .popup h1{display:inline-block}.annotationLayer .popupDate{display:inline-block;margin-left:calc(5px * var(--total-scale-factor))}.annotationLayer .popupContent{border-top:1px solid rgba(51,51,51,1);margin-top:calc(2px * var(--total-scale-factor));padding-top:calc(2px * var(--total-scale-factor))}.annotationLayer .richText>*{white-space:pre-wrap;font-size:calc(9px * var(--total-scale-factor))}.annotationLayer .highlightAnnotation,.annotationLayer .underlineAnnotation,.annotationLayer .squigglyAnnotation,.annotationLayer .strikeoutAnnotation,.annotationLayer .freeTextAnnotation,.annotationLayer .lineAnnotation svg line,.annotationLayer .squareAnnotation svg rect,.annotationLayer .circleAnnotation svg ellipse,.annotationLayer .polylineAnnotation svg polyline,.annotationLayer .polygonAnnotation svg polygon,.annotationLayer .caretAnnotation,.annotationLayer .inkAnnotation svg polyline,.annotationLayer .stampAnnotation,.annotationLayer .fileAttachmentAnnotation{cursor:pointer}.annotationLayer section svg{position:absolute;width:100%;height:100%;top:0;left:0}.annotationLayer .annotationTextContent{position:absolute;width:100%;height:100%;opacity:0;color:transparent;-webkit-user-select:none;user-select:none;pointer-events:none}.annotationLayer .annotationTextContent span{width:100%;display:inline-block}:root{--react-pdf-text-layer: 1;--highlight-bg-color: rgba(180, 0, 170, 1);--highlight-selected-bg-color: rgba(0, 100, 0, 1)}@media screen and (forced-colors:active){:root{--highlight-bg-color: Highlight;--highlight-selected-bg-color: ButtonText}}[data-main-rotation="90"]{transform:rotate(90deg) translateY(-100%)}[data-main-rotation="180"]{transform:rotate(180deg) translate(-100%,-100%)}[data-main-rotation="270"]{transform:rotate(270deg) translate(-100%)}.textLayer{position:absolute;text-align:initial;inset:0;overflow:hidden;line-height:1;text-size-adjust:none;forced-color-adjust:none;transform-origin:0 0;z-index:2}.textLayer :is(span,br){color:transparent;position:absolute;white-space:pre;cursor:text;margin:0;transform-origin:0 0}.textLayer span.markedContent{top:0;height:0}.textLayer .highlight{margin:-1px;padding:1px;background-color:var(--highlight-bg-color);border-radius:4px}.textLayer .highlight.appended{position:initial}.textLayer .highlight.begin{border-radius:4px 0 0 4px}.textLayer .highlight.end{border-radius:0 4px 4px 0}.textLayer .highlight.middle{border-radius:0}.textLayer .highlight.selected{background-color:var(--highlight-selected-bg-color)}.textLayer br::selection{background:transparent}.textLayer .endOfContent{display:block;position:absolute;inset:100% 0 0;z-index:-1;cursor:default;-webkit-user-select:none;user-select:none}.textLayer.selecting .endOfContent{top:0}.hiddenCanvasElement{position:absolute;top:0;left:0;width:0;height:0;display:none}.reader{min-height:100vh;background:#1a1d29;color:#e8eaed;display:flex;flex-direction:column}.reader--loading{align-items:center;justify-content:center;color:#9aa0a6}.reader__header{padding:.75rem 1rem;border-bottom:1px solid #2d3344;display:flex;flex-wrap:wrap;align-items:center;gap:.75rem}.reader__back{background:none;border:none;color:#9aa0a6;cursor:pointer;font-size:.9rem}.reader__back:hover{color:#e8eaed}.reader__title{margin:0;font-size:1.1rem;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reader__controls{display:flex;align-items:center;gap:.5rem}.reader__controls input[type=search]{padding:.4rem .6rem;border:1px solid #4a5568;border-radius:6px;background:#2d3344;color:#e8eaed;width:180px}.reader__controls button{padding:.4rem .75rem;border:none;border-radius:6px;background:#5b7cff;color:#fff;cursor:pointer;font-size:.875rem}.reader__nav{min-width:3rem}.reader__nav:disabled{opacity:.5;cursor:not-allowed}.reader__page{font-size:.875rem;color:#9aa0a6}.reader__search-hits{padding:.5rem 1rem;background:#2d3344;border-bottom:1px solid #252a3a;max-height:120px;overflow-y:auto}.reader__hit{font-size:.85rem;margin-bottom:.25rem;color:#c4c8cc}.reader__hit mark{background:#5b7cff66;color:#e8eaed}.reader__content{flex:1;padding:1rem;display:flex;justify-content:center;align-items:flex-start;min-height:0}.reader__page-area{display:flex;justify-content:center;cursor:grab;-webkit-user-select:none;user-select:none}.reader__page-area:active{cursor:grabbing}.reader__doc-loading{padding:2rem;color:#9aa0a6}.reader__content .react-pdf__Page{box-shadow:0 4px 24px #0000004d}.reader-style-picker{min-height:100vh;padding:1.2rem;display:grid;place-items:center;color:#eef1f6;background:radial-gradient(900px 440px at 15% -10%,rgba(120,158,246,.22),transparent 56%),radial-gradient(760px 380px at 85% 0%,rgba(96,210,187,.18),transparent 58%),linear-gradient(140deg,#131a2a,#1b253a 55%,#122137)}.reader-style-picker__panel{width:min(760px,100%);border-radius:18px;border:1px solid rgba(185,207,243,.26);background:#0b111ed6;box-shadow:0 20px 48px #03081273;padding:1.2rem 1rem 1.1rem}.reader-style-picker__back{border:none;background:transparent;color:#9bb0d2;cursor:pointer;padding:0;font-size:.88rem}.reader-style-picker__kicker{margin:.8rem 0 .3rem;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:#8ca2ca}.reader-style-picker__panel h1{margin:0;font-size:clamp(1.25rem,3vw,1.58rem);line-height:1.25}.reader-style-picker__intro{margin:.38rem 0 1rem;color:#a6b5d1}.reader-style-picker__options{display:grid;gap:.68rem}.reader-style-picker__option{border:1px solid rgba(139,177,235,.34);background:linear-gradient(140deg,#2b456e42,#111e3785);border-radius:12px;color:#ebf3ff;text-align:left;cursor:pointer;padding:.9rem}.reader-style-picker__option:hover{border-color:#8bb1eb94;background:linear-gradient(140deg,#42629752,#1a2b4b8f)}.reader-style-picker__option-title{display:block;font-size:1rem;font-weight:700;margin-bottom:.2rem}.reader-style-picker__option-copy{display:block;color:#aac1e2;font-size:.88rem;line-height:1.35}.reader-style-picker__error{margin-top:1rem;color:#e88;font-size:.9rem}@media(max-width:720px){.reader__controls{width:100%;overflow-x:auto;padding-bottom:.2rem}.reader__controls input[type=search]{width:11rem}}.book-management{padding:1rem;max-width:1200px;margin:0 auto}.book-management__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:.75rem}.book-management__header h1{margin:0;font-size:1.5rem;color:var(--app-fg, #e8eaed)}.book-management__actions{display:flex;gap:.5rem}.book-management__back{padding:.5rem 1rem;border:1px solid var(--app-border, #4a5568);border-radius:8px;background:transparent;color:var(--app-fg, #e8eaed);cursor:pointer;font-size:.9rem}.book-management__back:hover{background:#ffffff0f}.book-management__loading,.book-management__empty{color:var(--app-muted, #9aa0a6);margin:2rem 0}.book-management__error{color:#f87171;margin:0 0 1rem;font-size:.9rem}.book-management__table-wrap{overflow-x:auto}.book-management__table{width:100%;border-collapse:collapse;font-size:.9rem}.book-management__table th,.book-management__table td{padding:.6rem .75rem;text-align:left;border-bottom:1px solid var(--app-border, #3d4452)}.book-management__table th{color:var(--app-muted, #9aa0a6);font-weight:600}.book-management__table td{color:var(--app-fg, #e8eaed)}.book-management__table tbody tr:hover{background:#ffffff08}.book-management__btn{padding:.4rem .75rem;margin-right:.5rem;margin-bottom:.25rem;border:none;border-radius:6px;background:#5b7cff;color:#fff;cursor:pointer;font-size:.85rem}.book-management__btn:hover:not(:disabled){background:#4a6bf5}.book-management__btn:disabled{opacity:.7;cursor:not-allowed}.book-management__btn--secondary{background:transparent;border:1px solid var(--app-border, #4a5568);color:var(--app-fg, #e8eaed)}.book-management__btn--secondary:hover:not(:disabled){background:#ffffff0f}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:#1a1d29;color:#e8eaed}.app-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;color:#9aa0a6}.react-pdf__Page{margin:0 auto}.react-pdf__Page__textContent span{color:transparent;position:absolute;white-space:pre;transform-origin:0% 0%;pointer-events:none}.react-pdf__Page__annotations{position:absolute;inset:0}.react-pdf__Page__annotations .linkAnnotation>a{position:absolute;font-size:1em;top:0;left:0;width:100%;height:100%}.react-pdf__Page__annotations .linkAnnotation>a:hover{opacity:.2;background:#5b7cff}
