@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@500;600;700;800&family=Merriweather:ital,wght@0,300;0,400;0,700;1,300&display=swap";:root{--bg-primary: #ffffff;--bg-secondary: #f6f7f9;--bg-tertiary: #eef0f4;--border: rgba(0, 0, 0, .08);--text-primary: #111318;--text-secondary: #64748b;--text-muted: #94a3b8;--glass-bg: rgba(0, 0, 0, .03);--glass-border: rgba(0, 0, 0, .07);--accent-primary: #4f46e5;--accent-secondary: #7c3aed;--accent-soft: rgba(79, 70, 229, .08);--danger: #ef4444;--success: #22c55e;--warn: #f59e0b;--font-main: "Inter", sans-serif;--font-heading: "Outfit", sans-serif;--font-reader: "Merriweather", serif;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-xs: 4px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 18px;--radius-xl: 24px;--shadow-book: 0 2px 8px rgba(0, 0, 0, .12), 0 0 0 1px rgba(0, 0, 0, .04);--shadow-book-hover: 0 12px 32px rgba(0, 0, 0, .18), 0 2px 8px rgba(0, 0, 0, .1);--shadow-card: 0 1px 3px rgba(0, 0, 0, .08);--shadow-modal: 0 24px 80px rgba(0, 0, 0, .14);--transition-fast: .18s ease;--transition-normal: .28s ease;--transition-slow: .4s cubic-bezier(.22, 1, .36, 1)}[data-app-theme=dark]{--bg-primary: #0c0c0f;--bg-secondary: #17171c;--bg-tertiary: #1e1e25;--border: rgba(255, 255, 255, .07);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--glass-bg: rgba(255, 255, 255, .04);--glass-border: rgba(255, 255, 255, .08);--shadow-book: 0 2px 12px rgba(0, 0, 0, .5);--shadow-book-hover: 0 16px 40px rgba(0, 0, 0, .7)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{scroll-behavior:smooth}body{font-family:var(--font-main);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.55;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color var(--transition-normal),color var(--transition-normal)}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);letter-spacing:-.025em;line-height:1.2}button{cursor:pointer;border:none;outline:none;background:none;font-family:inherit;transition:var(--transition-fast);-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}input,textarea{font-family:inherit}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.glass{background:var(--glass-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border)}.brand-gradient{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.loader-container{height:100vh;display:flex;justify-content:center;align-items:center;background-color:var(--bg-primary)}.loader{width:40px;height:40px;border:3px solid var(--border);border-bottom-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:10px 20px;border-radius:var(--radius-md);font-weight:600;font-size:.9rem;transition:all var(--transition-fast)}.btn-primary{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;box-shadow:0 4px 14px #4f46e54d}.btn-primary:hover{filter:brightness(1.08)}.btn-primary:active{transform:scale(.97)}.btn-ghost{color:var(--text-secondary);background:transparent}.btn-ghost:hover{background:var(--bg-secondary);color:var(--text-primary)}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);padding:var(--spacing-md);position:relative;overflow:hidden}.auth-container:before{content:"";position:absolute;top:-10%;left:-10%;width:40%;height:40%;background:radial-gradient(circle,rgba(79,70,229,.08) 0%,transparent 70%);z-index:0}.auth-card{width:100%;max-width:420px;padding:var(--spacing-xl);border-radius:var(--radius-lg);background:var(--bg-primary);box-shadow:0 10px 25px #0000000d;border:1px solid var(--border);animation:fadeIn .4s ease-out;position:relative;z-index:1}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.auth-header{text-align:center;margin-bottom:var(--spacing-xl)}.brand-logo{font-size:2.2rem;font-weight:800;margin-bottom:var(--spacing-xs);font-family:var(--font-heading);letter-spacing:-.04em}.brand-tagline{color:var(--text-secondary);font-size:.95rem;font-weight:500}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.input-group{display:flex;flex-direction:column;gap:6px}.input-group label{font-size:.85rem;font-weight:600;color:var(--text-primary);margin-left:2px}.input-group input{padding:13px 16px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);font-size:1rem;transition:all var(--transition-fast)}.input-group input:focus{border-color:var(--accent-primary);background:var(--bg-primary);box-shadow:0 0 0 3px #4f46e51a;outline:none}.auth-btn{padding:13px 16px;border-radius:var(--radius-md);font-weight:700;font-size:.95rem;margin-top:var(--spacing-xs);display:flex;align-items:center;justify-content:center;gap:10px;transition:all var(--transition-fast)}.btn-primary{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;box-shadow:0 4px 12px #4f46e54d}.btn-primary:active{transform:scale(.98)}.btn-outline{border:1.5px solid var(--accent-primary);color:var(--accent-primary);background:transparent}.btn-outline:hover{background:var(--accent-soft)}.auth-footer{margin-top:var(--spacing-xl);text-align:center;font-size:.9rem;color:var(--text-secondary);border-top:1px solid var(--border);padding-top:var(--spacing-lg)}.link-btn{color:var(--accent-primary);font-weight:700;text-decoration:underline;background:none;border:none;padding:0;margin-left:6px;cursor:pointer}.divider{display:flex;align-items:center;text-align:center;margin:var(--spacing-lg) 0;color:var(--text-muted);font-size:.75rem;font-weight:700;letter-spacing:.05em}.divider:before,.divider:after{content:"";flex:1;border-bottom:1px solid var(--border)}.divider:not(:empty):before{margin-right:1.5em}.divider:not(:empty):after{margin-left:1.5em}.error-message{color:var(--danger);font-size:.85rem;text-align:center;margin-bottom:var(--spacing-md);padding:10px;background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);font-weight:500}.main-layout{display:flex;min-height:100vh;background-color:var(--bg-primary)}.sidebar{width:220px;min-height:100vh;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;padding:24px 12px;border-right:1px solid var(--border);background:var(--bg-primary);z-index:100;flex-shrink:0}.sidebar-brand{padding:0 8px;margin-bottom:32px}.brand-name{font-family:var(--font-heading);font-size:1.45rem;font-weight:800;letter-spacing:-.03em;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:block}.brand-tagline{font-size:.7rem;color:var(--text-muted);font-weight:500;margin-top:1px;letter-spacing:.01em}.nav-links{display:flex;flex-direction:column;gap:2px;flex:1}.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;color:var(--text-secondary);font-weight:500;font-size:.88rem;transition:all .15s ease;width:100%;text-align:left;background:transparent}.nav-item:hover{background:var(--bg-secondary);color:var(--text-primary)}.nav-item{-webkit-tap-highlight-color:transparent;touch-action:manipulation}.nav-item.active{background:var(--accent-soft);color:var(--accent-primary);font-weight:600}.sidebar-footer{margin-top:auto;padding-top:16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px}.user-profile{display:flex;align-items:center;gap:10px;padding:4px}.user-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;color:#fff;flex-shrink:0}.user-info{display:flex;flex-direction:column;overflow:hidden;min-width:0}.user-name{font-size:.83rem;font-weight:600;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;color:var(--text-primary)}.user-role{font-size:.7rem;color:var(--text-muted)}.sidebar-actions{display:flex;gap:4px}.icon-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:8px;color:var(--text-secondary);background:transparent;transition:all .15s ease}.icon-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.content-area{flex:1;padding:28px 36px;min-width:0;overflow-x:hidden}.topbar{display:flex;align-items:center;justify-content:flex-end;margin-bottom:28px;gap:12px}.search-bar{display:flex;align-items:center;gap:9px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:100px;padding:9px 16px;width:260px;transition:border-color .15s ease,box-shadow .15s ease}.search-bar:focus-within{border-color:var(--accent-primary);box-shadow:0 0 0 3px #4f46e51a}.search-bar input{background:transparent;border:none;color:var(--text-primary);width:100%;font-size:.87rem;outline:none;-webkit-text-size-adjust:100%}.search-bar input::placeholder{color:var(--text-muted)}.search-icon-color{color:var(--text-muted);flex-shrink:0}.mobile-topbar{display:none}@media(max-width:768px){.main-layout{flex-direction:column}.sidebar{position:fixed;inset:auto 0 0;width:100%;height:62px;min-height:unset;flex-direction:row;padding:0;border-right:none;border-top:1px solid var(--border);background:#ffffffeb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);z-index:200;justify-content:space-around;align-items:stretch}.sidebar-brand,.sidebar-footer{display:none}.nav-links{flex-direction:row;width:100%;justify-content:space-around;align-items:stretch;gap:0}.nav-item{flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 4px;font-size:.62rem;border-radius:0;flex:1;color:var(--text-muted)}.nav-item.active{color:var(--accent-primary);background:transparent;box-shadow:inset 0 2px 0 var(--accent-primary)}.content-area{padding:0 14px 80px}.topbar{display:none}.mobile-topbar{display:flex;align-items:center;gap:10px;padding:14px 0 16px;margin-bottom:6px}.mobile-brand-name{font-family:var(--font-heading);font-size:1.25rem;font-weight:800;letter-spacing:-.03em;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap}.mobile-search{flex:1}.search-bar{width:100%;padding:8px 14px}.search-bar input{font-size:16px}}.view-container{padding:0 0 100px}.section-header{display:flex;align-items:baseline;gap:10px;margin-bottom:22px}.section-title{font-size:1.55rem;font-weight:700;color:var(--text-primary);letter-spacing:-.03em}.section-count{font-size:.85rem;color:var(--text-muted);font-weight:500}.book-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:20px}.book-card{cursor:pointer;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.book-cover-wrapper{aspect-ratio:2 / 3;width:100%;border-radius:12px;overflow:hidden;position:relative;box-shadow:1px 1px 3px #0000001f,4px 4px 12px #00000014,inset -2px 0 4px #0000000a;transition:transform var(--transition-slow),box-shadow var(--transition-slow);will-change:transform,box-shadow;background:var(--bg-secondary);font-size:0}.book-card:hover .book-cover-wrapper{transform:scale(1.04) translateY(-6px);box-shadow:2px 2px 6px #0000001a,10px 20px 35px #00000024}.book-card:active .book-cover-wrapper{transform:scale(.975);transition-duration:.12s}.book-cover{width:100%;height:100%;object-fit:cover;image-rendering:-webkit-optimize-contrast;transition:filter .15s ease}.book-card:active .book-cover{filter:brightness(.85)}.book-lock-overlay{position:absolute;inset:0;background:#00000073;display:flex;align-items:flex-end;justify-content:flex-start;padding:10px;border-radius:inherit}.book-lock-icon{width:30px;height:30px;border-radius:8px;background:#fff3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;color:#fff}.book-cover-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:linear-gradient(145deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);color:var(--text-muted);font-size:.85rem;font-family:var(--font-heading);font-weight:600;padding:20px;text-align:center}.category-badge{position:absolute;top:10px;right:10px;padding:4px 10px;border-radius:100px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:5}.badge-premium{background:#f59e0be6;color:#fff}.book-card.skeleton .book-cover-wrapper{border-radius:12px;background:linear-gradient(100deg,var(--bg-secondary) 30%,var(--bg-tertiary) 50%,var(--bg-secondary) 70%);background-size:250% 100%;animation:shimmer 1.5s infinite ease-in-out;box-shadow:none}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-50% 0}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:100px 32px;gap:16px;color:var(--text-secondary);text-align:center}.empty-icon{width:72px;height:72px;border-radius:20px;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;color:var(--text-muted);margin-bottom:8px}.empty-state h3{font-size:1.2rem;color:var(--text-primary);font-weight:600}.empty-state p{font-size:.95rem;color:var(--text-secondary);max-width:320px;line-height:1.6}@media(min-width:769px)and (max-width:1200px){.book-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}}@media(max-width:768px){.view-container{padding:0 0 90px}.section-title{font-size:1.25rem}.book-grid{grid-template-columns:repeat(2,1fr);gap:12px}.book-cover-wrapper{border-radius:10px}.book-card:hover .book-cover-wrapper{transform:none;box-shadow:1px 1px 3px #0000001f,4px 4px 12px #00000014}.book-card:active .book-cover-wrapper{transform:scale(.95)}}: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-overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1000;display:flex;flex-direction:column;animation:readerFadeIn .3s cubic-bezier(.4,0,.2,1);-webkit-user-select:none;user-select:none;overflow:hidden;color:var(--text-primary);background:var(--bg-primary)}@keyframes readerFadeIn{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.reader-header{height:60px;padding:0 var(--spacing-xl);display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--glass-border);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);transition:transform .4s cubic-bezier(.23,1,.32,1),opacity .4s ease;z-index:2010}.reader-header.hidden{transform:translateY(-100%);opacity:0;pointer-events:none}.reader-viewport{flex:1;position:relative;overflow-y:auto;display:flex;flex-direction:column;align-items:center;padding:2rem 0;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;touch-action:pan-y;overflow-x:hidden;transition:background-color .3s ease}.paged-content-wrapper{width:100%;height:90%;max-width:850px;margin:0 auto;overflow:hidden;position:relative;cursor:pointer}.native-text-container{height:100%;width:100%;column-width:100%;column-count:1;column-fill:auto;column-gap:0;transition:transform .6s cubic-bezier(.16,1,.3,1),opacity .4s ease;box-sizing:border-box;color:var(--text-primary);text-align:left;padding:40px 0;-webkit-user-select:text;user-select:text;cursor:text}.native-text-container p,.pdf-native-p{font-family:Merriweather,serif;margin-bottom:2.2rem;text-indent:0;line-height:1.8;pointer-events:auto;font-weight:400;opacity:.95;orphans:3;widows:3;-webkit-hyphens:auto;hyphens:auto;word-break:break-word;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}.pdf-native-p strong{font-weight:800;color:var(--text-primary)}.pdf-native-p em{font-style:italic;opacity:.9}.pdf-native-p span{line-height:inherit;display:inline}.chapter-header{font-family:Inter,sans-serif;font-size:3.5em;font-weight:900;margin:1.5em 0 2.5rem;line-height:1.1;text-align:center;color:var(--text-primary);break-before:column;-webkit-column-break-before:column;letter-spacing:-.05em;animation:chapterFade .8s cubic-bezier(.16,1,.3,1);width:100%}@keyframes chapterFade{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.native-text-container p:first-of-type,.chapter-title+p{text-indent:0}.pdf-html-content{column-width:100%;column-count:1;column-fill:auto;column-gap:0;height:100%}.header-left{display:flex;align-items:center;gap:15px}.header-actions{display:flex;align-items:center;gap:12px}.action-btn{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-primary)!important;opacity:.9;transition:all .2s ease}.action-btn svg,.close-btn svg{stroke:currentColor}.book-info-minimal{flex:1;min-width:0}.reader-book-title{font-size:1rem;font-weight:700;color:var(--text-primary)!important;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:280px}.page-zone{display:none}.reader-controls{position:fixed;bottom:0;left:0;right:0;background:var(--bg-primary);border-top:1px solid var(--glass-border);padding:24px 40px;display:flex;flex-direction:column;gap:18px;transition:transform .4s cubic-bezier(.23,1,.32,1),opacity .4s ease;z-index:2010;-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);box-shadow:0 -15px 50px #0000004d}.reader-controls.hidden{transform:translateY(100%);opacity:0;pointer-events:none}.controls-upper{display:flex;justify-content:space-between;align-items:center}.control-group{display:flex;flex-direction:column;gap:8px}.group-label{font-size:.65rem;text-transform:uppercase;letter-spacing:1.5px;font-weight:900;opacity:.4}.control-row{display:flex;align-items:center;gap:12px;background:var(--glass-bg);padding:8px 18px;border-radius:14px;border:1px solid var(--glass-border)}.font-indicator{font-weight:800;font-size:1.1rem;opacity:.9}.progress-details{font-size:.9rem;font-weight:800;opacity:.8;background:var(--glass-bg);padding:6px 16px;border-radius:20px;border:1px solid var(--glass-border)}.theme-switcher{display:flex;gap:15px}.theme-dot{width:32px;height:32px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all .3s cubic-bezier(.175,.885,.32,1.275)}.theme-dot.active{border-color:var(--accent-primary);transform:scale(1.25);box-shadow:0 0 20px var(--accent-primary)}.theme-dot.light{background:#fff;border-color:#eee}.theme-dot.sepia{background:#f4ecd8}.theme-dot.dark{background:#1a1a1e}@media(max-width:768px){.reader-header{padding:0 var(--spacing-md);height:54px}.header-left{gap:10px}.reader-book-title{max-width:180px;font-size:.9rem}.reader-controls{padding:16px 16px 30px}.controls-upper{flex-direction:column;align-items:stretch;gap:12px}.control-group{flex-direction:row;justify-content:space-between;align-items:center}.control-row{padding:6px 12px}.progress-details{width:100%;text-align:center;order:-1;margin-bottom:5px;font-size:.8rem}.theme-switcher{gap:12px}.theme-dot{width:28px;height:28px}.pdf-render-container{gap:16px;padding:10px 0 120px}}.pdf-render-container{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:32px;padding:20px 0 100px;min-width:100%;width:fit-content;transition:filter .3s ease,transform .2s cubic-bezier(.2,0,0,1)}.reader-overlay[data-theme=light]{--bg-primary: #ffffff !important;--text-primary: #111318 !important;--glass-bg: rgba(0, 0, 0, .03) !important;--glass-border: rgba(0, 0, 0, .07) !important;background-color:var(--bg-primary)!important;color:var(--text-primary)!important}.reader-overlay[data-theme=dark]{--bg-primary: #121212 !important;--text-primary: #f8fafc !important;--glass-bg: rgba(255, 255, 255, .05) !important;--glass-border: rgba(255, 255, 255, .1) !important;background-color:var(--bg-primary)!important;color:var(--text-primary)!important}.reader-overlay[data-theme=sepia]{--bg-primary: #fbf0d9 !important;--text-primary: #5f4b32 !important;--glass-bg: rgba(95, 75, 50, .05) !important;--glass-border: rgba(95, 75, 50, .15) !important;background-color:var(--bg-primary)!important;color:var(--text-primary)!important}.theme-dark.pdf-render-container canvas{filter:invert(1) hue-rotate(180deg) brightness(.9) contrast(1.1)}.theme-sepia.pdf-render-container canvas{filter:sepia(.6) brightness(.9) contrast(1.05)}.pdf-page-shadow{box-shadow:0 15px 50px #0000004d;border-radius:4px;max-width:100vw;background-color:#fff}[data-theme=dark] .pdf-page-shadow{background-color:#121212}[data-theme=sepia] .pdf-page-shadow{background-color:#fbf0d9}.pdf-page-shadow canvas{max-width:none!important}.loader-container{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;background:transparent}.pdf-page-placeholder{background:var(--glass-bg);opacity:.1;transition:opacity .5s ease;border-radius:4px;margin:1.5rem auto;max-width:90%}.hidden-pdf{display:none!important}.reflow-text-container{max-width:800px;width:90%;margin:0 auto;padding:2rem;background:var(--glass-bg);color:var(--text-primary);border-radius:8px;box-shadow:0 10px 30px #0003;animation:reflowFadeIn .5s ease-out;line-height:1.8}.font-merriweather{font-family:Merriweather,serif}.font-inter{font-family:Inter,sans-serif}.font-outfit{font-family:Outfit,sans-serif}.font-switcher{display:flex;gap:8px;background:var(--bg-secondary);padding:4px;border-radius:8px;border:1px solid var(--glass-border)}.font-btn{padding:6px 12px;border-radius:6px;font-size:.85rem;color:var(--text-secondary);background:transparent;transition:all .2s ease}.font-btn:hover{color:var(--text-primary)}.font-btn.active{background:var(--accent-primary);color:#fff}.native-pdf-formatting p{margin-bottom:1.25em;text-align:justify;word-break:break-word;color:inherit}.native-pdf-formatting p:last-child{margin-bottom:0}.native-pdf-formatting strong{font-weight:700;color:var(--text-primary)}.native-pdf-formatting em{font-style:italic}@keyframes reflowFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.reflow-text-container .pdf-native-p{font-family:Merriweather,serif;margin-bottom:2rem;color:var(--text-primary);text-align:left;word-break:break-word;white-space:pre-wrap}.reflow-loading{display:flex;flex-direction:column;align-items:center;gap:12px;padding:4rem;opacity:.6;color:var(--text-primary)}.page-wrapper-responsive{width:100%;display:flex;flex-direction:column;align-items:center;margin-bottom:2rem}@media(max-width:768px){.reflow-text-container{padding:1.5rem 1rem;width:100%;border-radius:0;box-shadow:none;background:transparent;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}.page-wrapper-responsive{margin-bottom:1rem}.reader-header{height:56px;padding:0 16px}.action-btn{width:44px;height:44px;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.close-btn{-webkit-tap-highlight-color:transparent;touch-action:manipulation;padding:8px;color:var(--text-primary)!important}.reader-controls{padding:16px 20px}.controls-upper{flex-wrap:wrap;gap:14px}.font-switcher{gap:4px}.font-btn{padding:6px 10px;font-size:.8rem}}.pgate-backdrop{position:fixed;inset:0;background:#000000bf;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:9000;display:flex;align-items:flex-end;justify-content:center;animation:pgFadeIn .25s ease}@media(min-width:600px){.pgate-backdrop{align-items:center}}@keyframes pgFadeIn{0%{opacity:0}to{opacity:1}}.pgate-sheet{width:100%;max-width:480px;background:var(--bg-primary);border-radius:24px 24px 0 0;padding:0 0 env(safe-area-inset-bottom);animation:pgSlideUp .35s cubic-bezier(.2,0,0,1);overflow:hidden}@media(min-width:600px){.pgate-sheet{border-radius:20px}}@keyframes pgSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.pgate-handle{width:36px;height:4px;background:var(--glass-border);border-radius:2px;margin:12px auto 0}.pgate-book-preview{display:flex;align-items:center;gap:16px;padding:20px 24px 16px;border-bottom:1px solid var(--glass-border)}.pgate-cover{width:64px;height:96px;border-radius:8px;object-fit:cover;box-shadow:0 8px 24px #0000004d;flex-shrink:0}.pgate-cover-placeholder{width:64px;height:96px;border-radius:8px;background:linear-gradient(135deg,var(--bg-secondary),var(--bg-tertiary));display:flex;align-items:center;justify-content:center;flex-shrink:0}.pgate-book-meta h3{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0 0 4px;line-height:1.3}.pgate-book-meta p{font-size:.85rem;color:var(--text-secondary);margin:0}.pgate-lock-badge{display:inline-flex;align-items:center;gap:5px;background:#f59e0b26;color:#f59e0b;border:1px solid rgba(245,158,11,.3);border-radius:100px;padding:3px 10px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-top:8px}.pgate-body{padding:20px 24px 24px}.pgate-title{font-size:1.2rem;font-weight:700;color:var(--text-primary);margin:0 0 6px}.pgate-subtitle{font-size:.9rem;color:var(--text-secondary);margin:0 0 24px;line-height:1.5}.pgate-actions{display:flex;flex-direction:column;gap:12px}.pgate-btn-primary{width:100%;padding:15px 20px;border-radius:14px;font-size:1rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);box-shadow:0 4px 20px #6366f166;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.pgate-btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 28px #6366f180}.pgate-btn-primary:active{transform:scale(.97)}.pgate-btn-secondary{width:100%;padding:14px 20px;border-radius:14px;font-size:.95rem;font-weight:600;color:var(--text-primary);background:var(--glass-bg);border:1px solid var(--glass-border);transition:all .2s ease}.pgate-btn-secondary:hover{background:var(--bg-secondary)}.pgate-btn-ghost{width:100%;padding:12px;font-size:.85rem;color:var(--text-muted);text-align:center;transition:color .2s ease}.pgate-btn-ghost:hover{color:var(--text-secondary)}.pgate-plans{display:flex;flex-direction:column;gap:10px;margin-bottom:16px;max-height:45vh;overflow-y:auto}.pgate-plan-card{padding:14px 16px;border:2px solid var(--glass-border);border-radius:14px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:space-between;gap:12px}.pgate-plan-card:hover,.pgate-plan-card.selected{border-color:#6366f1;background:#6366f112}.pgate-plan-info{flex:1}.pgate-plan-name{font-size:.95rem;font-weight:700;color:var(--text-primary);margin:0 0 3px}.pgate-plan-desc{font-size:.8rem;color:var(--text-secondary);margin:0}.pgate-plan-price{text-align:right;flex-shrink:0}.pgate-plan-main-price{font-size:1.15rem;font-weight:800;color:var(--text-primary);line-height:1;display:flex;flex-direction:column;align-items:flex-end}.price-interval{font-size:.7rem;color:var(--text-muted);font-weight:500;margin-top:2px}.pgate-currency-switch{text-align:center;margin:12px 0 20px}.pgate-currency-switch button{background:none;border:none;color:#6366f1;font-size:.8rem;font-weight:600;text-decoration:underline;cursor:pointer;opacity:.8;transition:opacity .2s}.pgate-currency-switch button:hover{opacity:1}.pgate-error{color:#ef4444;background:#ef44441a;padding:10px;border-radius:8px;font-size:.8rem;text-align:center;margin-bottom:16px;border:1px solid rgba(239,68,68,.2)}.pgate-pay-row{display:flex;flex-direction:column;gap:12px;margin-bottom:8px}.pgate-pay-stripe,.pgate-pay-razorpay{padding:16px;border-radius:14px;color:#fff;font-weight:700;font-size:.95rem;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .2s ease;border:none;width:100%}.pgate-pay-stripe{background:#635bff;box-shadow:0 4px 15px #635bff4d}.pgate-pay-razorpay{background:#111;box-shadow:0 4px 15px #0003}.pgate-pay-stripe:hover,.pgate-pay-razorpay:hover{transform:translateY(-2px);filter:brightness(1.1)}.pgate-pay-stripe:disabled,.pgate-pay-razorpay:disabled{opacity:.6;transform:none;cursor:not-allowed}.library-container{padding-bottom:100px;max-width:1200px;margin:0 auto}.library-account-section{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:24px;margin-bottom:40px}.account-header,.recents-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.account-icon,.recents-icon{color:var(--accent-primary)}.account-header h3,.recents-header h3{font-size:1.5rem;color:var(--text-primary);margin:0}.account-details{display:flex;flex-direction:column;gap:16px}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#0003;border-radius:var(--radius-sm)}.theme-light .detail-row{background:#00000008}.detail-row .label{color:var(--text-secondary);font-size:.9rem;font-weight:500}.detail-row .value{color:var(--text-primary);font-weight:600}.guest-auth-prompt{text-align:center;max-width:400px;margin:0 auto}.guest-auth-prompt p{color:var(--text-secondary);margin-bottom:24px;font-size:.95rem;line-height:1.5}.inline-auth-form{display:flex;flex-direction:column;gap:16px}.switch-mode-btn:hover{color:var(--text-primary)}.sub-manager{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:24px;margin-bottom:40px;transition:all .3s ease}.sub-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:12px}.sub-header h3{margin:0;font-size:1.5rem;color:var(--text-primary)}.sub-icon{margin-right:8px}.sub-icon.premium{color:#10b981}.badge{padding:4px 12px;border-radius:20px;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.active-badge{background:#10b9811a;color:#10b981;border:1px solid rgba(16,185,129,.2)}.cancelling-badge{background:#f59e0b1a;color:#f59e0b;border:1px solid rgba(245,158,11,.2)}.sub-details{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.sub-actions{margin-top:24px;padding-top:20px;border-top:1px solid var(--glass-border);display:flex;flex-direction:column;gap:8px}.cancel-btn{background:transparent;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:10px 20px;border-radius:var(--radius-sm);font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s ease;align-self:flex-start}.cancel-btn:hover:not(:disabled){background:#ef44441a;border-color:#ef4444}.cancel-btn:disabled{opacity:.7;cursor:not-allowed}.helper-text{font-size:.85rem;color:var(--text-secondary);margin:0}.cancelled-notice{display:flex;align-items:center;gap:10px;color:#ef4444;background:#ef44440d;padding:12px 16px;border-radius:var(--radius-sm);font-size:.95rem;font-weight:500;border:1px solid rgba(239,68,68,.1)}.cancelled-notice strong{color:#ef4444;font-weight:700}.reactivate-btn{background:#10b981;border:none;color:#fff;padding:12px 20px;border-radius:var(--radius-sm);font-weight:700;font-size:1rem;cursor:pointer;transition:all .2s ease;align-self:flex-start;box-shadow:0 4px 12px #10b98133}.reactivate-btn:hover:not(:disabled){background:#059669;transform:translateY(-1px);box-shadow:0 6px 16px #10b9814d}.reactivate-btn:active:not(:disabled){transform:translateY(0)}.reactivate-btn:disabled{opacity:.7;cursor:not-allowed}.sub-manager.inactive{display:flex;align-items:center;gap:16px;padding:20px 24px}.sub-manager.inactive .sub-icon{color:var(--text-secondary)}.sub-manager.inactive h4{margin:0 0 4px;color:var(--text-primary);font-size:1.1rem}.sub-manager.inactive p{margin:0;color:var(--text-secondary);font-size:.9rem}.sub-manager-skeleton{height:180px;display:flex;align-items:center;justify-content:center;border:1px solid var(--glass-border);border-radius:var(--radius-lg);margin-bottom:40px;opacity:.7}@media(max-width:600px){.sub-header{flex-direction:column;align-items:flex-start;gap:8px}.cancel-btn{width:100%;text-align:center}}
