@import"https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&display=swap";*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--ink: #0F0F0F;--ink-2: #1C1C1E;--ink-3: #3A3A3C;--ink-4: #636366;--ink-5: #8E8E93;--paper: #FAFAF8;--paper-2: #F2F2EF;--paper-3: #E8E8E4;--paper-4: #D4D4CE;--white: #FFFFFF;--accent: #C1440E;--accent-light: #E8673A;--accent-bg: #FDF1EC;--sage: #4A6741;--sage-light: #6B8F68;--sage-bg: #EDF2EC;--amber: #B07B20;--amber-bg: #FBF4E3;--cobalt: #1A4A8A;--cobalt-bg: #EBF0F8;--font-display: "DM Serif Display", Georgia, serif;--font-body: "DM Sans", system-ui, sans-serif;--sp-1: .25rem;--sp-2: .5rem;--sp-3: .75rem;--sp-4: 1rem;--sp-5: 1.25rem;--sp-6: 1.5rem;--sp-8: 2rem;--sp-10: 2.5rem;--sp-12: 3rem;--sp-16: 4rem;--sp-20: 5rem;--sp-24: 6rem;--r-sm: 4px;--r-md: 8px;--r-lg: 12px;--r-xl: 16px;--r-2xl: 24px;--r-full: 9999px;--shadow-sm: 0 1px 3px rgba(15,15,15,.08);--shadow-md: 0 4px 12px rgba(15,15,15,.08), 0 1px 3px rgba(15,15,15,.04);--shadow-lg: 0 12px 32px rgba(15,15,15,.1), 0 4px 8px rgba(15,15,15,.06);--shadow-xl: 0 24px 48px rgba(15,15,15,.12), 0 8px 16px rgba(15,15,15,.06);--shadow-accent: 0 8px 24px rgba(193,68,14,.2);--t-fast: .12s ease;--t-base: .22s ease;--t-slow: .38s cubic-bezier(.4,0,.2,1);--container: 1260px}[data-theme=dark]{--paper: #0F0F0F;--paper-2: #1C1C1E;--paper-3: #2C2C2E;--paper-4: #3A3A3C;--ink: #F5F5F0;--ink-2: #EBEBDF;--ink-3: #D4D4CE;--ink-4: #8E8E93;--ink-5: #636366;--white: #1C1C1E;--accent-bg: rgba(193,68,14,.12);--sage-bg: rgba(74,103,65,.12);--amber-bg: rgba(176,123,32,.12);--cobalt-bg: rgba(26,74,138,.12)}html{scroll-behavior:smooth;font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:var(--font-body);color:var(--ink);background:var(--paper);line-height:1.6;overflow-x:hidden;transition:background .3s,color .3s}a{text-decoration:none;color:inherit}img{max-width:100%;height:auto;display:block}button{border:none;background:none;cursor:pointer;font-family:inherit}ul,ol{list-style:none}input,textarea,select{font-family:inherit;border:none;outline:none}.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 var(--sp-6)}.section{padding:var(--sp-24) 0}.section--alt{background:var(--paper-2)}.section-header{text-align:center;margin-bottom:var(--sp-12)}.section-tag{display:inline-flex;align-items:center;gap:var(--sp-2);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);background:var(--accent-bg);padding:var(--sp-1) var(--sp-3);border-radius:var(--r-full);margin-bottom:var(--sp-4)}.section-title{font-family:var(--font-display);font-size:clamp(1.8rem,4vw,2.8rem);color:var(--ink);line-height:1.15;margin-bottom:var(--sp-4)}.section-subtitle{font-size:1.05rem;color:var(--ink-4);max-width:560px;margin:0 auto}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:.65rem 1.5rem;font-weight:600;font-size:.9rem;border-radius:var(--r-md);transition:all var(--t-base);white-space:nowrap;cursor:pointer;font-family:var(--font-body)}.btn--primary{background:var(--ink);color:var(--paper);border:1.5px solid var(--ink)}.btn--primary:hover{background:var(--ink-3);border-color:var(--ink-3);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn--accent{background:var(--accent);color:#fff;border:1.5px solid var(--accent);box-shadow:var(--shadow-accent)}.btn--accent:hover{background:var(--accent-light);border-color:var(--accent-light);transform:translateY(-2px)}.btn--outline{background:transparent;color:var(--ink);border:1.5px solid var(--paper-3)}.btn--outline:hover{border-color:var(--ink-3);background:var(--paper-2);transform:translateY(-1px)}.btn--ghost{background:transparent;color:var(--ink-4);padding:.5rem .75rem;border:none}.btn--ghost:hover{color:var(--ink);background:var(--paper-2)}.btn--sm{padding:.45rem 1rem;font-size:.82rem}.btn--lg{padding:.85rem 2rem;font-size:1rem}.btn--icon{width:38px;height:38px;padding:0;border-radius:var(--r-md)}.btn--icon-round{width:38px;height:38px;padding:0;border-radius:var(--r-full)}.btn--danger{background:#dc2626;color:#fff;border:none}.btn--danger:hover{background:#b91c1c}.btn--sage{background:var(--sage);color:#fff;border:none}.btn--sage:hover{background:var(--sage-light)}.btn--following{background:var(--sage-bg);color:var(--sage);border:1.5px solid var(--sage)}.btn--following:hover{background:#fdecea;color:#dc2626;border-color:#dc2626}.badge{display:inline-flex;align-items:center;gap:var(--sp-1);padding:.2rem .65rem;font-size:.72rem;font-weight:600;border-radius:var(--r-full);border:1px solid transparent}.badge--accent{background:var(--accent-bg);color:var(--accent)}.badge--sage{background:var(--sage-bg);color:var(--sage)}.badge--amber{background:var(--amber-bg);color:var(--amber)}.badge--cobalt{background:var(--cobalt-bg);color:var(--cobalt)}.badge--neutral{background:var(--paper-3);color:var(--ink-3)}.stars{display:inline-flex;gap:1px;color:var(--amber);font-size:.85rem}.onboarding{position:fixed;inset:0;z-index:9999;background:var(--paper);display:flex;align-items:center;justify-content:center;padding:var(--sp-6);animation:fadeIn .4s ease}.onboarding.hidden{display:none}.onboarding__card{background:var(--white);border:1px solid var(--paper-3);border-radius:var(--r-2xl);padding:var(--sp-12) var(--sp-10);max-width:520px;width:100%;box-shadow:var(--shadow-xl);text-align:center}.onboarding__logo{width:48px;height:48px;background:var(--ink);border-radius:var(--r-lg);margin:0 auto var(--sp-6);display:flex;align-items:center;justify-content:center}.onboarding__logo svg{color:var(--paper)}.onboarding__title{font-family:var(--font-display);font-size:1.9rem;color:var(--ink);margin-bottom:var(--sp-2)}.onboarding__subtitle{color:var(--ink-4);font-size:.95rem;margin-bottom:var(--sp-8)}.onboarding__step{display:none}.onboarding__step.active{display:block;animation:fadeIn .3s ease}.onboarding__avatars{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-3);margin-bottom:var(--sp-6)}.onboarding__avatar-opt{width:100%;aspect-ratio:1;border-radius:var(--r-full);overflow:hidden;cursor:pointer;border:3px solid transparent;transition:all var(--t-base)}.onboarding__avatar-opt:hover{border-color:var(--paper-3);transform:scale(1.05)}.onboarding__avatar-opt.selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-bg)}.onboarding__avatar-opt img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;background:#fafaf8e0;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--paper-3);transition:all var(--t-base)}[data-theme=dark] .navbar{background:#0f0f0fe0;border-bottom-color:var(--paper-3)}.navbar.scrolled{box-shadow:var(--shadow-sm)}.navbar__inner{display:flex;align-items:center;justify-content:space-between;height:64px}.navbar__logo{display:flex;align-items:center;gap:var(--sp-2);font-family:var(--font-display);font-size:1.35rem;font-style:italic;color:var(--ink)}.navbar__logo-mark{width:32px;height:32px;background:var(--ink);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.navbar__logo-mark svg{color:var(--paper)}.navbar__menu{display:flex;align-items:center;gap:2px}.navbar__link{padding:.4rem .85rem;font-size:.875rem;font-weight:500;color:var(--ink-4);border-radius:var(--r-md);transition:all var(--t-fast);cursor:pointer}.navbar__link:hover,.navbar__link.active{color:var(--ink);background:var(--paper-2)}.navbar__actions{display:flex;align-items:center;gap:var(--sp-2)}.navbar__icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-md);color:var(--ink-4);transition:all var(--t-fast)}.navbar__avatar-btn{width:34px;height:34px;border-radius:var(--r-full);overflow:hidden;border:2px solid var(--paper-3);cursor:pointer;transition:border-color var(--t-fast);flex-shrink:0}.navbar__avatar-btn:hover{border-color:var(--accent)}.navbar__avatar-btn img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.navbar__notif-btn{position:relative}.navbar__notif-dot{position:absolute;top:4px;right:4px;width:8px;height:8px;background:var(--accent);border-radius:var(--r-full);border:2px solid var(--paper);display:none}.navbar__notif-dot.show{display:block}.navbar__toggle{display:none;flex-direction:column;gap:5px;padding:8px}.navbar__toggle span{width:20px;height:1.5px;background:var(--ink-3);border-radius:2px;transition:all var(--t-base)}.navbar__toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.navbar__toggle.active span:nth-child(2){opacity:0}.navbar__toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.mobile-menu{display:none;position:fixed;inset:64px 0 0;background:var(--paper);z-index:999;padding:var(--sp-6);flex-direction:column;gap:var(--sp-1)}.mobile-menu.show{display:flex}.mobile-menu__link{padding:var(--sp-4) var(--sp-5);font-size:1rem;font-weight:500;color:var(--ink-3);border-radius:var(--r-md);cursor:pointer;transition:all var(--t-fast)}.mobile-menu__link:hover,.mobile-menu__link.active{background:var(--paper-2);color:var(--ink)}.notif-panel{position:fixed;top:72px;right:var(--sp-4);width:360px;background:var(--white);border:1px solid var(--paper-3);border-radius:var(--r-xl);box-shadow:var(--shadow-xl);z-index:2500;display:none;animation:slideDown .2s ease;overflow:hidden;max-height:480px}.notif-panel.show{display:block}.notif-panel__header{padding:var(--sp-4) var(--sp-6);border-bottom:1px solid var(--paper-2);display:flex;align-items:center;justify-content:space-between}.notif-panel__title{font-weight:700;font-size:.9rem;color:var(--ink)}.notif-panel__mark{font-size:.78rem;color:var(--accent);cursor:pointer;font-weight:500}.notif-panel__list{overflow-y:auto;max-height:380px}.notif-item{display:flex;gap:var(--sp-3);padding:var(--sp-4) var(--sp-6);border-bottom:1px solid var(--paper-2);cursor:pointer;transition:background var(--t-fast)}.notif-item:hover{background:var(--paper-2)}.notif-item.unread{background:var(--accent-bg)}.notif-item__avatar{width:36px;height:36px;border-radius:var(--r-full);overflow:hidden;flex-shrink:0}.notif-item__avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.notif-item__icon{width:36px;height:36px;border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1rem}.notif-item__content{flex:1}.notif-item__text{font-size:.84rem;color:var(--ink-3);line-height:1.4}.notif-item__text strong{color:var(--ink)}.notif-item__time{font-size:.74rem;color:var(--ink-5);margin-top:2px}.notif-empty{text-align:center;padding:var(--sp-12);color:var(--ink-5);font-size:.9rem}.search-overlay{position:fixed;inset:0;background:#0f0f0f99;backdrop-filter:blur(8px);z-index:2000;display:none;align-items:flex-start;justify-content:center;padding-top:100px}.search-overlay.show{display:flex}.search-box{background:var(--white);border-radius:var(--r-xl);width:90%;max-width:600px;box-shadow:var(--shadow-xl);overflow:hidden;animation:scaleIn .25s ease}.search-box__input-row{display:flex;align-items:center;padding:var(--sp-5) var(--sp-6);gap:var(--sp-3);border-bottom:1px solid var(--paper-2)}.search-box__input-row svg{color:var(--ink-5);flex-shrink:0}.search-box__input{flex:1;font-size:1.1rem;color:var(--ink);background:none}.search-box__input::-moz-placeholder{color:var(--ink-5)}.search-box__input::placeholder{color:var(--ink-5)}.search-box__esc{padding:3px 8px;font-size:.75rem;background:var(--paper-2);border-radius:var(--r-sm);color:var(--ink-4);font-weight:500}.search-results{padding:var(--sp-3);max-height:400px;overflow-y:auto}.search-result-item{display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-3) var(--sp-4);border-radius:var(--r-md);cursor:pointer;transition:background var(--t-fast)}.search-result-item:hover{background:var(--paper-2)}.search-result-item__cover{width:36px;height:52px;border-radius:var(--r-sm);overflow:hidden;flex-shrink:0;background:var(--paper-3)}.search-result-item__cover img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.search-result-item__title{font-size:.9rem;font-weight:600;color:var(--ink)}.search-result-item__meta{font-size:.78rem;color:var(--ink-5)}.search-hint{text-align:center;padding:var(--sp-8) var(--sp-4);color:var(--ink-5);font-size:.88rem}.page{display:none}.page.active{display:block;animation:fadeIn .35s ease}.hero{padding-top:120px;padding-bottom:var(--sp-24);position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden}.hero:before{content:"";position:absolute;inset:0;z-index:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");background-repeat:repeat;background-size:200px;pointer-events:none}.hero__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-16);align-items:center;position:relative;z-index:1}.hero__eyebrow{display:inline-flex;align-items:center;gap:var(--sp-2);font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:var(--sp-6)}.hero__eyebrow-line{width:24px;height:1.5px;background:var(--accent)}.hero__title{font-family:var(--font-display);font-size:clamp(2.8rem,5.5vw,4.2rem);line-height:1.05;color:var(--ink);margin-bottom:var(--sp-6)}.hero__title em{font-style:italic;color:var(--accent)}.hero__desc{font-size:1.1rem;color:var(--ink-4);line-height:1.75;margin-bottom:var(--sp-10);max-width:480px}.hero__cta{display:flex;gap:var(--sp-3);align-items:center;margin-bottom:var(--sp-12)}.hero__metrics{display:flex;gap:var(--sp-8)}.hero__metric-num{font-family:var(--font-display);font-size:1.9rem;color:var(--ink);line-height:1}.hero__metric-label{font-size:.8rem;color:var(--ink-5);margin-top:2px}.hero__visual{position:relative;height:480px}.hero__books-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4);height:100%}.hero__book-tile{border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-lg);transition:transform var(--t-slow);cursor:pointer}.hero__book-tile:hover{transform:translateY(-6px) rotate(-.5deg)}.hero__book-tile:nth-child(1){margin-top:var(--sp-8)}.hero__book-tile:nth-child(3){margin-top:-var(--sp-4)}.hero__book-tile img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.hero__tag-cloud{position:absolute;bottom:-12px;left:50%;transform:translate(-50%);display:flex;gap:var(--sp-2);flex-wrap:wrap;justify-content:center}.hero__tag{padding:var(--sp-2) var(--sp-4);background:var(--white);border:1px solid var(--paper-3);border-radius:var(--r-full);font-size:.78rem;color:var(--ink-4);box-shadow:var(--shadow-sm);white-space:nowrap}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--sp-6)}.feature-card{background:var(--white);border:1px solid var(--paper-3);border-radius:var(--r-xl);padding:var(--sp-8);transition:all var(--t-slow)}.feature-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--paper-4)}.feature-card__icon{width:44px;height:44px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;margin-bottom:var(--sp-5)}.feature-card__icon--ink{background:var(--ink);color:var(--paper)}.feature-card__icon--accent{background:var(--accent-bg);color:var(--accent)}.feature-card__icon--sage{background:var(--sage-bg);color:var(--sage)}.feature-card__icon--cobalt{background:var(--cobalt-bg);color:var(--cobalt)}.feature-card__title{font-size:1rem;font-weight:700;color:var(--ink);margin-bottom:var(--sp-2)}.feature-card__desc{font-size:.875rem;color:var(--ink-4);line-height:1.65}.trending-scroll{display:flex;gap:var(--sp-5);overflow-x:auto;padding-bottom:var(--sp-4);scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}.trending-scroll::-webkit-scrollbar{display:none}.book-card{flex-shrink:0;width:200px;scroll-snap-align:start;cursor:pointer;transition:transform var(--t-base)}.book-card:hover{transform:translateY(-5px)}.book-card__cover{width:100%;height:280px;border-radius:var(--r-lg);overflow:hidden;position:relative;box-shadow:var(--shadow-md);margin-bottom:var(--sp-4)}.book-card__cover img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform var(--t-slow)}.book-card:hover .book-card__cover img{transform:scale(1.04)}.book-card__overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,15,15,.7),transparent);opacity:0;transition:opacity var(--t-base);display:flex;align-items:flex-end;padding:var(--sp-4)}.book-card:hover .book-card__overlay{opacity:1}.book-card__title{font-weight:700;font-size:.9rem;color:var(--ink);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.book-card__author{font-size:.78rem;color:var(--ink-4)}.catalog-header{padding-top:104px;padding-bottom:var(--sp-10);border-bottom:1px solid var(--paper-3)}.catalog-header__title{font-family:var(--font-display);font-size:clamp(1.8rem,4vw,2.6rem);color:var(--ink);margin-bottom:var(--sp-2)}.catalog-filters{display:flex;flex-wrap:wrap;gap:var(--sp-3);align-items:center;margin-bottom:var(--sp-6);padding:var(--sp-5);background:var(--white);border-radius:var(--r-xl);border:1px solid var(--paper-3);box-shadow:var(--shadow-sm)}.catalog-search{flex:1;min-width:200px;display:flex;align-items:center;gap:var(--sp-3);padding:.55rem var(--sp-4);background:var(--paper-2);border-radius:var(--r-md);border:1px solid var(--paper-3);transition:border-color var(--t-fast)}.catalog-search:focus-within{border-color:var(--ink-3);background:var(--white)}.catalog-search svg{color:var(--ink-5);flex-shrink:0}.catalog-search input{flex:1;background:none;color:var(--ink);font-size:.875rem}.catalog-select{padding:.55rem var(--sp-8) .55rem var(--sp-4);background:var(--paper-2);border:1px solid var(--paper-3);border-radius:var(--r-md);color:var(--ink-3);cursor:pointer;font-size:.875rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%23636366' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;transition:border-color var(--t-fast)}.catalog-select:focus{border-color:var(--ink-3)}.genre-tags{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin-bottom:var(--sp-8)}.genre-tag{padding:.38rem 1rem;background:var(--white);border:1px solid var(--paper-3);border-radius:var(--r-full);font-size:.82rem;font-weight:500;color:var(--ink-4);cursor:pointer;transition:all var(--t-fast)}.genre-tag:hover,.genre-tag.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}.catalog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:var(--sp-6)}.catalog-book{background:var(--white);border:1px solid var(--paper-3);border-radius:var(--r-xl);overflow:hidden;transition:all var(--t-slow);cursor:pointer}.catalog-book:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}.catalog-book__cover{width:100%;height:260px;overflow:hidden;position:relative}.catalog-book__cover img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform var(--t-slow)}.catalog-book:hover .catalog-book__cover img{transform:scale(1.04)}.catalog-book__badge{position:absolute;top:var(--sp-3);left:var(--sp-3)}.catalog-book__save-btn{position:absolute;top:var(--sp-3);right:var(--sp-3);width:32px;height:32px;background:#ffffffeb;backdrop-filter:blur(8px);border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;color:var(--ink-4);transition:all var(--t-fast);border:none;cursor:pointer}.catalog-book__save-btn:hover{color:var(--accent)}.catalog-book__save-btn.saved{color:var(--accent);background:var(--accent-bg)}.catalog-book__info{padding:var(--sp-4) var(--sp-5) var(--sp-5)}.catalog-book__title{font-weight:700;font-size:.9rem;color:var(--ink);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.catalog-book__author{font-size:.78rem;color:var(--ink-4);margin-bottom:var(--sp-3)}.catalog-book__footer{display:flex;align-items:center;justify-content:space-between}.catalog-book__price{font-weight:700;color:var(--ink);font-size:.9rem}.pagination{display:flex;align-items:center;justify-content:center;gap:var(--sp-2);margin-top:var(--sp-12)}.pagination__btn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-md);font-weight:600;font-size:.875rem;color:var(--ink-4);background:var(--white);border:1px solid var(--paper-3);transition:all var(--t-fast)}.pagination__btn:hover,.pagination__btn.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}.modal-overlay{position:fixed;inset:0;z-index:3000;display:none;align-items:center;justify-content:center;padding:var(--sp-6);background:#0f0f0f8c;backdrop-filter:blur(8px)}.modal-overlay.show{display:flex}.modal-box{position:relative;background:var(--white);border-radius:var(--r-2xl);max-width:760px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:scaleIn .28s ease}.modal-close{position:absolute;top:var(--sp-5);right:var(--sp-5);width:34px;height:34px;background:var(--paper-2);border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;z-index:1;color:var(--ink-4);transition:all var(--t-fast)}.modal-close:hover{background:var(--paper-3);color:var(--ink)}.book-modal__grid{display:grid;grid-template-columns:240px 1fr;gap:var(--sp-8);padding:var(--sp-8)}.book-modal__cover{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-md)}.book-modal__cover img{width:100%;height:auto;display:block}.book-modal__title{font-family:var(--font-display);font-size:1.5rem;color:var(--ink);margin-bottom:var(--sp-1)}.book-modal__author{color:var(--accent);font-weight:600;font-size:.9rem;margin-bottom:var(--sp-4)}.book-modal__tags{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin-bottom:var(--sp-5)}.book-modal__synopsis{color:var(--ink-4);line-height:1.8;margin-bottom:var(--sp-6);font-size:.92rem}.book-modal__actions{display:flex;gap:var(--sp-3);flex-wrap:wrap}.book-modal__status-select{width:100%;padding:.6rem var(--sp-4);border:1.5px solid var(--paper-3);border-radius:var(--r-md);background:var(--paper-2);color:var(--ink);font-family:var(--font-body);font-size:.875rem;margin-bottom:var(--sp-3);cursor:pointer;transition:border-color var(--t-fast)}.book-modal__status-select:focus{border-color:var(--ink-3)}.book-review-section{border-top:1px solid var(--paper-3);padding:var(--sp-6) var(--sp-8)}.book-review-section__title{font-weight:700;font-size:.88rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-5);margin-bottom:var(--sp-4)}.star-picker{display:flex;gap:var(--sp-1);margin-bottom:var(--sp-3)}.star-picker__star{font-size:1.3rem;cursor:pointer;color:var(--paper-4);transition:color var(--t-fast)}.star-picker__star.active{color:var(--amber)}.review-textarea{width:100%;padding:var(--sp-3) var(--sp-4);border:1.5px solid var(--paper-3);border-radius:var(--r-md);background:var(--paper-2);color:var(--ink);font-size:.875rem;resize:vertical;min-height:80px;font-family:var(--font-body);transition:border-color var(--t-fast)}.review-textarea:focus{border-color:var(--ink-3);background:var(--white)}.review-saved{display:none;align-items:center;gap:var(--sp-2);padding:var(--sp-3) var(--sp-4);background:var(--sage-bg);border-radius:var(--r-md);color:var(--sage);font-size:.85rem;font-weight:600}.review-saved.show{display:flex}.reviews-list{display:flex;flex-direction:column;gap:var(--sp-3);margin-top:var(--sp-4)}.review-item{padding:var(--sp-4);background:var(--paper-2);border-radius:var(--r-lg)}.review-item__header{display:flex;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-2)}.review-item__avatar{width:30px;height:30px;border-radius:var(--r-full);overflow:hidden}.review-item__avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.review-item__name{font-weight:600;font-size:.84rem;color:var(--ink)}.review-item__stars{margin-left:auto}.review-item__text{font-size:.84rem;color:var(--ink-4);line-height:1.6}.library-header{padding-top:104px;padding-bottom:var(--sp-10);border-bottom:1px solid var(--paper-3)}.library-goal{background:var(--ink);color:var(--paper);border-radius:var(--r-2xl);padding:var(--sp-8) var(--sp-10);margin-bottom:var(--sp-8);display:grid;grid-template-columns:1fr auto;gap:var(--sp-6);align-items:center;position:relative;overflow:hidden}.library-goal:after{content:"";position:absolute;right:-40px;top:-40px;width:200px;height:200px;background:#ffffff0a;border-radius:50%}.library-goal__label{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-5);margin-bottom:var(--sp-2)}.library-goal__title{font-family:var(--font-display);font-size:1.3rem;margin-bottom:var(--sp-4)}.library-goal__bar{width:100%;height:6px;background:#ffffff26;border-radius:var(--r-full);overflow:hidden}.library-goal__fill{height:100%;background:var(--accent);border-radius:var(--r-full);transition:width 1.2s ease}.library-goal__sub{font-size:.82rem;color:#ffffff80;margin-top:var(--sp-2)}.library-goal__num{font-family:var(--font-display);font-size:3rem;text-align:center;line-height:1}.library-goal__pct{font-size:.82rem;color:#ffffff80;text-align:center}.library-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-4);margin-bottom:var(--sp-8)}.library-stat{background:var(--white);border:1px solid var(--paper-3);border-radius:var(--r-xl);padding:var(--sp-6);text-align:center;transition:all var(--t-base)}.library-stat:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.library-stat__num{font-family:var(--font-display);font-size:1.8rem;color:var(--ink);line-height:1}.library-stat__label{font-size:.78rem;color:var(--ink-5);margin-top:var(--sp-1);text-transform:uppercase;letter-spacing:.06em}.library-tabs{display:flex;gap:2px;margin-bottom:var(--sp-8);border-bottom:1px solid var(--paper-3);overflow-x:auto}.library-tab{padding:var(--sp-3) var(--sp-5);font-weight:600;font-size:.875rem;color:var(--ink-5);border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;transition:all var(--t-fast)}.library-tab:hover{color:var(--ink)}.library-tab.active{color:var(--ink);border-bottom-color:var(--ink)}.library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:var(--sp-5)}.library-book{background:var(--white);border:1px solid var(--paper-3);border-radius:var(--r-xl);overflow:hidden;transition:all var(--t-slow);cursor:pointer;position:relative}.library-book:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:transparent}.library-book__cover{width:100%;height:220px;overflow:hidden;position:relative}.library-book__cover img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform var(--t-slow)}.library-book:hover .library-book__cover img{transform:scale(1.04)}.library-book__status{position:absolute;top:var(--sp-2);left:var(--sp-2)}.library-book__del{position:absolute;top:var(--sp-2);right:var(--sp-2);width:26px;height:26px;background:#dc2626e6;border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;color:#fff;opacity:0;transition:opacity var(--t-fast);border:none;cursor:pointer}.library-book:hover .library-book__del{opacity:1}.library-book__info{padding:var(--sp-3) var(--sp-4) var(--sp-4)}.library-book__title{font-weight:700;font-size:.84rem;color:var(--ink);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.library-book__author{font-size:.74rem;color:var(--ink-5)}.library-progress{margin-top:var(--sp-2)}.library-progress__bar{width:100%;height:3px;background:var(--paper-3);border-radius:var(--r-full);overflow:hidden}.library-progress__fill{height:100%;background:var(--accent);border-radius:var(--r-full);transition:width 1s ease}.library-progress__text{font-size:.7rem;color:var(--ink-5);margin-top:3px}.library-empty{text-align:center;padding:var(--sp-24);color:var(--ink-5);grid-column:1/-1}.library-empty__icon{width:64px;height:64px;background:var(--paper-2);border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;margin:0 auto var(--sp-5);color:var(--ink-5)}.library-empty__title{font-family:var(--font-display);font-size:1.2rem;color:var(--ink-3);margin-bottom:var(--sp-2)}.library-empty__sub{font-size:.88rem;margin-bottom:var(--sp-6)}.blog-header{padding-top:104px;padding-bottom:var(--sp-10);border-bottom:1px solid var(--paper-3)}.blog-featured{display:grid;grid-template-columns:1.3fr 1fr;gap:0;margin-bottom:var(--sp-12);background:var(--white);border-radius:var(--r-2xl);overflow:hidden;border:1px solid var(--paper-3);box-shadow:var(--shadow-md);cursor:pointer;transition:box-shadow var(--t-base)}.blog-featured:hover{box-shadow:var(--shadow-xl)}.blog-featured__img{height:100%;min-height:360px;overflow:hidden}.blog-featured__img img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform var(--t-slow)}.blog-featured:hover .blog-featured__img img{transform:scale(1.03)}.blog-featured__content{padding:var(--sp-10) var(--sp-8);display:flex;flex-direction:column;justify-content:center}.blog-featured__tag{margin-bottom:var(--sp-4)}.blog-featured__title{font-family:var(--font-display);font-size:1.5rem;font-weight:400;color:var(--ink);line-height:1.3;margin-bottom:var(--sp-4)}.blog-featured__excerpt{color:var(--ink-4);line-height:1.7;margin-bottom:var(--sp-6);font-size:.9rem}.blog-featured__meta{display:flex;align-items:center;gap:var(--sp-3)}.blog-featured__avatar{width:36px;height:36px;border-radius:var(--r-full);overflow:hidden}.blog-featured__avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.blog-featured__author{font-weight:600;font-size:.84rem;color:var(--ink)}.blog-featured__date{font-size:.78rem;color:var(--ink-5)}.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--sp-6)}.blog-card{background:var(--white);border:1px solid var(--paper-3);border-radius:var(--r-xl);overflow:hidden;transition:all var(--t-slow);cursor:pointer}.blog-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:transparent}.blog-card__img{width:100%;height:190px;overflow:hidden}.blog-card__img img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform var(--t-slow)}.blog-card:hover .blog-card__img img{transform:scale(1.04)}.blog-card__content{padding:var(--sp-5) var(--sp-6) var(--sp-6)}.blog-card__title{font-size:1rem;font-weight:700;color:var(--ink);margin-bottom:var(--sp-2);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.blog-card__excerpt{font-size:.85rem;color:var(--ink-4);margin-bottom:var(--sp-5);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.blog-card__footer{display:flex;align-items:center;justify-content:space-between}.blog-card__author-wrap{display:flex;align-items:center;gap:var(--sp-2)}.blog-card__author-avatar{width:28px;height:28px;border-radius:var(--r-full);overflow:hidden}.blog-card__author-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.blog-card__author-name{font-weight:600;font-size:.78rem;color:var(--ink-3)}.blog-card__read-time{font-size:.78rem;color:var(--ink-5)}.community-header{padding-top:104px;padding-bottom:var(--sp-10);border-bottom:1px solid var(--paper-3)}.community-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-4);margin-bottom:var(--sp-10)}.community-stat{text-align:center;padding:var(--sp-6);background:var(--white);border-radius:var(--r-xl);border:1px solid var(--paper-3);box-shadow:var(--shadow-sm)}.community-stat__num{font-family:var(--font-display);font-size:2rem;color:var(--ink);line-height:1}.community-stat__label{font-size:.8rem;color:var(--ink-5);margin-top:var(--sp-1)}.community-tabs{display:flex;gap:2px;margin-bottom:var(--sp-8);border-bottom:1px solid var(--paper-3);overflow-x:auto}.community-tab{padding:var(--sp-3) var(--sp-6);font-weight:600;font-size:.875rem;color:var(--ink-5);border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;transition:all var(--t-fast)}.community-tab:hover{color:var(--ink)}.community-tab.active{color:var(--ink);border-bottom-color:var(--ink)}.tab-content{display:none}.tab-content.active{display:block;animation:fadeIn .3s ease}.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:var(--sp-6)}.user-card{background:var(--white);border:1px solid var(--paper-3);border-radius:var(--r-xl);padding:var(--sp-6);transition:all var(--t-base)}.user-card:hover{box-shadow:var(--shadow-lg);border-color:transparent}.user-card__header{display:flex;align-items:center;gap:var(--sp-4);margin-bottom:var(--sp-5)}.user-card__avatar{width:52px;height:52px;border-radius:var(--r-full);overflow:hidden;flex-shrink:0;border:2px solid var(--paper-3);cursor:pointer;transition:border-color var(--t-fast)}.user-card__avatar:hover{border-color:var(--ink)}.user-card__avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.user-card__name{font-weight:700;font-size:1rem;color:var(--ink);cursor:pointer}.user-card__name:hover{color:var(--accent)}.user-card__username{font-size:.78rem;color:var(--ink-5)}.user-card__level{margin-top:var(--sp-1)}.user-card__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-2);margin-bottom:var(--sp-5);padding:var(--sp-4);background:var(--paper-2);border-radius:var(--r-md)}.user-card__stat{text-align:center}.user-card__stat-num{font-weight:800;font-size:1.05rem;color:var(--ink)}.user-card__stat-label{font-size:.68rem;color:var(--ink-5);text-transform:uppercase;letter-spacing:.05em}.user-card__books{display:flex;gap:var(--sp-2);margin-bottom:var(--sp-5)}.user-card__book-thumb{width:40px;height:58px;border-radius:var(--r-sm);overflow:hidden;box-shadow:var(--shadow-sm)}.user-card__book-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.user-card__book-more{width:40px;height:58px;border-radius:var(--r-sm);background:var(--paper-2);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:600;color:var(--ink-5)}.user-card__actions{display:flex;gap:var(--sp-2)}.activity-feed{max-width:680px;margin:0 auto}.activity-item{display:flex;gap:var(--sp-4);padding:var(--sp-5);border-bottom:1px solid var(--paper-2);transition:background var(--t-fast)}.activity-item:hover{background:var(--paper-2)}.activity-item__avatar{width:40px;height:40px;border-radius:var(--r-full);overflow:hidden;flex-shrink:0}.activity-item__avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.activity-item__body{flex:1}.activity-item__text{font-size:.88rem;color:var(--ink-3);line-height:1.5}.activity-item__text strong{color:var(--ink)}.activity-item__text em{color:var(--accent);font-style:normal;font-weight:600}.activity-item__time{font-size:.74rem;color:var(--ink-5);margin-top:3px}.activity-item__book{display:flex;align-items:center;gap:var(--sp-3);margin-top:var(--sp-3);padding:var(--sp-3);background:var(--paper-2);border-radius:var(--r-md)}.activity-item__book-thumb{width:28px;height:40px;border-radius:var(--r-sm);overflow:hidden}.activity-item__book-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.activity-item__book-title{font-size:.8rem;font-weight:600;color:var(--ink-3)}.activity-item__book-author{font-size:.72rem;color:var(--ink-5)}.challenges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:var(--sp-6)}.challenge-card{background:var(--white);border:1px solid var(--paper-3);border-radius:var(--r-xl);padding:var(--sp-6);transition:all var(--t-base)}.challenge-card:hover{box-shadow:var(--shadow-lg);border-color:transparent}.challenge-card__top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--sp-4)}.challenge-card__icon{width:44px;height:44px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;background:var(--paper-2);color:var(--ink-3)}.challenge-card__title{font-size:1rem;font-weight:700;color:var(--ink);margin-bottom:var(--sp-2)}.challenge-card__desc{font-size:.84rem;color:var(--ink-4);margin-bottom:var(--sp-5);line-height:1.5}.challenge-progress{margin-bottom:var(--sp-4)}.challenge-progress__bar{width:100%;height:6px;background:var(--paper-2);border-radius:var(--r-full);overflow:hidden}.challenge-progress__fill{height:100%;border-radius:var(--r-full);transition:width 1s ease}.challenge-progress__fill--accent{background:var(--accent)}.challenge-progress__fill--sage{background:var(--sage)}.challenge-progress__fill--amber{background:var(--amber)}.challenge-progress__meta{display:flex;justify-content:space-between;font-size:.78rem;color:var(--ink-5);margin-top:var(--sp-1)}.challenge-participants{display:flex;align-items:center}.challenge-participant{width:26px;height:26px;border-radius:var(--r-full);border:2px solid var(--white);overflow:hidden;margin-left:-6px}.challenge-participant:first-child{margin-left:0}.challenge-participant img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.challenge-count{margin-left:var(--sp-3);font-size:.78rem;color:var(--ink-5)}.contact-header{padding-top:104px;padding-bottom:var(--sp-10);border-bottom:1px solid var(--paper-3)}.contact-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:var(--sp-12);align-items:start}.contact-form{background:var(--white);border:1px solid var(--paper-3);border-radius:var(--r-2xl);padding:var(--sp-8);box-shadow:var(--shadow-md)}.form-group{margin-bottom:var(--sp-5)}.form-label{display:block;font-weight:600;font-size:.84rem;color:var(--ink-3);margin-bottom:var(--sp-2)}.form-label span{color:var(--accent)}.form-input{width:100%;padding:.7rem var(--sp-4);border:1.5px solid var(--paper-3);border-radius:var(--r-md);background:var(--paper-2);color:var(--ink);font-size:.9rem;font-family:var(--font-body);transition:all var(--t-fast)}.form-input:focus{border-color:var(--ink-3);background:var(--white);box-shadow:0 0 0 3px #0f0f0f0f}.form-input::-moz-placeholder{color:var(--ink-5)}.form-input::placeholder{color:var(--ink-5)}textarea.form-input{min-height:130px;resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-5)}.contact-info-list{display:flex;flex-direction:column;gap:var(--sp-5)}.contact-info-item{display:flex;gap:var(--sp-4);padding:var(--sp-6);background:var(--white);border:1px solid var(--paper-3);border-radius:var(--r-xl);transition:all var(--t-base)}.contact-info-item:hover{box-shadow:var(--shadow-md);border-color:transparent}.contact-info-item__icon{width:42px;height:42px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:var(--ink-3);flex-shrink:0;background:var(--paper-2)}.contact-info-item__label{font-weight:700;font-size:.9rem;color:var(--ink);margin-bottom:2px}.contact-info-item__text{font-size:.84rem;color:var(--ink-4);line-height:1.5}.faq-list{max-width:680px;margin:0 auto}.faq-item{border-bottom:1px solid var(--paper-2)}.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;padding:var(--sp-5) 0;font-weight:600;font-size:.95rem;color:var(--ink-3);text-align:left;cursor:pointer;transition:color var(--t-fast)}.faq-question:hover{color:var(--ink)}.faq-question svg{flex-shrink:0;transition:transform var(--t-base);color:var(--ink-5)}.faq-item.open .faq-question svg{transform:rotate(45deg);color:var(--ink)}.faq-answer{max-height:0;overflow:hidden;transition:max-height var(--t-slow)}.faq-item.open .faq-answer{max-height:200px}.faq-answer p{padding-bottom:var(--sp-5);color:var(--ink-4);line-height:1.7;font-size:.9rem}.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--sp-6)}.testimonial-card{background:var(--white);border:1px solid var(--paper-3);border-radius:var(--r-xl);padding:var(--sp-8);transition:all var(--t-base)}.testimonial-card:hover{box-shadow:var(--shadow-lg);border-color:transparent}.testimonial-card__quote{font-family:var(--font-display);font-size:2.5rem;color:var(--paper-4);line-height:1;margin-bottom:var(--sp-2)}.testimonial-card__text{font-size:.92rem;color:var(--ink-4);line-height:1.75;margin-bottom:var(--sp-6)}.testimonial-card__avatar{width:44px;height:44px;border-radius:var(--r-full);overflow:hidden}.testimonial-card__name{font-weight:700;font-size:.9rem;color:var(--ink)}.testimonial-card__role{font-size:.78rem;color:var(--ink-5)}.newsletter{background:var(--ink);border-radius:var(--r-2xl);padding:var(--sp-12) var(--sp-10);text-align:center;color:var(--paper);position:relative;overflow:hidden}.newsletter:before{content:"";position:absolute;width:300px;height:300px;background:var(--accent);border-radius:50%;top:-150px;right:-100px;opacity:.06}.newsletter__title{font-family:var(--font-display);font-size:clamp(1.5rem,3vw,2rem);margin-bottom:var(--sp-2);position:relative;z-index:1}.newsletter__sub{font-size:.95rem;opacity:.65;margin-bottom:var(--sp-8);position:relative;z-index:1}.newsletter__form{display:flex;max-width:440px;margin:0 auto;gap:var(--sp-2);position:relative;z-index:1}.newsletter__input{flex:1;padding:.75rem var(--sp-5);border-radius:var(--r-md);background:#ffffff1a;color:var(--paper);font-size:.9rem;border:1px solid rgba(255,255,255,.2)}.newsletter__input::-moz-placeholder{color:#fff6}.newsletter__input::placeholder{color:#fff6}.newsletter__btn{padding:.75rem var(--sp-6);background:var(--accent);color:#fff;font-weight:700;border-radius:var(--r-md);transition:all var(--t-base);white-space:nowrap}.newsletter__btn:hover{background:var(--accent-light);transform:translateY(-1px)}.profile-modal{position:fixed;inset:0;z-index:3000;display:none;align-items:center;justify-content:center;padding:var(--sp-6);background:#0f0f0f8c;backdrop-filter:blur(8px)}.profile-modal.show{display:flex}.profile-modal__box{position:relative;background:var(--white);border-radius:var(--r-2xl);max-width:820px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:scaleIn .28s ease}.profile-cover{width:100%;height:160px;background:var(--ink);position:relative;border-radius:var(--r-2xl) var(--r-2xl) 0 0;overflow:hidden}.profile-cover__pattern{position:absolute;inset:0;opacity:.04;background-image:repeating-linear-gradient(45deg,#fff 0,#fff 1px,transparent 0,transparent 50%);background-size:12px 12px}.profile-cover__accent{position:absolute;right:-60px;top:-60px;width:240px;height:240px;background:var(--accent);border-radius:50%;opacity:.12}.profile-header{padding:0 var(--sp-8) var(--sp-6);position:relative}.profile-avatar-wrap{display:inline-block;margin-top:-44px;margin-bottom:var(--sp-4);position:relative}.profile-avatar{width:88px;height:88px;border-radius:var(--r-full);border:4px solid var(--white);overflow:hidden;box-shadow:var(--shadow-md);cursor:pointer;position:relative}.profile-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.profile-avatar__overlay{position:absolute;inset:0;border-radius:var(--r-full);background:#0f0f0f80;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--t-fast);color:#fff}.profile-avatar:hover .profile-avatar__overlay{opacity:1}.profile-online{position:absolute;bottom:4px;right:4px;width:16px;height:16px;background:var(--sage);border-radius:var(--r-full);border:3px solid var(--white)}.profile-name{font-family:var(--font-display);font-size:1.6rem;color:var(--ink);margin-bottom:2px}.profile-username{font-size:.85rem;color:var(--ink-5);margin-bottom:var(--sp-3)}.profile-bio{font-size:.88rem;color:var(--ink-4);max-width:440px;line-height:1.55}.profile-header__row{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:var(--sp-4)}.profile-stats-bar{display:flex;gap:var(--sp-8);padding:var(--sp-5) var(--sp-8);border-top:1px solid var(--paper-2);border-bottom:1px solid var(--paper-2);background:var(--paper-2);overflow-x:auto}.profile-stat{text-align:center;flex-shrink:0}.profile-stat__num{font-family:var(--font-display);font-size:1.4rem;color:var(--ink);line-height:1}.profile-stat__label{font-size:.7rem;color:var(--ink-5);text-transform:uppercase;letter-spacing:.08em;margin-top:3px}.profile-body{padding:var(--sp-6) var(--sp-8) var(--sp-8);display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-8)}.profile-section-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-5);margin-bottom:var(--sp-4)}.profile-book-row{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2);border-radius:var(--r-md);transition:background var(--t-fast);cursor:pointer}.profile-book-row:hover{background:var(--paper-2)}.profile-book-row__thumb{width:34px;height:48px;border-radius:var(--r-sm);overflow:hidden;flex-shrink:0;box-shadow:var(--shadow-sm)}.profile-book-row__thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.profile-book-row__title{font-size:.84rem;font-weight:600;color:var(--ink)}.profile-book-row__author{font-size:.74rem;color:var(--ink-5)}.profile-book-row__rating{margin-left:auto;font-size:.74rem;color:var(--amber);flex-shrink:0}.profile-badges-grid{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.profile-badge{display:flex;flex-direction:column;align-items:center;gap:3px;padding:var(--sp-2) var(--sp-3);background:var(--paper-2);border:1px solid var(--paper-3);border-radius:var(--r-md);transition:all var(--t-fast)}.profile-badge:hover{border-color:var(--ink-3);background:var(--white)}.profile-badge__icon{color:var(--ink-3)}.profile-badge__name{font-size:.65rem;font-weight:600;color:var(--ink-5);text-align:center}.profile-genre-list{display:flex;flex-direction:column;gap:var(--sp-3)}.profile-genre-row__header{display:flex;justify-content:space-between;margin-bottom:4px;font-size:.82rem}.profile-genre-row__label{font-weight:600;color:var(--ink-3)}.profile-genre-row__pct{color:var(--ink-5)}.profile-genre-row__bar{width:100%;height:4px;background:var(--paper-3);border-radius:var(--r-full);overflow:hidden}.profile-genre-row__fill{height:100%;background:var(--accent);border-radius:var(--r-full)}.edit-modal{position:fixed;inset:0;z-index:4000;display:none;align-items:center;justify-content:center;padding:var(--sp-6);background:#0f0f0f99;backdrop-filter:blur(10px)}.edit-modal.show{display:flex}.edit-modal__box{position:relative;background:var(--white);border-radius:var(--r-2xl);max-width:520px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:scaleIn .25s ease}.edit-modal__header{padding:var(--sp-6) var(--sp-8) var(--sp-5);border-bottom:1px solid var(--paper-2);display:flex;align-items:center;justify-content:space-between}.edit-modal__title{font-family:var(--font-display);font-size:1.2rem;color:var(--ink)}.edit-modal__close{width:32px;height:32px;background:var(--paper-2);border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;color:var(--ink-4);cursor:pointer;transition:all var(--t-fast)}.edit-modal__close:hover{background:var(--paper-3);color:var(--ink)}.edit-modal__body{padding:var(--sp-6) var(--sp-8)}.edit-modal__footer{padding:var(--sp-5) var(--sp-8) var(--sp-6);border-top:1px solid var(--paper-2);display:flex;gap:var(--sp-3);justify-content:flex-end}.avatar-row{display:flex;align-items:center;gap:var(--sp-6);margin-bottom:var(--sp-6)}.avatar-preview{width:72px;height:72px;border-radius:var(--r-full);overflow:hidden;border:3px solid var(--paper-3);flex-shrink:0}.avatar-preview img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.avatar-grid{display:flex;gap:var(--sp-2);flex-wrap:wrap}.avatar-opt{width:44px;height:44px;border-radius:var(--r-full);overflow:hidden;border:2.5px solid transparent;cursor:pointer;transition:all var(--t-base)}.avatar-opt:hover{border-color:var(--paper-4);transform:scale(1.08)}.avatar-opt.selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-bg)}.avatar-opt img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.settings-section{margin-bottom:var(--sp-6)}.settings-section__title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-5);margin-bottom:var(--sp-4);padding-bottom:var(--sp-2);border-bottom:1px solid var(--paper-2)}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4) 0;border-bottom:1px solid var(--paper-2)}.settings-row:last-child{border-bottom:none}.settings-row__info{flex:1}.settings-row__label{font-size:.9rem;font-weight:600;color:var(--ink)}.settings-row__desc{font-size:.78rem;color:var(--ink-5);margin-top:1px}.toggle{position:relative;width:40px;height:22px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0}.toggle__track{position:absolute;inset:0;background:var(--paper-3);border-radius:var(--r-full);cursor:pointer;transition:all var(--t-base)}.toggle__track:before{content:"";position:absolute;width:16px;height:16px;left:3px;top:3px;background:#fff;border-radius:50%;transition:all var(--t-base)}.toggle input:checked+.toggle__track{background:var(--ink)}.toggle input:checked+.toggle__track:before{transform:translate(18px)}.settings-select{padding:.4rem .8rem;border:1px solid var(--paper-3);border-radius:var(--r-md);background:var(--paper-2);color:var(--ink-3);font-size:.82rem;cursor:pointer;font-family:var(--font-body)}.danger-zone{background:#fef2f2;border:1px solid #FECACA;border-radius:var(--r-lg);padding:var(--sp-5);margin-top:var(--sp-4)}.danger-zone__title{font-size:.78rem;font-weight:700;color:#dc2626;margin-bottom:var(--sp-3);text-transform:uppercase;letter-spacing:.06em}.footer{background:var(--ink);color:#ffffff80;padding:var(--sp-20) 0 var(--sp-8)}.footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:var(--sp-10);margin-bottom:var(--sp-12)}.footer__brand-logo{display:flex;align-items:center;gap:var(--sp-2);font-family:var(--font-display);font-style:italic;font-size:1.3rem;color:var(--paper);margin-bottom:var(--sp-4)}.footer__brand-mark{width:28px;height:28px;background:var(--accent);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center}.footer__brand-mark svg{color:#fff}.footer__desc{font-size:.84rem;line-height:1.7;margin-bottom:var(--sp-5)}.footer__social{display:flex;gap:var(--sp-2)}.footer__social-link{width:34px;height:34px;border-radius:var(--r-md);background:#ffffff12;display:flex;align-items:center;justify-content:center;color:#ffffff80;transition:all var(--t-fast)}.footer__social-link:hover{background:var(--accent);color:#fff}.footer__col-title{font-weight:700;font-size:.84rem;color:var(--paper);margin-bottom:var(--sp-4);text-transform:uppercase;letter-spacing:.06em}.footer__links li{margin-bottom:var(--sp-3)}.footer__links a{font-size:.84rem;color:#ffffff73;transition:color var(--t-fast)}.footer__links a:hover{color:var(--paper)}.footer__bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:var(--sp-6);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--sp-4)}.footer__copy{font-size:.82rem}.footer__legal{display:flex;gap:var(--sp-6)}.footer__legal a{font-size:.82rem;color:#ffffff59;transition:color var(--t-fast)}.footer__legal a:hover{color:var(--paper)}.toast-container{position:fixed;top:80px;right:var(--sp-5);z-index:5000;display:flex;flex-direction:column;gap:var(--sp-2)}.toast{background:var(--white);border-radius:var(--r-lg);padding:var(--sp-4) var(--sp-5);box-shadow:var(--shadow-xl);display:flex;align-items:center;gap:var(--sp-3);min-width:280px;max-width:380px;animation:slideInRight .28s ease;border-left:3px solid var(--sage)}.toast--error{border-left-color:#dc2626}.toast--info{border-left-color:var(--cobalt)}.toast__icon{flex-shrink:0;color:var(--ink-4)}.toast__msg{font-size:.875rem;color:var(--ink-3);font-weight:500;flex:1}.toast__close{color:var(--ink-5);cursor:pointer;flex-shrink:0}.toast__close:hover{color:var(--ink)}.scroll-top{position:fixed;bottom:var(--sp-6);right:var(--sp-6);width:40px;height:40px;background:var(--ink);color:var(--paper);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transition:all var(--t-base);z-index:100}.scroll-top.show{opacity:1;visibility:visible}.scroll-top:hover{background:var(--ink-3);transform:translateY(-2px)}.lib-ctx-menu{position:fixed;background:var(--white);border:1px solid var(--paper-3);border-radius:var(--r-xl);box-shadow:var(--shadow-xl);z-index:9999;min-width:180px;overflow:hidden;animation:scaleIn .18s ease}.lib-ctx-item{display:flex;align-items:center;gap:var(--sp-3);width:100%;padding:.65rem var(--sp-5);text-align:left;font-size:.875rem;font-weight:500;color:var(--ink-3);transition:background var(--t-fast);border:none;background:none;cursor:pointer;font-family:var(--font-body)}.lib-ctx-item:hover{background:var(--paper-2);color:var(--ink)}.lib-ctx-item svg{color:var(--ink-5);flex-shrink:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@media (max-width: 1024px){.hero__grid{grid-template-columns:1fr;text-align:center}.hero__desc{margin:0 auto var(--sp-10)}.hero__cta,.hero__metrics{justify-content:center}.hero__visual{display:none}.footer__grid{grid-template-columns:1fr 1fr}.contact-grid,.blog-featured{grid-template-columns:1fr}.blog-featured__img{min-height:240px}.community-stats,.library-stats{grid-template-columns:repeat(2,1fr)}.book-modal__grid,.library-goal,.profile-body{grid-template-columns:1fr}}@media (max-width: 768px){.navbar__menu{display:none}.navbar__toggle{display:flex}.hero{padding-top:104px;min-height:auto;padding-bottom:var(--sp-16)}.catalog-grid,.library-grid{grid-template-columns:repeat(2,1fr)}.form-row{grid-template-columns:1fr}.newsletter__form{flex-direction:column}.footer__grid{grid-template-columns:1fr}.footer__bottom{flex-direction:column;text-align:center}.notif-panel{width:calc(100vw - 2rem);right:var(--sp-4)}.profile-cover{height:120px}.profile-header{padding:0 var(--sp-5) var(--sp-5)}.profile-stats-bar{padding:var(--sp-4) var(--sp-5);gap:var(--sp-5)}.profile-body{padding:var(--sp-5);gap:var(--sp-6)}}@media (max-width: 480px){.catalog-grid,.library-grid{grid-template-columns:1fr}.library-stats,.community-stats{grid-template-columns:1fr 1fr}.features-grid{grid-template-columns:1fr}}.page-header{background:var(--paper-2);border-bottom:1px solid var(--paper-3);padding:120px 0 var(--sp-8);margin-top:0}.page-header__row{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4)}.page-header__title{font-family:var(--font-display);font-size:clamp(1.6rem,3vw,2.2rem);color:var(--ink);line-height:1.15}.page-header__subtitle{color:var(--ink-4);font-size:.95rem;margin-top:var(--sp-2)}.catalog-result-count{font-size:.85rem;color:var(--ink-4);margin-bottom:var(--sp-4)}.catalog-empty{grid-column:1/-1;text-align:center;color:var(--ink-4);padding:3rem;font-size:1rem}.lib-add-menu{background:var(--white);border:1px solid var(--paper-3);border-radius:var(--r-lg);box-shadow:var(--shadow-xl);overflow:hidden;min-width:175px}.lib-add-menu__item{display:flex;align-items:center;gap:var(--sp-3);width:100%;padding:.6rem 1rem;font-size:.88rem;font-weight:500;color:var(--ink-3);text-align:left;background:none;border:none;cursor:pointer;transition:background var(--t-fast)}.lib-add-menu__item:hover{background:var(--paper-2)}.lib-add-menu__icon{display:flex;align-items:center;color:var(--ink-4);flex-shrink:0}.book-card-full__save{position:absolute;top:var(--sp-2);right:var(--sp-2);width:32px;height:32px;background:var(--white);border:1px solid var(--paper-3);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--t-base);color:var(--ink-4);opacity:0}.book-card-full:hover .book-card-full__save{opacity:1}.book-card-full__save:hover{background:var(--ink);color:var(--paper);border-color:var(--ink);transform:scale(1.05)}.book-card-full__save.active{opacity:1;background:var(--ink);color:var(--paper);border-color:var(--ink)}.input-prefix-wrap{display:flex;align-items:center;border:1.5px solid var(--paper-3);border-radius:var(--r-md);overflow:hidden;transition:border-color var(--t-fast)}.input-prefix-wrap:focus-within{border-color:var(--ink-3)}.input-prefix{padding:0 var(--sp-3);font-size:.9rem;color:var(--ink-4);background:var(--paper-2);align-self:stretch;display:flex;align-items:center;border-right:1px solid var(--paper-3)}.input-prefix-input{border:none!important;border-radius:0!important;flex:1}.form-hint{font-size:.78rem;color:var(--ink-5);margin-top:var(--sp-1);display:block}.edit-avatar-preview{width:72px;height:72px;border-radius:var(--r-full);-o-object-fit:cover;object-fit:cover;border:2px solid var(--paper-3);margin:0 auto var(--sp-4);display:block}.edit-avatar-label{font-size:.82rem;color:var(--ink-4);text-align:center;margin-bottom:var(--sp-4)}.onboarding__dot{width:8px;height:8px;border-radius:var(--r-full);background:var(--paper-3);transition:background var(--t-base)}.onboarding__dot.active{background:var(--ink)}.ob-genres{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin-top:var(--sp-2)}.ob-genre-btn{padding:.4rem .9rem;border:1.5px solid var(--paper-3);border-radius:var(--r-full);font-size:.85rem;font-weight:500;color:var(--ink-3);background:var(--paper-2);cursor:pointer;transition:all var(--t-fast)}.ob-genre-btn:hover{border-color:var(--ink-3);color:var(--ink)}.ob-genre-btn.selected{background:var(--ink);color:var(--paper);border-color:var(--ink)}.navbar__icon-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--r-md);color:var(--ink-3);background:none;transition:all var(--t-fast)}.navbar__icon-btn:hover{background:var(--paper-2);color:var(--ink)}.navbar__avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--paper-2);color:var(--ink-4)}.reading-goal__title-row{display:flex;align-items:center;gap:var(--sp-2)}.reading-goal__edit{display:flex;align-items:center;padding:3px;color:var(--ink-5);border-radius:var(--r-sm);transition:color var(--t-fast)}.reading-goal__edit:hover{color:var(--ink)}.challenge-card__footer{display:flex;align-items:center;justify-content:space-between;margin-top:var(--sp-4)}.user-card__avatar--club{background:var(--paper-2);color:var(--ink-3);border:1px solid var(--paper-3);display:flex;align-items:center;justify-content:center}.toast{opacity:0;transform:translateY(8px);transition:opacity .25s ease,transform .25s ease}.toast.show{opacity:1;transform:translateY(0)}.profile-header__avatar--editable{cursor:pointer}.section-label{display:inline-flex;align-items:center;gap:var(--sp-2);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);background:var(--accent-bg);padding:var(--sp-1) var(--sp-3);border-radius:var(--r-full);margin-bottom:var(--sp-4)}.library-book__remove{position:absolute;top:var(--sp-2);left:var(--sp-2);width:28px;height:28px;background:#0f0f0fb3;color:#fff;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--t-fast)}.library-book:hover .library-book__remove{opacity:1}.library-book__remove:hover{background:#dc2626}.profile-section-title{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-5);margin-bottom:var(--sp-4)}.library-empty__text{font-size:1.05rem;font-weight:600;color:var(--ink-3);margin-bottom:var(--sp-2)}.library-empty__sub{font-size:.9rem;color:var(--ink-5);margin-bottom:var(--sp-6)}.book-card-full__badge{position:absolute;top:var(--sp-2);left:var(--sp-2)}.book-card-full__cover{position:relative;overflow:hidden;border-radius:var(--r-md);background:var(--paper-3)}.book-card-full__cover img{width:100%;aspect-ratio:2/3;-o-object-fit:cover;object-fit:cover;display:block}.book-card-full__info{padding:var(--sp-3) 0 0}.book-card-full__title{font-family:var(--font-display);font-size:.95rem;color:var(--ink);line-height:1.3;margin-bottom:var(--sp-1)}.book-card-full__author{font-size:.82rem;color:var(--ink-4);margin-bottom:var(--sp-2)}.book-card-full__footer{display:flex;align-items:center;justify-content:space-between}.book-card-full__price{font-size:.88rem;font-weight:600;color:var(--accent)}.book-modal__details{flex:1;display:flex;flex-direction:column;gap:var(--sp-4)}.book-modal__title{font-family:var(--font-display);font-size:1.6rem;color:var(--ink);line-height:1.2}.book-modal__author-name{color:var(--ink-4);font-size:1rem}.book-modal__meta{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.book-modal__synopsis{color:var(--ink-3);font-size:.95rem;line-height:1.7}.book-modal__actions{display:flex;gap:var(--sp-3);flex-wrap:wrap;margin-top:auto;padding-top:var(--sp-2)}.profile-header__avatar-wrap{position:relative;flex-shrink:0}.profile-header__avatar-overlay{position:absolute;inset:0;border-radius:var(--r-full);background:#00000073;color:#fff;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--t-fast)}.profile-header__avatar--editable:hover .profile-header__avatar-overlay{opacity:1}.profile-header__online{position:absolute;bottom:3px;right:3px;width:14px;height:14px;background:#22c55e;border:2px solid var(--white);border-radius:var(--r-full)}.profile-header__info{flex:1;display:flex;justify-content:space-between;align-items:flex-start;gap:var(--sp-4);flex-wrap:wrap}.profile-header__name{font-family:var(--font-display);font-size:1.5rem;color:var(--ink)}.profile-header__username{color:var(--ink-4);font-size:.9rem;margin:var(--sp-1) 0 var(--sp-2);display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap}.profile-header__bio{color:var(--ink-3);font-size:.9rem;line-height:1.6;max-width:480px}.profile-header__actions{display:flex;gap:var(--sp-2);flex-shrink:0}.profile-stats-row{display:flex;gap:var(--sp-6);flex-wrap:wrap;padding:var(--sp-6) 0;border-top:1px solid var(--paper-3);border-bottom:1px solid var(--paper-3);margin:var(--sp-6) 0}.profile-stat__number{font-family:var(--font-display);font-size:1.4rem;color:var(--ink);line-height:1}.profile-stat__label{font-size:.78rem;color:var(--ink-5);margin-top:var(--sp-1);text-transform:uppercase;letter-spacing:.06em}.profile-book-item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) 0;border-bottom:1px solid var(--paper-2);cursor:pointer;transition:background var(--t-fast)}.profile-book-item:last-child{border-bottom:none}.profile-book-item:hover{background:var(--paper-2);border-radius:var(--r-md);padding-left:var(--sp-2)}.profile-book-item__thumb img{width:38px;height:54px;-o-object-fit:cover;object-fit:cover;border-radius:var(--r-sm)}.profile-book-item__title{font-size:.88rem;font-weight:600;color:var(--ink)}.profile-book-item__author{font-size:.8rem;color:var(--ink-4);margin-top:2px}.profile-book-item__stars{margin-left:auto;font-size:.8rem;color:var(--amber);white-space:nowrap}.profile-badges{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.profile-badge-item{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);background:var(--paper-2);border-radius:var(--r-md);border:1px solid var(--paper-3)}.profile-badge-item__icon{color:var(--ink-3);display:flex}.profile-badge-item__name{font-size:.8rem;font-weight:600;color:var(--ink-3)}.profile-progress-list{display:flex;flex-direction:column;gap:var(--sp-3)}.profile-progress-item__header{display:flex;justify-content:space-between;font-size:.85rem;color:var(--ink-3);margin-bottom:var(--sp-1)}.profile-progress-item__bar{height:6px;background:var(--paper-3);border-radius:var(--r-full);overflow:hidden}.profile-progress-item__fill{height:100%;background:var(--accent);border-radius:var(--r-full);transition:width .8s ease}.toast__message{flex:1;font-size:.88rem}.user-card__footer{display:flex;gap:var(--sp-2);margin-top:var(--sp-4)}.challenge-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--sp-3);margin-bottom:var(--sp-2)}.challenge-card__progress{margin:var(--sp-4) 0 0}.challenge-card__progress-bar{height:8px;background:var(--paper-3);border-radius:var(--r-full);overflow:hidden;margin-bottom:var(--sp-2)}.challenge-card__progress-fill{height:100%;border-radius:var(--r-full);transition:width 1s ease}.challenge-card__progress-text{display:flex;justify-content:space-between;font-size:.8rem;color:var(--ink-4)}.challenge-card__participants{display:flex;align-items:center;gap:var(--sp-1)}.challenge-card__participant-avatar img{width:28px;height:28px;border-radius:var(--r-full);border:2px solid var(--white);margin-left:-6px;-o-object-fit:cover;object-fit:cover}.challenge-card__participant-avatar:first-child{margin-left:0}.challenge-card__participant-count{font-size:.8rem;color:var(--ink-4);margin-left:var(--sp-2)}.activity-item__content{flex:1}.activity-item__text{font-size:.9rem;color:var(--ink-3);line-height:1.5;margin-bottom:var(--sp-1)}.activity-item__time{font-size:.78rem;color:var(--ink-5);margin-bottom:var(--sp-3)}.activity-item__book{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);background:var(--paper-2);border-radius:var(--r-md)}.activity-item__book-thumb img{width:32px;height:44px;-o-object-fit:cover;object-fit:cover;border-radius:var(--r-sm)}.activity-item__book-title{font-size:.85rem;font-weight:600;color:var(--ink)}.activity-item__book-author{font-size:.78rem;color:var(--ink-4)}.search-result-item__img img{width:40px;height:56px;-o-object-fit:cover;object-fit:cover;border-radius:var(--r-sm)}.search-result-item__info h4{font-size:.9rem;font-weight:600;color:var(--ink)}.search-result-item__info p{font-size:.8rem;color:var(--ink-4);margin-top:2px}.search-hint{text-align:center;color:var(--ink-4);padding:2rem;font-size:.9rem}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-6) var(--sp-6) 0}.modal__body{padding:var(--sp-6);overflow-y:auto}.modal__footer{display:flex;justify-content:flex-end;gap:var(--sp-3);padding:0 var(--sp-6) var(--sp-6);border-top:1px solid var(--paper-3);padding-top:var(--sp-5)}.modal__title{font-family:var(--font-display);font-size:1.25rem;color:var(--ink)}.modal__close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--r-md);color:var(--ink-4);transition:all var(--t-fast);flex-shrink:0}.modal__close:hover{background:var(--paper-2);color:var(--ink)}.form-textarea{width:100%;padding:.65rem var(--sp-4);border:1.5px solid var(--paper-3);border-radius:var(--r-md);font-size:.9rem;color:var(--ink);background:var(--white);resize:vertical;line-height:1.6;transition:border-color var(--t-fast);font-family:var(--font-body)}.form-textarea:focus{border-color:var(--ink-3);outline:none}.settings-item{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4) 0;border-bottom:1px solid var(--paper-2)}.settings-item:last-child{border-bottom:none}.settings-item__label{font-size:.9rem;font-weight:600;color:var(--ink)}.settings-item__sub{font-size:.8rem;color:var(--ink-4);margin-top:2px}.settings-section--danger{border-top:1px solid #FECACA;padding-top:var(--sp-4);margin-top:var(--sp-2)}.settings-section--danger .settings-section__title{color:#dc2626}.settings-section--danger{display:flex;flex-direction:column;gap:var(--sp-3);align-items:flex-start}.toggle-switch{position:relative;display:inline-flex;cursor:pointer}.toggle-switch input{position:absolute;opacity:0;width:0;height:0}.toggle-switch__track{display:block;width:42px;height:24px;background:var(--paper-3);border-radius:var(--r-full);transition:background var(--t-base);position:relative}.toggle-switch__track:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;background:var(--white);border-radius:var(--r-full);transition:transform var(--t-base);box-shadow:var(--shadow-sm)}.toggle-switch input:checked+.toggle-switch__track{background:var(--ink)}.toggle-switch input:checked+.toggle-switch__track:after{transform:translate(18px)}.avatar-option{cursor:pointer;border-radius:var(--r-full);border:2.5px solid transparent;transition:border-color var(--t-fast),transform var(--t-fast);overflow:hidden;flex-shrink:0}.avatar-option img{display:block;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.avatar-option:hover{border-color:var(--ink-4);transform:scale(1.05)}.avatar-option.selected{border-color:var(--ink);transform:scale(1.05)}.avatar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-3);margin-bottom:var(--sp-4)}.avatar-grid .avatar-option{width:60px;height:60px}.edit-avatar-section{text-align:center;margin-bottom:var(--sp-6)}.onboarding__progress{display:flex;justify-content:center;gap:var(--sp-2);margin-top:var(--sp-6)}.library-stat__icon{display:flex;align-items:center;justify-content:center}.library-stat__icon--cobalt{color:var(--cobalt)}.library-stat__icon--accent{color:var(--accent)}.library-stat__icon--amber{color:var(--amber)}.library-stat__icon--sage{color:var(--sage)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-6) var(--sp-6) 0}.modal-body{padding:var(--sp-6);overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:var(--sp-3);padding:var(--sp-5) var(--sp-6) var(--sp-6);border-top:1px solid var(--paper-3)}.modal-title{font-family:var(--font-display);font-size:1.25rem;color:var(--ink)}.modal-box--profile{max-width:820px;padding:0;overflow:hidden}.modal-box--profile .profile-body{padding:var(--sp-6) var(--sp-8) var(--sp-8)}.profile-avatar--editable{cursor:pointer}.profile-avatar--editable:hover .profile-avatar__overlay{opacity:1}.edit-fields{display:flex;flex-direction:column;gap:var(--sp-4)}.edit-avatar-section{display:flex;flex-direction:column;align-items:center;margin-bottom:var(--sp-4)}.profile-books-list{display:flex;flex-direction:column}.modal-box--blog{max-width:720px;padding:0;overflow:hidden}.blog-modal__hero{position:relative;height:260px;overflow:hidden}.blog-modal__hero img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.blog-modal__hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(15,15,15,.55))}.blog-modal__content{padding:var(--sp-8)}.blog-modal__title{font-family:var(--font-display);font-size:clamp(1.3rem,3vw,1.8rem);color:var(--ink);line-height:1.25;margin-bottom:var(--sp-5)}.blog-modal__meta{margin-bottom:var(--sp-6);padding-bottom:var(--sp-5);border-bottom:1px solid var(--paper-3)}.blog-modal__author-name{font-size:.9rem;font-weight:600;color:var(--ink)}.blog-modal__author-date{font-size:.8rem;color:var(--ink-5);margin-top:2px}.blog-modal__body{color:var(--ink-3);font-size:.97rem;line-height:1.85}.blog-modal__body h3{font-family:var(--font-display);font-size:1.15rem;color:var(--ink);margin:var(--sp-6) 0 var(--sp-2)}.blog-modal__body p{margin-bottom:var(--sp-4)}.blog-modal__footer{display:flex;justify-content:space-between;align-items:center;margin-top:var(--sp-8);padding-top:var(--sp-6);border-top:1px solid var(--paper-3)}.modal-box--profile>.modal-close{position:absolute;top:var(--sp-4);right:var(--sp-4);z-index:2;background:#ffffff26;color:#fff;backdrop-filter:blur(4px)}.modal-box--profile>.modal-close:hover{background:#ffffff40;color:#fff}.profile-header{display:flex;align-items:flex-end;gap:var(--sp-5);flex-wrap:wrap;padding:0 var(--sp-8) var(--sp-5)}.profile-header__row{flex:1;display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:var(--sp-4);padding-bottom:var(--sp-2)}.footer__logo-mark{width:28px;height:28px;background:var(--accent);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.footer__logo{display:flex;align-items:center;gap:var(--sp-3)}.scroll-top svg{display:block}.blog-card{cursor:pointer}.modal-box{position:relative}.profile-cover{background:linear-gradient(135deg,var(--ink) 0%,#2a2a2e 100%)}@media (max-width: 600px){.blog-modal__hero{height:180px}.blog-modal__content{padding:var(--sp-5)}.blog-modal__footer{flex-direction:column;gap:var(--sp-3)}.blog-modal__footer .btn{width:100%;justify-content:center}}.footer__copyright{font-size:.82rem;color:#ffffff59}.footer__bottom-links{display:flex;gap:var(--sp-5)}.footer__bottom-links a{font-size:.82rem;color:#ffffff59;transition:color var(--t-fast)}.footer__bottom-links a:hover{color:#ffffffb3}.modal-box--blog{max-width:720px;padding:0;overflow-y:auto;overflow-x:hidden;max-height:90vh}.modal-box--blog .blog-modal__hero{position:sticky;position:relative;flex-shrink:0}.community-stat-card{background:var(--white);border:1px solid var(--paper-3);border-radius:var(--r-xl);padding:var(--sp-6);text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--sp-3);box-shadow:var(--shadow-sm);transition:transform var(--t-base),box-shadow var(--t-base)}.community-stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.community-stat-card__icon{width:48px;height:48px;background:var(--paper-2);border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;color:var(--ink-3)}.community-stat-card__number{font-family:var(--font-display);font-size:2rem;color:var(--ink);line-height:1}.community-stat-card__label{font-size:.82rem;color:var(--ink-5);text-transform:uppercase;letter-spacing:.06em}.contact-info-card{background:var(--white);border:1px solid var(--paper-3);border-radius:var(--r-xl);padding:var(--sp-6);text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--sp-3);box-shadow:var(--shadow-sm)}.contact-info-card__icon{width:48px;height:48px;background:var(--paper-2);border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;color:var(--ink-3)}.contact-info-card__title{font-weight:700;color:var(--ink);font-size:.9rem}.contact-info-card__value{color:var(--ink-4);font-size:.88rem}.library-stat{background:var(--white);border:1px solid var(--paper-3);border-radius:var(--r-xl);padding:var(--sp-5) var(--sp-6);display:flex;align-items:center;gap:var(--sp-4);box-shadow:var(--shadow-sm)}.library-stat__number{font-family:var(--font-display);font-size:1.8rem;color:var(--ink);line-height:1}.library-stat__label{font-size:.78rem;color:var(--ink-5);text-transform:uppercase;letter-spacing:.06em;margin-top:3px}.feature-card{background:var(--white);border:1px solid var(--paper-3);border-radius:var(--r-xl);padding:var(--sp-7);box-shadow:var(--shadow-sm);transition:transform var(--t-base),box-shadow var(--t-base)}.feature-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.feature-card__icon{width:48px;height:48px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;margin-bottom:var(--sp-5)}.feature-card__title{font-family:var(--font-display);font-size:1.15rem;color:var(--ink);margin-bottom:var(--sp-2)}.feature-card__desc{font-size:.88rem;color:var(--ink-4);line-height:1.65}.testimonial-card{background:var(--white);border:1px solid var(--paper-3);border-radius:var(--r-xl);padding:var(--sp-7);box-shadow:var(--shadow-sm)}.testimonial-card__stars{color:var(--amber);font-size:.9rem;margin-bottom:var(--sp-4);letter-spacing:2px}.testimonial-card__text{font-size:.92rem;color:var(--ink-3);line-height:1.75;margin-bottom:var(--sp-5);font-style:italic}.testimonial-card__author{display:flex;align-items:center;gap:var(--sp-3)}.testimonial-card__avatar{width:44px;height:44px;border-radius:var(--r-full);overflow:hidden;flex-shrink:0}.testimonial-card__avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.testimonial-card__name{font-weight:700;font-size:.88rem;color:var(--ink)}.testimonial-card__role{font-size:.78rem;color:var(--ink-5);margin-top:2px}.loading-spinner{width:40px;height:40px;border:3px solid var(--surface-2, #e2e8f0);border-top-color:var(--accent, #6c63ff);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.pagination{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:2rem 0}.pagination__btn{min-width:40px;height:40px;padding:0 .75rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-1);color:var(--ink-3);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.pagination__btn:hover:not(:disabled){background:var(--accent);color:#fff;border-color:var(--accent)}.pagination__btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.pagination__btn:disabled{opacity:.4;cursor:not-allowed}.form-error{display:block;color:var(--error, #e53e3e);font-size:.8rem;margin-top:.25rem;min-height:1rem}.form-input--error{border-color:var(--error, #e53e3e)!important}
