@charset "UTF-8";.book-card{background:#fff;border-radius:16px;overflow:hidden;border:2px solid #e9d5ff;transition:all .3s ease;cursor:pointer;display:flex;flex-direction:column}.book-card:hover{border-color:#a855f7}.book-card:hover .open-button{background:#7c3aed}.book-preview{width:100%;height:220px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#faf5ff,#f3e8ff);overflow:hidden;position:relative}.book-preview .thumbnail-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;opacity:0;transition:opacity .3s ease}.book-preview .thumbnail-image.loaded{opacity:1}.preview-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#faf5ff,#f3e8ff);z-index:5}.preview-error{padding:2rem;text-align:center;color:#6b7280;font-size:.9rem;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:.5rem}.preview-error:before{content:"⚠️";font-size:2rem;opacity:.5}.spinner{width:36px;height:36px;border:3px solid #e9d5ff;border-top-color:#8b5cf6;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.preview-error{color:#ef4444}.book-info{padding:1rem;display:flex;flex-direction:column;gap:.25rem;flex:1}.book-title{font-size:1rem;font-weight:700;color:#7c3aed;margin:0}.book-description{font-size:.8rem;color:#6b7280;margin:0;line-height:1.4;flex:1;min-height:2.5rem}.book-pages{font-size:.85rem;color:#9ca3af;margin:0}.encrypted-badge{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;font-weight:600;color:#7c3aed;background:#f3e8ff;padding:.25rem .75rem;border-radius:9999px;width:-moz-fit-content;width:fit-content;margin-top:.25rem}.open-button{margin-top:auto;padding:.5rem 1rem;background:#8b5cf6;color:#fff;border:2px solid #8b5cf6;border-radius:12px;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .2s;text-transform:uppercase;box-shadow:0 3px #6d28d9;margin-bottom:3px}.open-button:hover{background:#7c3aed;border-color:#7c3aed}.open-button:active{margin-top:auto;margin-bottom:0;box-shadow:none}@media(max-width:768px){.book-preview{height:180px}.book-info{padding:.75rem}.book-title{font-size:.9rem}}: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{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{-webkit-appearance:none;-moz-appearance:none;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;-moz-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;-webkit-text-size-adjust:none;-moz-text-size-adjust:none;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::-moz-selection{background:transparent}.textLayer br::selection{background:transparent}.textLayer .endOfContent{display:block;position:absolute;inset:100% 0 0;z-index:-1;cursor:default;-webkit-user-select:none;-moz-user-select:none;user-select:none}.textLayer.selecting .endOfContent{top:0}.hiddenCanvasElement{position:absolute;top:0;left:0;width:0;height:0;display:none}@keyframes fbFadeIn{0%{opacity:0}to{opacity:1}}@keyframes fbSpin{to{transform:rotate(360deg)}}.fb-overlay{position:fixed;inset:0;background:linear-gradient(135deg,#faf5ff,#ede9fe);z-index:1000;display:flex;align-items:center;justify-content:center;animation:fbFadeIn .25s ease-in}.fb-container{width:100%;height:100%;display:flex;flex-direction:column}.fb-toolbar{height:56px;padding:0 12px;background:#fffffff2;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #e9d5ff}.fb-toolbar-left,.fb-toolbar-right{display:flex;gap:8px}.fb-toolbar-btn{width:36px;height:36px;border-radius:8px;border:none;background:#ede9fe;color:#6d28d9;font-weight:600;cursor:pointer}.fb-close-btn{background:#7c3aed;color:#fff}.fb-content{flex:1;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.fb-content.fb-zoomed{overflow:auto}.fb-scroll-spacer{display:flex;align-items:center;justify-content:center}.fb-zoom-wrapper{transform-origin:center center;display:flex;align-items:center;justify-content:center}.fb-book{background:#fff;box-shadow:0 20px 45px #00000040;isolation:isolate}.fb-book .stf__wrapper,.fb-book .stf__block,.fb-book .stf__item{background:#fff!important;opacity:1!important}.fb-page-wrapper{width:100%;height:100%;position:relative;background:#fff!important;overflow:hidden;border:1px solid #d1d5db;backface-visibility:hidden;-webkit-backface-visibility:hidden;transform-style:preserve-3d}.fb-page-left,.fb-page-right{background:#fff!important}.fb-page-shadow{position:absolute;inset:0;pointer-events:none}.fb-page-left .fb-page-shadow{background:linear-gradient(to left,#0000001f,#0000)}.fb-page-right .fb-page-shadow{background:linear-gradient(to right,#0000001f,#0000)}.react-pdf__Page{width:100%!important;height:100%!important;display:flex!important;align-items:center;justify-content:center;background:#fff!important;backface-visibility:hidden;-webkit-backface-visibility:hidden}.react-pdf__Page canvas{width:100%!important;height:auto!important;max-height:100%;display:block;background:#fff!important;backface-visibility:hidden;-webkit-backface-visibility:hidden}.fb-page-loading{position:absolute;inset:0;background:#fff;z-index:5;display:flex;align-items:center;justify-content:center}.fb-spinner,.fb-spinner-main{width:42px;height:42px;border-radius:50%;border:4px solid #e9d5ff;border-top-color:#7c3aed;animation:fbSpin .8s linear infinite}.fb-controls{height:56px;background:#fffffff2;border-top:1px solid #e9d5ff;display:flex;align-items:center;justify-content:center;gap:24px}.fb-nav-button{padding:6px 18px;border-radius:6px;border:none;background:#8b5cf6;color:#fff;font-weight:600;cursor:pointer}.fb-nav-button:disabled{background:#e9d5ff;cursor:not-allowed}.fb-page-info{min-width:140px;text-align:center;font-weight:600;color:#6d28d9}@media(max-width:768px){.fb-toolbar,.fb-controls{height:48px}.fb-page-info{min-width:90px;font-size:.8rem}}
