:root{--font-body: "Outfit", system-ui, -apple-system, sans-serif;--font-display: "Cormorant Garamond", Georgia, serif;--bg-primary: #faf9f7;--bg-secondary: #ffffff;--card-bg: #ffffff;--text-primary: #1a1a1a;--text-secondary: #4a4a4a;--text-tertiary: #7a7a7a;--border-color: rgba(0, 0, 0, .08);--input-bg: #ffffff;--accent-color: #6c5ce7;--accent-shadow: rgba(108, 92, 231, .15);--transition-fast: .15s ease;--transition-medium: .3s ease}@media(prefers-color-scheme:dark){:root:not([data-theme]){--bg-primary: #0d0d0f;--bg-secondary: #161618;--card-bg: #1c1c1f;--text-primary: #f5f5f5;--text-secondary: #b0b0b0;--text-tertiary: #707070;--border-color: rgba(255, 255, 255, .08);--input-bg: #232326;--accent-color: #a29bfe;--accent-shadow: rgba(162, 155, 254, .2)}}:root[data-theme=dark]{--bg-primary: #0d0d0f;--bg-secondary: #161618;--card-bg: #1c1c1f;--text-primary: #f5f5f5;--text-secondary: #b0b0b0;--text-tertiary: #707070;--border-color: rgba(255, 255, 255, .08);--input-bg: #232326;--accent-color: #a29bfe;--accent-shadow: rgba(162, 155, 254, .2)}*,*:before,*:after{box-sizing:border-box}*{margin:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scrollbar-gutter:stable}body{font-family:var(--font-body);font-weight:400;line-height:1.6;color:var(--text-primary);background:var(--bg-primary);min-height:100vh}body:before{content:"";position:fixed;inset:0;background-image:radial-gradient(circle at 20% 80%,var(--accent-color) 0%,transparent 25%),radial-gradient(circle at 80% 20%,#e85d4c 0%,transparent 25%),radial-gradient(circle at 40% 40%,#00b894 0%,transparent 20%);opacity:.03;pointer-events:none;z-index:-1}body:after{content:"";position:fixed;top:-50px;right:5%;width:50%;height:250px;background:radial-gradient(ellipse 60% 50% at 50% 40%,var(--accent-color) 0%,transparent 60%),radial-gradient(ellipse 40% 40% at 20% 60%,#e07a5f 0%,transparent 50%),radial-gradient(ellipse 35% 35% at 80% 55%,#81b29a 0%,transparent 45%);opacity:.18;pointer-events:none;z-index:0;filter:blur(30px);animation:gradientFloat 15s ease-in-out infinite}@media(max-width:640px){body:after{width:80%;right:-10%;top:-30px;height:200px;opacity:.12;filter:blur(25px)}}@media(min-width:641px)and (max-width:1024px){body:after{width:60%;right:0;opacity:.15}}img{display:block;max-width:100%}button,input,select,textarea{font:inherit}a{color:inherit;text-decoration:none}:focus-visible{outline:2px solid var(--accent-color);outline-offset:2px}::selection{background:var(--accent-color);color:#fff}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}#root{min-height:100vh}.header{position:relative;padding:3rem 0 1rem;overflow:visible}@keyframes gradientFloat{0%,to{transform:translate(0) scale(1);opacity:.18}50%{transform:translate(-5px,3px) scale(1.02);opacity:.22}}.header__content{position:relative;z-index:1}.header__brand{display:flex;align-items:center;gap:.75rem}.header__icon{font-size:1.5rem;color:var(--accent-color);animation:sparkle 2s ease-in-out infinite}@keyframes sparkle{0%,to{opacity:1;transform:scale(1) rotate(0)}50%{opacity:.7;transform:scale(1.1) rotate(15deg)}}.header__title{font-family:var(--font-display);font-size:2.5rem;font-weight:700;margin:0;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent-color) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@media(min-width:768px){.header__title{font-size:3rem}}.header__subtitle{font-family:var(--font-display);font-size:1.1rem;font-weight:500;font-style:italic;color:var(--text-primary);margin:.25rem 0 0;letter-spacing:.01em}.category-badges{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}@media(min-width:768px){.category-badges{padding:1rem 2.5rem;margin-left:-2.5rem;margin-right:-2.5rem}}.category-badges__list{display:flex;flex-wrap:wrap;gap:.5rem}.category-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:20px;background:var(--card-bg);color:var(--text-secondary);font-family:inherit;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.category-badge:hover{border-color:var(--accent-color);color:var(--accent-color);transform:translateY(-1px)}.category-badge--active{background:linear-gradient(135deg,color-mix(in srgb,var(--accent-color) 75%,var(--text-primary)) 0%,var(--accent-color) 100%);border-color:transparent;color:#fff}.category-badge--active:hover{background:linear-gradient(135deg,color-mix(in srgb,var(--accent-color) 75%,var(--text-primary)) 0%,var(--accent-color) 100%);border-color:transparent;color:#fff;opacity:.9}.category-badge__count{display:inline-flex;align-items:center;justify-content:center;min-width:1.5rem;height:1.5rem;padding:0 .4rem;background:#0000001a;border-radius:10px;font-size:.75rem;font-weight:600}.category-badge--active .category-badge__count{background:#fff3}.category-badges__actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.category-badges__sort,.category-badges__toggle{position:relative;display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:50%;color:var(--text-secondary);font-size:1rem;cursor:pointer;transition:all .2s ease}.category-badges__sort:hover,.category-badges__toggle:hover{border-color:var(--accent-color);color:var(--accent-color);transform:scale(1.05)}[data-tooltip]{position:relative}[data-tooltip]:before{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%) translateY(4px);padding:.4rem .6rem;background:var(--card-bg);color:var(--text-primary);font-size:.75rem;font-weight:500;white-space:nowrap;border-radius:8px;box-shadow:0 2px 8px #00000026;border:1px solid var(--border-color);opacity:0;visibility:hidden;transition:all .15s ease;pointer-events:none;z-index:100}[data-tooltip]:after{content:"";position:absolute;bottom:calc(100% + 4px);left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:var(--card-bg);opacity:0;visibility:hidden;transition:all .15s ease;pointer-events:none;z-index:100}[data-tooltip]:hover:before{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}[data-tooltip]:hover:after{opacity:1;visibility:visible}.category-badges__random{position:relative;display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:50%;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;flex-shrink:0}.category-badges__random:hover{border-color:var(--accent-color);color:var(--accent-color);transform:scale(1.05)}.category-badges__random:active{transform:scale(.95)}@media(max-width:640px){.category-badges{flex-wrap:wrap}.category-badges__list{gap:.4rem}.category-badge{padding:.4rem .75rem;font-size:.8rem}.category-badges__toggle,.category-badges__random{width:32px;height:32px}}.book-card{position:relative;display:flex;flex-direction:column;background:var(--card-bg);border-radius:12px;overflow:hidden;cursor:zoom-in;transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s ease}.book-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 24px 48px #00000026,0 12px 24px #0000001a}.book-card:focus-visible{outline:none}.book-card__cover-wrapper{position:relative;aspect-ratio:2 / 3;overflow:hidden;background:linear-gradient(135deg,var(--book-color) 0%,color-mix(in srgb,var(--book-color) 60%,black) 100%)}.book-card__cover{width:100%;height:100%;object-fit:cover;object-position:center top}.book-card__cover-placeholder{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;padding:1.5rem;text-align:center;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.3);-webkit-user-select:none;user-select:none}.book-card__cover-title{font-family:var(--font-display);font-size:1.1rem;font-weight:600;line-height:1.3;margin-bottom:.5rem}.book-card__cover-author{font-size:.85rem;opacity:.85}.book-card__color-accent{position:absolute;bottom:0;left:0;right:0;height:4px;background:var(--book-color);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.book-card:hover .book-card__color-accent{transform:scaleX(1)}.book-card__content{flex:1;padding:1rem 1.25rem 1.25rem;display:flex;flex-direction:column;gap:.35rem}.book-card__category{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--book-color);opacity:.9}.book-card__title{font-family:var(--font-display);font-size:1rem;font-weight:600;line-height:1.35;margin:0;color:var(--text-primary)}.book-card__author{font-size:.85rem;color:var(--text-secondary);margin:0}.book-card__notes{font-size:.8rem;line-height:1.5;color:var(--text-tertiary);margin:.5rem 0 0;max-height:0;overflow:hidden;opacity:0;transition:max-height .3s ease,opacity .3s ease}.book-card__notes.visible{max-height:100px;opacity:1}.book-card__year{position:absolute;top:.75rem;right:.75rem;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;font-size:.7rem;font-weight:600;padding:.25rem .5rem;border-radius:4px;font-variant-numeric:tabular-nums;-webkit-user-select:none;user-select:none}.book-card--lifted{pointer-events:none;transform:translateY(-8px) scale(1.02);box-shadow:0 24px 48px #00000026,0 12px 24px #0000001a}.book-card--lifted>*:not(.book-card__placeholder){opacity:0;transition:opacity .15s ease}.book-card__placeholder{position:absolute;inset:0;border-radius:12px;overflow:hidden;background:#00000008}.book-card__placeholder:before{content:"";position:absolute;top:0;left:0;right:0;aspect-ratio:2 / 3;background:linear-gradient(145deg,#0000000f,#0000000a);border-radius:12px 12px 0 0}.book-card__placeholder:after{content:"";position:absolute;bottom:0;left:0;right:0;top:calc(100% / 1.5);background:#00000005;border-radius:0 0 12px 12px}.book-card--compact{background:transparent;border-radius:0;border:none;outline:none}.book-card--compact .book-card__cover-wrapper{border-radius:0;border:none;aspect-ratio:auto;box-shadow:0 8px 16px #0003,0 4px 8px #0000001f;transition:box-shadow .3s ease,transform .3s ease}.book-card--compact .book-card__cover{width:100%;height:auto;aspect-ratio:auto;display:block;border:none;outline:none}.book-card--compact .book-card__cover-placeholder{aspect-ratio:2 / 3}.book-card--compact:hover,.book-card--compact:focus-visible{transform:translateY(-5px) scale(1.02);outline:none}.book-card--compact:hover .book-card__cover-wrapper,.book-card--compact:focus-visible .book-card__cover-wrapper{box-shadow:0 16px 32px #0000002e,0 6px 12px #0000001f}.book-card--compact .book-card__year,.book-card--compact .book-card__color-accent{display:none}.book-card--compact .book-card__placeholder{border-radius:0;box-shadow:4px 6px 12px #0003,2px 3px 6px #0000001f}.book-card--compact .book-card__placeholder:before{border-radius:0;aspect-ratio:unset;bottom:0}.book-card--compact .book-card__placeholder:after{display:none}.book-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:2rem;padding:1rem 0}@media(min-width:768px){.book-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:2.5rem}}@media(min-width:1200px){.book-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}}.book-grid__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:var(--text-secondary)}.book-grid__empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.book-grid__empty p{font-size:1.1rem;margin:0}.book-grid--compact{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem;align-items:end}@media(min-width:768px){.book-grid--compact{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1.25rem}}@media(min-width:1200px){.book-grid--compact{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1.5rem}}.book-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:2rem;background:#0000;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px);transition:background .4s ease,backdrop-filter .4s ease;overflow:hidden}.book-modal--lifting,.book-modal--opening,.book-modal--open{background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.book-modal--closing{background:#0000;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px);transition:background .5s ease .1s,backdrop-filter .5s ease .1s}.book-modal--closing-fast{background:#0000;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px);transition:background .25s ease,backdrop-filter .25s ease}.book-modal__book{position:relative;height:min(92vh,1000px);width:calc(min(92vh,1000px) * 2 / 3);max-width:100vw;perspective:2000px;transform-style:preserve-3d;transform:translate(var(--origin-x),var(--origin-y)) scale(var(--origin-scale));opacity:0}.book-modal--lifting .book-modal__book{animation:bookLift .35s cubic-bezier(.22,1,.36,1) forwards}@keyframes bookLift{0%{transform:translate(var(--origin-x),var(--origin-y)) scale(var(--origin-scale));opacity:.8;filter:drop-shadow(0 5px 15px rgba(0,0,0,.2))}40%{opacity:1;filter:drop-shadow(0 25px 50px rgba(0,0,0,.35))}to{transform:translate(0) scale(1);opacity:1;filter:drop-shadow(0 30px 60px rgba(0,0,0,.4))}}.book-modal--opening .book-modal__book,.book-modal--open .book-modal__book{transform:translate(0) scale(1);opacity:1;filter:drop-shadow(0 30px 60px rgba(0,0,0,.4))}.book-modal--closing .book-modal__book{animation:bookDrop .7s cubic-bezier(.4,0,.2,1) forwards}@keyframes bookDrop{0%{transform:translate(0) scale(1);opacity:1;filter:drop-shadow(0 30px 60px rgba(0,0,0,.4))}40%{transform:translate(0) scale(1);opacity:1;filter:drop-shadow(0 25px 50px rgba(0,0,0,.35))}to{transform:translate(var(--origin-x),var(--origin-y)) scale(var(--origin-scale));opacity:0;filter:drop-shadow(0 5px 15px rgba(0,0,0,.1))}}.book-modal--closing-fast .book-modal__book{animation:bookDropFast .3s ease-out forwards}.book-modal--no-origin.book-modal--closing .book-modal__book{animation:bookFadeOut .4s ease-out forwards}@keyframes bookFadeOut{0%{transform:translate(0) scale(1);opacity:1}to{transform:translate(0) scale(.95);opacity:0}}.book-modal--no-origin.book-modal--closing .book-modal__cover{animation:none}@keyframes bookDropFast{0%{opacity:1}to{transform:translate(var(--origin-x),var(--origin-y)) scale(var(--origin-scale));opacity:0;filter:drop-shadow(0 5px 15px rgba(0,0,0,.1))}}.book-modal--closing-fast .book-modal__cover{animation:none;transform:rotateY(0)}.book-modal--closing-fast .book-modal__pages{opacity:0;transition:opacity .1s ease}.book-modal__cover{position:absolute;left:0;top:0;width:100%;height:100%;transform-style:preserve-3d;transform-origin:left center;transform:rotateY(0)}.book-modal--lifting .book-modal__cover{transform:rotateY(0)}.book-modal--opening .book-modal__cover{animation:coverOpen .6s cubic-bezier(.34,1.56,.64,1) forwards}.book-modal--open .book-modal__cover{transform:rotateY(-165deg)}.book-modal--closing .book-modal__cover{animation:coverClose .28s ease-out forwards}@keyframes coverOpen{0%{transform:rotateY(0)}to{transform:rotateY(-165deg)}}@keyframes coverClose{0%{transform:rotateY(-165deg)}to{transform:rotateY(0)}}.book-modal__cover-front,.book-modal__cover-back{position:absolute;inset:0;backface-visibility:hidden}.book-modal__cover-front{border-radius:12px;background:linear-gradient(160deg,var(--book-color) 0%,var(--book-color) 40%,color-mix(in srgb,var(--book-color) 70%,black) 100%);box-shadow:2px 0 8px #0003,inset -1px 0 #ffffff1a;transition:background .3s ease}.book-modal__cover-front img,.book-modal__cover-back{border-radius:12px}.book-modal__cover-front img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:opacity .2s ease}.book-modal__cover-placeholder{transition:opacity .2s ease;display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;padding:2rem;text-align:center;color:#fff}.book-modal__cover-title{font-family:var(--font-display);font-size:1.5rem;font-weight:600;line-height:1.3;margin-bottom:.5rem;text-shadow:0 2px 4px rgba(0,0,0,.3)}.book-modal__cover-author{font-size:1rem;opacity:.85}.book-modal__cover-back{transform:rotateY(180deg);background:linear-gradient(to left,#f5f0e8,#ebe5db);box-shadow:inset -2px 0 8px #00000014}.book-modal__pages{position:absolute;left:0;top:0;width:100%;height:100%;background:linear-gradient(to right,#e8e4de,#f5f2ed 3%,#fdfcfa 8% 92%,#f5f2ed);border-radius:12px;box-shadow:4px 4px 20px #00000026;opacity:0;overflow:hidden;transition:opacity .3s ease}.book-modal--opening .book-modal__pages{animation:pagesAppear .4s ease forwards;animation-delay:.25s}.book-modal--open .book-modal__pages{opacity:1}.book-modal--closing .book-modal__pages{opacity:0;transition:opacity .15s ease}@keyframes pagesAppear{0%{opacity:0}to{opacity:1}}.book-modal__pages:before{content:"";position:absolute;left:0;top:0;bottom:0;width:30px;background:linear-gradient(to right,rgba(0,0,0,.2) 0%,rgba(0,0,0,.12) 15%,rgba(0,0,0,.04) 50%,transparent 100%);border-radius:12px 0 0 12px;pointer-events:none;z-index:5}.book-modal__pages:after{content:"";position:absolute;left:0;top:5%;bottom:5%;width:2px;background:#0000001a;border-radius:1px;pointer-events:none;z-index:6}.book-modal__nav-btn{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border:none;background:#ffffffe6;border-radius:50%;font-size:1.1rem;color:#444;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .2s,opacity .3s;-webkit-user-select:none;user-select:none;z-index:10;opacity:0;box-shadow:0 2px 6px #0000001f}.book-modal__nav-btn--prev{left:1.75rem}.book-modal__nav-btn--next{right:1.75rem}.book-modal--open .book-modal__nav-btn{opacity:1;transition:background .2s,transform .2s,opacity .3s ease .3s}.book-modal--closing .book-modal__nav-btn,.book-modal--closing-fast .book-modal__nav-btn{opacity:0;transition:opacity .1s ease}.book-modal__nav-btn:hover{background:#fff;transform:translateY(-50%) scale(1.1);color:#222}.book-modal__nav-btn:active{transform:translateY(-50%) scale(1.02)}.book-modal__content{height:100%;padding:1.25rem 1.5rem;overflow-y:auto;overscroll-behavior:contain;color:#2a2a2a;opacity:0;transform:translate(10px);transition:opacity .3s ease,transform .3s ease;scrollbar-color:rgba(0,0,0,.2) transparent}.book-modal__content::-webkit-scrollbar{width:8px}.book-modal__content::-webkit-scrollbar-track{background:transparent}.book-modal__content::-webkit-scrollbar-thumb{background:#0003;border-radius:4px}.book-modal__content::-webkit-scrollbar-thumb:hover{background:#0000004d}.book-modal--open .book-modal__content{opacity:1;transform:translate(0);transition:opacity .4s ease .2s,transform .4s ease .2s}.book-modal--transitioning .book-modal__content,.book-modal--transitioning .book-modal__cover-front img,.book-modal--transitioning .book-modal__cover-placeholder{opacity:0;transition:opacity .12s ease-out}.book-modal--open:not(.book-modal--transitioning) .book-modal__content{opacity:1;transition:opacity .12s ease-in}.book-modal--closing .book-modal__content{opacity:0;transform:translate(10px);transition:opacity .15s ease,transform .15s ease}.book-modal__header{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid rgba(0,0,0,.08)}.book-modal__category{display:inline-block;font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#fff;background:var(--book-color);padding:.25rem .5rem;border-radius:3px;margin-bottom:.5rem}.book-modal__title{font-family:var(--font-display);font-size:1.4rem;font-weight:700;line-height:1.2;margin:0 0 .25rem;color:#1a1a1a}.book-modal__author{font-size:.9rem;color:#666;margin:0 0 .125rem;font-style:italic}.book-modal__year{display:block;font-size:.8rem;color:#999;font-variant-numeric:tabular-nums}.book-modal__section{margin-bottom:1rem}.book-modal__section:last-child{margin-bottom:0}.book-modal__section h3{font-family:var(--font-display);font-size:.85rem;font-weight:600;color:#333;margin:0 0 .375rem;display:flex;align-items:center;gap:.375rem}.book-modal__section h3:before{content:"§";color:var(--book-color);font-weight:400}.book-modal__section p{font-size:.8rem;line-height:1.6;color:#444;margin:0}.book-modal__quotes{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.book-modal__quote{position:relative;padding-left:.75rem}.book-modal__quote:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--book-color);border-radius:1px}.book-modal__quote blockquote{margin:0;font-size:.8rem;line-height:1.5;color:#555;font-style:italic}.book-modal__links{display:flex;flex-wrap:wrap;gap:.375rem .75rem;margin-top:.625rem}.book-modal__link{display:inline-flex;align-items:center;gap:.2rem;font-size:.75rem;color:color-mix(in srgb,var(--book-color) 70%,#666);text-decoration:none;font-weight:500;transition:color .2s}.book-modal__link:hover{color:var(--book-color)}@media(prefers-color-scheme:dark){:root:not([data-theme]) .book-modal__pages{background:linear-gradient(to right,#1a1a1c,#1e1e20 3%,#222224 8% 92%,#1e1e20)}:root:not([data-theme]) .book-modal__pages:before{background:linear-gradient(to right,rgba(0,0,0,.35) 0%,rgba(0,0,0,.2) 15%,rgba(0,0,0,.08) 50%,transparent 100%)}:root:not([data-theme]) .book-modal__pages:after{background:#0003}:root:not([data-theme]) .book-modal__cover-back{background:linear-gradient(to left,#2a2a2c,#333335)}:root:not([data-theme]) .book-modal__content{color:#e5e5e5;scrollbar-color:rgba(255,255,255,.2) transparent}:root:not([data-theme]) .book-modal__content::-webkit-scrollbar-thumb{background:#fff3}:root:not([data-theme]) .book-modal__content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}:root:not([data-theme]) .book-modal__title{color:#f5f5f5}:root:not([data-theme]) .book-modal__author{color:#aaa}:root:not([data-theme]) .book-modal__year{color:#888}:root:not([data-theme]) .book-modal__section h3{color:#ddd}:root:not([data-theme]) .book-modal__section p{color:#bbb}:root:not([data-theme]) .book-modal__quote blockquote{color:#aaa}:root:not([data-theme]) .book-modal__nav-btn{background:#282828e6;color:#ddd}:root:not([data-theme]) .book-modal__nav-btn:hover{background:#323232}}:root[data-theme=dark] .book-modal__pages{background:linear-gradient(to right,#1a1a1c,#1e1e20 3%,#222224 8% 92%,#1e1e20)}:root[data-theme=dark] .book-modal__pages:before{background:linear-gradient(to right,rgba(0,0,0,.35) 0%,rgba(0,0,0,.2) 15%,rgba(0,0,0,.08) 50%,transparent 100%)}:root[data-theme=dark] .book-modal__pages:after{background:#0003}:root[data-theme=dark] .book-modal__cover-back{background:linear-gradient(to left,#2a2a2c,#333335)}:root[data-theme=dark] .book-modal__content{color:#e5e5e5;scrollbar-color:rgba(255,255,255,.2) transparent}:root[data-theme=dark] .book-modal__content::-webkit-scrollbar-thumb{background:#fff3}:root[data-theme=dark] .book-modal__content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}:root[data-theme=dark] .book-modal__title{color:#f5f5f5}:root[data-theme=dark] .book-modal__author{color:#aaa}:root[data-theme=dark] .book-modal__year{color:#888}:root[data-theme=dark] .book-modal__section h3{color:#ddd}:root[data-theme=dark] .book-modal__section p{color:#bbb}:root[data-theme=dark] .book-modal__quote blockquote{color:#aaa}:root[data-theme=dark] .book-modal__nav-btn{background:#282828e6;color:#ddd}:root[data-theme=dark] .book-modal__nav-btn:hover{background:#323232}@media(max-width:600px){.book-modal{padding:.75rem;align-items:center;overflow:hidden}.book-modal__book{width:100%;max-width:none;height:calc(100vh - 1.5rem);height:calc(100dvh - 1.5rem);max-height:none;perspective:none}.book-modal__cover{display:none}.book-modal__pages{position:relative;left:0;width:100%;height:100%;border-radius:12px;opacity:1;overflow:hidden}.book-modal__content{height:100%;padding:1.25rem 1.25rem 1.5rem;overflow-y:auto}.book-modal__title{font-size:1.5rem}.book-modal__nav{opacity:1}.book-modal--lifting .book-modal__book,.book-modal--opening .book-modal__book{animation:mobileAppear .15s ease-out forwards}.book-modal--open .book-modal__book{transform:none;opacity:1}.book-modal--lifting .book-modal__pages,.book-modal--opening .book-modal__pages,.book-modal--open .book-modal__pages{opacity:1;animation:none}.book-modal--closing .book-modal__book,.book-modal--closing-fast .book-modal__book{animation:mobileDisappear .2s ease-in forwards}@keyframes mobileAppear{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes mobileDisappear{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(30px) scale(.95)}}}.loader{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:2rem}.loader__books{display:flex;align-items:flex-end;gap:6px;height:50px}.loader__book{width:14px;border-radius:2px 2px 0 0;transform-origin:bottom;animation:bookWave 1.8s ease-in-out infinite}.loader__book--1{height:35px;background:var(--accent-color);animation-delay:0s}.loader__book--2{height:45px;background:#e85d4c;animation-delay:.1s}.loader__book--3{height:40px;background:#00b894;animation-delay:.2s}.loader__book--4{height:32px;background:#fdcb6e;animation-delay:.3s}.loader__book--5{height:38px;background:#74b9ff;animation-delay:.4s}@keyframes bookWave{0%,to{transform:scaleY(1)}50%{transform:scaleY(.6)}}.loader__text{font-size:.875rem;color:var(--text-tertiary);margin:0;letter-spacing:.02em}.app{min-height:100vh;display:flex;flex-direction:column}.container{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:0 1.5rem 3rem}@media(min-width:768px){.container{padding:0 2.5rem 4rem}}.error{display:flex;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.error p{color:#e85d4c;font-size:1rem}.footer{padding:2rem;border-top:1px solid var(--border-color);margin-top:auto}.footer__content{display:flex;align-items:center;justify-content:center;gap:1rem;max-width:1400px;margin:0 auto;position:relative}.footer p{margin:0;font-size:.85rem;color:var(--text-tertiary)}.theme-toggle{position:absolute;right:0;background:var(--card-bg);border:1px solid var(--border-color);border-radius:50%;width:2.25rem;height:2.25rem;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast)}.theme-toggle:hover{transform:scale(1.1);box-shadow:0 2px 8px var(--accent-shadow)}.theme-toggle:active{transform:scale(.95)}.footer .heart{color:#e85d4c;animation:heartbeat 1.5s ease-in-out infinite;display:inline-block}.footer a{background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent-color) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:500;transition:opacity .2s ease}.footer a:hover{opacity:.8}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}
