:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.book-list{display:flex;flex-wrap:wrap;justify-content:center;padding:2rem;background-color:#f8f8f8;min-height:100vh}body,html,#root{margin:0;padding:0;width:100%;height:100%;background-color:#141414;color:#fff;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;overflow-x:hidden}.App{display:flex;flex-direction:column;min-height:100vh;width:100%;background-color:#141414;box-sizing:border-box}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}html,body{height:100%;width:100%;overflow:hidden;background-color:#000}.splash-container{display:flex;justify-content:center;align-items:center;height:100vh;width:100vw;background-color:#000;position:absolute;top:0;left:0;z-index:500;overflow:hidden;opacity:1;transition:opacity 1s ease-out}.splash-container.fade-out{opacity:0}.logo{max-width:80%;max-height:80%;width:auto;height:auto;transition:none!important;filter:none!important;box-shadow:none!important;outline:none!important;cursor:default!important}.logo:hover,.logo:focus,.logo:active{filter:none!important;box-shadow:none!important;outline:none!important;transition:none!important;cursor:default!important}@media (max-width: 600px){.logo{max-width:70%;max-height:70%}}.logo-wrapper{display:flex;flex-direction:column;align-items:center}.secret-message{margin-top:1rem;color:#ff6f91;font-style:italic;font-size:1.2rem;text-align:center;animation:fadeIn 1s ease forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.top-bar{position:relative;display:flex;align-items:center;justify-content:space-between;padding:1rem 3rem;background-color:#242424;color:#fff;width:100%;height:80px;box-sizing:border-box;z-index:1000}.logo-container{position:absolute;left:50%;transform:translate(-50%);pointer-events:none}.top-logo{height:40px;width:auto;display:block}.nav-links{display:flex;gap:1.5rem;flex-shrink:0}.left-nav{flex:1}.right-nav{flex:1;display:flex;justify-content:flex-end;min-width:0}.nav-links a{color:#fff;text-decoration:none;font-size:1rem;white-space:nowrap;transition:color .3s ease;display:flex;align-items:center;gap:.5rem;padding:.5rem}.nav-links a:hover{color:#61dafb}.mobile-menu-button{display:none}@media (max-width: 768px){.top-bar{height:60px;padding:1rem 1.5rem;justify-content:center}.mobile-menu-button{display:flex;background:none;border:none;color:#fff;cursor:pointer;padding:.5rem;margin-left:0;position:absolute;left:1.5rem;top:50%;transform:translateY(-50%);width:32px;height:32px;align-items:center;justify-content:center;transition:transform .3s ease;z-index:1100}.mobile-menu-button.open{transform:translateY(-50%) rotate(90deg)}.left-nav,.right-nav{display:none}.logo-container{position:static;transform:none;pointer-events:auto}.mobile-dropdown{position:absolute;top:60px;left:0;right:0;background-color:#242424;flex-direction:column;gap:1rem;padding:1rem 2rem;max-height:0;overflow:hidden;opacity:0;transition:max-height .3s ease,opacity .3s ease;z-index:1000;border-top:1px solid #444;display:flex}.mobile-dropdown.open{max-height:300px;opacity:1}.nav-text{display:inline-block}}.book-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,240px));gap:1rem;padding:2rem;background-color:#141414;margin-top:80px}.book-card-link{text-decoration:none;width:100%}.book-card{background-color:#1e1e1e;border-radius:8px;overflow:hidden;color:#fff;display:flex;flex-direction:column;align-items:center;transition:transform .2s,box-shadow .2s;box-shadow:0 0 5px #0000004d;width:100%;height:360px}.book-cover{width:100%;aspect-ratio:6 / 7;object-fit:cover;display:block}.book-card:hover{transform:scale(1.05);box-shadow:0 8px 20px #646cff99}.progress-container{height:6px;background-color:#333;border-radius:0;overflow:hidden;width:100%;box-shadow:inset 0 0 3px #000000b3;margin:0}.progress-bar{height:100%;background:linear-gradient(90deg,#4caf50,#81c784);transition:width .4s ease-in-out;border-radius:0}.progress-label{font-size:.75rem;color:#aaa;margin-top:4px;margin-bottom:6px;text-align:center;-webkit-user-select:none;user-select:none;width:100%}.book-info{padding:0 10px 10px;text-align:center;flex-grow:1}.book-title{font-size:1rem;font-weight:600;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#ddd}@media (max-width: 480px){.book-grid{padding:1rem;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.book-cover{aspect-ratio:4 / 5}.book-title{font-size:.9rem}.book-info{padding:8px 6px}.book-card{height:auto;min-height:280px}}.books-section{padding:2rem 1rem;max-width:1200px;margin:0 auto}.section-wrapper{margin-bottom:2rem}.section-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;padding-left:.25rem}.book-grid{margin-top:0}.section-header:before{content:"";display:inline-block;width:6px;height:18px;background-color:#6366f1;border-radius:4px}.section-title{font-size:1.5rem;font-weight:600;color:#fff}@media (max-width: 480px){.books-section{padding:1.25rem .75rem;max-width:100%}.section-wrapper{margin-bottom:1.25rem}.section-header{gap:.35rem;padding-left:.15rem}.section-header:before{width:4px;height:14px}.section-title{font-size:1.2rem}}.about-container{max-width:800px;margin:6rem auto 2rem;padding:2rem;background-color:#1e1e1e;color:#fff;border-radius:12px;box-shadow:0 4px 10px #0000004d;font-family:Segoe UI,sans-serif;line-height:1.6;text-align:center}.profile-card{margin-top:2rem;background-color:#2c2c2c;padding:2rem;border-radius:12px;box-shadow:0 2px 6px #0000004d}.profile-image{width:120px;height:120px;border-radius:50%;object-fit:cover;margin-bottom:1rem;border:2px solid #61dafb}.profile-card h2{margin-bottom:.5rem;color:#61dafb}.role{font-weight:700;margin-bottom:1rem;color:#ccc}.bio{font-style:italic;margin-bottom:1rem}.social-links a{margin:0 .5rem;color:#61dafb;text-decoration:none;font-weight:700}.social-links a:hover{text-decoration:underline}:root{--color-bg: #121212;--color-text-primary: #e0e0e0;--color-text-secondary: #bbbbbb;--color-accent: #4caf50;--color-accent-hover: #388e3c;--color-shadow: rgba(0,0,0,.5)}body{background-color:var(--color-bg);color:var(--color-text-primary);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:0;padding:0}.book-page{max-width:1100px;margin:2rem auto;padding:2rem 3rem;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:#333}.book-page .back-button{display:inline-block;margin-bottom:1.5rem;font-size:1rem;color:#61dafb;text-decoration:none;font-weight:600;transition:color .3s ease}.book-page .back-button:hover{color:#21a1f1}.bookcard{display:grid;grid-template-columns:1fr 2fr;gap:3rem;padding:2rem;background:linear-gradient(145deg,#1e1e1e,#282828);border-radius:18px;box-shadow:0 10px 30px #0009;color:#fff}.bookcover-wrapper{position:relative}.bookcover-wrapper img.cover-image{width:100%;height:420px;object-fit:cover;border-radius:12px;box-shadow:0 6px 12px #00000026;transition:transform .3s ease}.bookcover-wrapper:hover img.cover-image{transform:scale(1.05)}.cover-background-text{display:none}.bookdetails{display:flex;flex-direction:column;justify-content:space-between}.title-large{font-size:2.5rem;margin-bottom:1rem;color:#ddd}.description-text{font-size:1.1rem;line-height:1.6;color:#ccc;white-space:pre-wrap;margin-bottom:1.5rem}.bookmetadata{color:#aaa;font-size:.9rem;line-height:1.4;font-style:italic;margin-bottom:2rem}.read-button.readbtn{padding:1rem 2rem;font-size:1.1rem;border-radius:12px;background-color:#4caf50;color:#fff;font-weight:700;text-align:center;text-decoration:none;transition:background-color .2s ease-in-out;width:fit-content}.read-button.readbtn:hover{background-color:#388e3c}@media (max-width: 768px){.bookcard{grid-template-columns:1fr;padding:1.5rem}.bookcover-wrapper img.cover-image{width:100%;height:auto;aspect-ratio:2 / 3}.cover-background-text{font-size:3rem;bottom:10px;left:10px}}@media (max-width: 480px){.book-page{padding:1rem 1.5rem}.title-large{font-size:1.8rem}.description-text{font-size:1rem;max-height:200px;overflow-y:auto;margin-bottom:1rem}.read-button.readbtn{width:100%;font-size:1.1rem;padding:12px 20px}.bookmetadata{font-size:.85rem;margin-bottom:1rem}}.bookdetails{min-width:0}.read-button.readbtn{max-width:100%;white-space:normal;word-wrap:break-word;box-sizing:border-box;display:inline-block}.text-container.bookdetails{overflow-wrap:break-word;word-break:break-word}.reader-page{height:100vh;overflow:hidden;display:flex;flex-direction:column;align-items:center;padding:16px;background-color:#121212;color:#eee;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.pdf-viewer{width:100%;max-width:920px;box-sizing:content-box;overflow-x:hidden;margin:0 auto;padding:0;display:flex;justify-content:flex-start;background:#121212;border-radius:6px;box-shadow:0 0 10px #ffffff1a}.pdf-viewer canvas{display:block!important;margin:0!important;padding:0!important;width:100%!important;max-width:100%!important;height:auto!important;vertical-align:top!important}.pdf-controls{margin-top:12px;display:flex;flex-wrap:wrap;justify-content:center;gap:12px;padding:0 8px;max-width:920px;width:100%}.pdf-controls button{background-color:#64b5f6;border:none;padding:8px 14px;border-radius:4px;cursor:pointer;font-weight:600;color:#eee}.pdf-controls button:disabled{background-color:#444;color:#999;cursor:not-allowed}.pdf-controls button:hover:not(:disabled){background-color:#90caf9}.pdf-controls input{width:60px;padding:6px;text-align:center;font-size:1rem;border-radius:4px;border:1px solid #ccc}.pdf-controls span{line-height:2.5rem;color:#eee}.back-button{color:#64b5f6;text-decoration:none;font-weight:700;margin-bottom:12px}.back-button:hover{text-decoration:underline}.spinner{border:4px solid rgba(255,255,255,.2);border-top:4px solid #64b5f6;border-radius:50%;width:36px;height:36px;animation:spin 1s linear infinite;margin:40px auto}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 600px){.reader-page{padding:12px}.pdf-viewer{max-width:100vw!important;width:100vw!important;height:auto!important;overflow-y:visible!important;margin:0!important;padding:0!important}.pdf-controls{flex-direction:row;justify-content:center;align-items:center;flex-wrap:wrap;gap:8px;padding:0;margin-top:12px;width:100%}.pdf-controls button{font-size:.9rem;padding:6px 10px;border-radius:6px;min-width:70px}.pdf-controls input{width:60px;font-size:.9rem;padding:6px;border-radius:6px}.pdf-controls span{font-size:.9rem;line-height:1}}: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(--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(--scale-factor));width:100%;min-width:calc(180px * var(--scale-factor));pointer-events:none}.annotationLayer .popup{position:absolute;max-width:calc(180px * var(--scale-factor));background-color:#ff9;box-shadow:0 calc(2px * var(--scale-factor)) calc(5px * var(--scale-factor)) #888;border-radius:calc(2px * var(--scale-factor));padding:calc(6px * var(--scale-factor));margin-left:calc(5px * var(--scale-factor));cursor:pointer;font:message-box;white-space:normal;word-wrap:break-word;pointer-events:auto}.annotationLayer .popup>*{font-size:calc(9px * var(--scale-factor))}.annotationLayer .popup h1{display:inline-block}.annotationLayer .popupDate{display:inline-block;margin-left:calc(5px * var(--scale-factor))}.annotationLayer .popupContent{border-top:1px solid rgba(51,51,51,1);margin-top:calc(2px * var(--scale-factor));padding-top:calc(2px * var(--scale-factor))}.annotationLayer .richText>*{white-space:pre-wrap;font-size:calc(9px * var(--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;top:0;right:0;bottom:0;left: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;top:100%;right:0;bottom:0;left: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}
