*{box-sizing:border-box;margin:0;padding:0}body{color:#e0e0e0;background-color:#1a1a2e;min-height:100vh;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}#root{min-height:100vh}.star-rating{gap:2px;display:flex}.star{color:#3a3a5a;cursor:default;background:0 0;border:none;padding:0;line-height:1;transition:color .1s,transform .1s}.star.filled{color:#f5a623}.star-rating.interactive .star{cursor:pointer}.star-rating.interactive .star:hover,.star-rating.interactive .star:focus{outline:none;transform:scale(1.2)}.star-rating--sm .star{font-size:.9rem}.star-rating--md .star{font-size:1.4rem}.star-rating--lg .star{font-size:1.8rem}.book-card{cursor:pointer;background:#16213e;border:1px solid #0f3460;border-radius:12px;flex-direction:column;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex;overflow:hidden}.book-card:hover{border-color:#e94560;transform:translateY(-4px);box-shadow:0 8px 24px #0006}.book-cover-wrapper{aspect-ratio:2/3;background:#0f3460;flex-shrink:0;width:100%;overflow:hidden}.book-cover{object-fit:cover;width:100%;height:100%;transition:transform .3s;display:block}.book-card:hover .book-cover{transform:scale(1.04)}.book-cover-placeholder{background:linear-gradient(135deg,#0f3460,#16213e);justify-content:center;align-items:center;width:100%;height:100%;display:flex}.placeholder-icon{opacity:.4;font-size:3rem}.book-info{flex-direction:column;flex:1;gap:4px;padding:12px;display:flex}.book-title{color:#e0e0e0;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.9rem;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.book-author{color:#a0c4ff;white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;overflow:hidden}.book-meta{flex-wrap:wrap;gap:4px;margin-top:6px;display:flex}.meta-tag{color:#a0a0b0;background:#ffffff0d;border-radius:4px;padding:2px 6px;font-size:.72rem}.book-review-badge{margin-top:6px}.book-tooltip{pointer-events:none;background:#0d1b2e;border:1px solid #e94560;border-radius:10px;padding:12px 14px;animation:.15s tooltip-in;box-shadow:0 8px 24px #0009}.book-tooltip:after{content:"";border:6px solid #0000;border-top-color:#e94560;position:absolute;top:100%;left:50%;transform:translate(-50%)}@keyframes tooltip-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.tooltip-label{text-transform:uppercase;letter-spacing:.5px;color:#e94560;margin-bottom:6px;font-size:.7rem;font-weight:600}.tooltip-community-rating{align-items:center;gap:6px;display:flex}.tooltip-avg{color:#f5a623;font-size:.95rem;font-weight:700}.tooltip-count{color:#606080;margin-top:3px;font-size:.72rem}.tooltip-review-text{color:#b0b0c0;-webkit-line-clamp:3;-webkit-box-orient:vertical;margin-top:6px;font-size:.78rem;line-height:1.4;display:-webkit-box;overflow:hidden}.tooltip-loading,.tooltip-no-rating{color:#606080;font-size:.78rem;font-style:italic}.book-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:20px;display:grid}.book-card-skeleton{background:#16213e;border-radius:12px;height:320px;animation:1.5s infinite shimmer}@keyframes shimmer{0%{opacity:.5}50%{opacity:1}to{opacity:.5}}@media (width<=600px){.book-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.book-card-skeleton{height:240px}}.home-page{flex-direction:column;gap:48px;display:flex}.home-hero{text-align:center;background:linear-gradient(135deg,#0f3460 0%,#16213e 100%);border:1px solid #1a3a6e;border-radius:16px;padding:48px 40px}.hero-title{color:#e0e0e0;margin-bottom:12px;font-size:2rem;font-weight:700}.hero-subtitle{color:#a0a0b0;max-width:480px;margin:0 auto 28px;font-size:1.05rem;line-height:1.6}.hero-btn{color:#fff;cursor:pointer;background:#e94560;border:none;border-radius:10px;padding:12px 32px;font-size:1rem;font-weight:600;transition:background .2s,transform .15s}.hero-btn:hover{background:#c73652;transform:translateY(-1px)}.book-section{flex-direction:column;gap:16px;display:flex}.section-title{color:#e0e0e0;border-bottom:2px solid #e94560;padding-bottom:8px;font-size:1.25rem;font-weight:700;display:inline-block}.section-header{justify-content:space-between;align-items:baseline;display:flex}.section-link{color:#e94560;cursor:pointer;background:0 0;border:none;font-size:.875rem;font-weight:600;transition:opacity .2s}.section-link:hover{opacity:.75}.library-home-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px;display:grid}.library-home-card{cursor:pointer;background:#16213e;border:1px solid #0f3460;border-radius:10px;transition:transform .2s,border-color .2s,box-shadow .2s;overflow:hidden}.library-home-card:hover{border-color:#e94560;transform:translateY(-3px);box-shadow:0 6px 20px #0006}.library-home-cover-wrapper{aspect-ratio:2/3;background:#0f3460;width:100%;overflow:hidden}.library-home-cover{object-fit:cover;width:100%;height:100%;transition:transform .3s;display:block}.library-home-card:hover .library-home-cover{transform:scale(1.04)}.library-home-cover-placeholder{opacity:.3;justify-content:center;align-items:center;width:100%;height:100%;font-size:2rem;display:flex}.library-home-info{flex-direction:column;gap:4px;padding:8px 10px 10px;display:flex}.library-home-title{color:#e0e0e0;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.8rem;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.library-home-no-review{color:#606080;font-size:.72rem;font-style:italic}@media (width<=600px){.home-page{gap:32px}.home-hero{border-radius:12px;padding:28px 20px}.hero-title{font-size:1.5rem}.hero-subtitle{font-size:.95rem}}.book-search{width:100%}.search-form{margin-bottom:24px}.search-input-wrapper{background:#16213e;border:1px solid #0f3460;border-radius:12px;align-items:center;gap:8px;padding:4px 4px 4px 16px;transition:border-color .2s;display:flex}.search-input-wrapper:focus-within{border-color:#e94560}.search-icon{flex-shrink:0;font-size:1.1rem}.search-input{color:#e0e0e0;background:0 0;border:none;outline:none;flex:1;padding:10px 0;font-size:1rem}.search-input::placeholder{color:#606080}.search-btn{color:#fff;cursor:pointer;background:#e94560;border:none;border-radius:8px;flex-shrink:0;padding:10px 24px;font-size:.95rem;font-weight:600;transition:background .2s,opacity .2s}.search-btn:hover:not(:disabled){background:#c73652}.search-btn:disabled{opacity:.6;cursor:not-allowed}.quick-searches{margin-bottom:32px}.quick-label{color:#a0a0b0;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;font-size:.85rem}.quick-tags{flex-wrap:wrap;gap:8px;display:flex}.quick-tag{color:#a0c4ff;cursor:pointer;background:#16213e;border:1px solid #0f3460;border-radius:20px;padding:6px 16px;font-size:.875rem;transition:all .2s}.quick-tag:hover{color:#e0e0e0;background:#0f3460;border-color:#e94560}.results-count{color:#a0a0b0;margin-bottom:20px;font-size:.875rem}.error-msg{color:#e94560;background:#e945601a;border:1px solid #e945604d;border-radius:8px;margin-bottom:20px;padding:12px 16px}@media (width<=600px){.search-input{font-size:16px}.search-btn{padding:10px 16px;font-size:.875rem}}.detail-page{flex-direction:column;gap:24px;display:flex}.back-btn{color:#a0a0b0;cursor:pointer;background:0 0;border:1px solid #0f3460;border-radius:8px;align-self:flex-start;padding:8px 16px;font-size:.875rem;transition:all .2s}.back-btn:hover{color:#e0e0e0;border-color:#e94560}.detail-content{align-items:flex-start;gap:40px;display:flex}.detail-cover-col{flex-shrink:0;width:220px}.detail-cover{border-radius:10px;width:100%;display:block;box-shadow:0 8px 32px #00000080}.detail-cover-placeholder{aspect-ratio:2/3;opacity:.5;background:linear-gradient(135deg,#0f3460,#16213e);border-radius:10px;justify-content:center;align-items:center;width:100%;font-size:4rem;display:flex}.detail-info-col{flex-direction:column;flex:1;gap:20px;min-width:0;display:flex}.detail-title{color:#e0e0e0;font-size:2rem;font-weight:700;line-height:1.2}.detail-authors{color:#a0c4ff;font-size:1.1rem}.detail-meta{flex-wrap:wrap;gap:24px;display:flex}.detail-meta-item{flex-direction:column;gap:2px;display:flex}.meta-label{color:#606080;text-transform:uppercase;letter-spacing:.5px;font-size:.75rem}.meta-value{color:#e0e0e0;font-size:1rem;font-weight:600}.section-heading{color:#e94560;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:.85rem;font-weight:600}.detail-description p{color:#b0b0c0;font-size:.95rem;line-height:1.7}.description-fallback{font-style:italic;color:#606080!important}.description-toggle{color:#e94560;cursor:pointer;background:0 0;border:none;padding:6px 0 0;font-size:.875rem;font-weight:600;transition:opacity .2s}.description-toggle:hover{opacity:.8}.subject-tags{flex-wrap:wrap;gap:8px;display:flex}.subject-tag{color:#a0a0b0;background:#ffffff0d;border:1px solid #0f3460;border-radius:20px;padding:4px 12px;font-size:.8rem}.detail-error{color:#e94560;background:#e945601a;border:1px solid #e945604d;border-radius:8px;padding:16px}.detail-skeleton{align-items:flex-start;gap:40px;display:flex}.skeleton-cover{aspect-ratio:2/3;background:#16213e;border-radius:10px;flex-shrink:0;width:220px;animation:1.5s infinite shimmer}.skeleton-info{flex-direction:column;flex:1;gap:14px;padding-top:8px;display:flex}.skeleton-line{background:#16213e;border-radius:6px;height:16px;animation:1.5s infinite shimmer}.skeleton-line.wide{width:80%}.skeleton-line.medium{width:55%}.skeleton-line.short{width:30%}@media (width<=640px){.detail-content{flex-direction:column}.detail-cover-col{align-self:center;width:160px}.detail-title{font-size:1.5rem}}.library-btn{color:#fff;cursor:pointer;background:#e94560;border:none;border-radius:10px;align-self:flex-start;padding:10px 24px;font-size:.95rem;font-weight:600;transition:background .2s,transform .15s}.library-btn:hover{background:#c73652;transform:translateY(-1px)}.library-btn.in-library{color:#4caf82;background:0 0;border:1px solid #4caf82}.library-btn.in-library:hover{background:#4caf821a;transform:translateY(-1px)}.review-block{border-top:1px solid #1a2a4a;flex-direction:column;gap:12px;padding-top:8px;display:flex}.review-form{flex-direction:column;gap:10px;display:flex}.review-textarea{color:#e0e0e0;resize:vertical;background:#0f1e38;border:1px solid #0f3460;border-radius:8px;padding:10px 12px;font-family:inherit;font-size:.9rem;transition:border-color .2s}.review-textarea:focus{border-color:#e94560;outline:none}.review-textarea::placeholder{color:#606080}.review-form-actions{gap:8px;display:flex}.review-save-btn{color:#fff;cursor:pointer;background:#e94560;border:none;border-radius:8px;padding:8px 20px;font-size:.875rem;font-weight:600;transition:background .2s}.review-save-btn:hover:not(:disabled){background:#c73652}.review-save-btn:disabled{opacity:.4;cursor:not-allowed}.review-cancel-btn{color:#a0a0b0;cursor:pointer;background:0 0;border:1px solid #3a3a5a;border-radius:8px;padding:8px 16px;font-size:.875rem;transition:all .2s}.review-cancel-btn:hover{color:#e0e0e0;border-color:#a0a0b0}.review-hint{color:#606080;font-size:.78rem}.review-display{flex-direction:column;gap:8px;display:flex}.review-text{color:#b0b0c0;background:#0f1e38;border-left:3px solid #e94560;border-radius:8px;padding:10px 12px;font-size:.9rem;line-height:1.6}.review-display-actions{gap:8px;display:flex}.review-edit-btn{color:#a0a0b0;cursor:pointer;background:0 0;border:1px solid #3a3a5a;border-radius:8px;padding:6px 14px;font-size:.8rem;transition:all .2s}.review-edit-btn:hover{color:#e0e0e0;border-color:#e94560}.review-delete-btn{color:#606080;cursor:pointer;background:0 0;border:1px solid #3a3a5a;border-radius:8px;padding:6px 14px;font-size:.8rem;transition:all .2s}.review-delete-btn:hover{color:#e94560;border-color:#e94560}.detail-actions{flex-wrap:wrap;gap:10px;display:flex}.room-btn{color:#a0c4ff;cursor:pointer;background:0 0;border:1px solid #4a6fa5;border-radius:10px;padding:10px 24px;font-size:.95rem;font-weight:600;transition:all .2s}.room-btn:hover{color:#e0e0e0;background:#a0c4ff1a;border-color:#a0c4ff;transform:translateY(-1px)}.status-section{flex-direction:column;gap:10px;display:flex}.status-buttons{flex-wrap:wrap;gap:8px;display:flex}.status-btn{color:#a0a0b0;cursor:pointer;background:0 0;border:1px solid #3a3a5a;border-radius:20px;padding:7px 18px;font-size:.875rem;font-weight:500;transition:all .2s}.status-btn:hover{color:#e0e0e0;border-color:#a0a0b0}.status-btn--active{font-weight:700}.rooms-section{flex-direction:column;gap:10px;display:flex}.room-cards{flex-wrap:wrap;gap:10px;display:flex}.room-card{color:#606080;cursor:not-allowed;opacity:.6;background:#16213e;border:1px solid #3a3a5a;border-radius:10px;align-items:center;gap:8px;padding:10px 16px;font-size:.875rem;font-weight:500;transition:all .2s;display:flex}.room-card--active{color:#e0e0e0;cursor:pointer;opacity:1}.room-card--active:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}.room-card-emoji{font-size:1rem}.room-card-label{font-weight:600}.room-card-join{color:#e94560;margin-left:4px;font-size:.8rem}.room-card-locked{opacity:.5;margin-left:4px;font-size:.75rem}.rooms-hint{color:#606080;font-size:.8rem;font-style:italic}.room-card--visitable{color:#a0a0b0;cursor:pointer;opacity:.85}.room-card--visitable:hover{opacity:1;transform:translateY(-1px);border-color:#a0a0b0!important}.room-card-visit{color:#a0a0b0;margin-left:4px;font-size:.8rem}.private-room-list{flex-direction:column;gap:8px;margin-bottom:10px;display:flex}.private-room-row{cursor:pointer;text-align:left;color:#e0e0e0;background:#16213e;border:1px solid #0f3460;border-radius:10px;align-items:center;gap:10px;width:100%;padding:10px 14px;transition:border-color .2s,transform .15s;display:flex}.private-room-row:hover{border-color:#e94560;transform:translate(3px)}.private-room-icon{font-size:1rem}.private-room-name{flex:1;font-size:.9rem;font-weight:600}.private-room-members{color:#606080;font-size:.75rem}.private-room-actions{flex-wrap:wrap;gap:8px;display:flex}.private-room-btn{color:#fff;cursor:pointer;background:#e94560;border:none;border-radius:10px;padding:9px 20px;font-size:.875rem;font-weight:600;transition:background .2s}.private-room-btn:hover{background:#c73652}.private-room-btn--secondary{color:#a0c4ff;background:0 0;border:1px solid #4a6fa5}.private-room-btn--secondary:hover{color:#e0e0e0;background:#a0c4ff1a;border-color:#a0c4ff}.room-action-error{color:#e94560;background:#e945601a;border-radius:6px;padding:6px 10px;font-size:.82rem}.private-room-row--locked{opacity:.5;cursor:default;pointer-events:none}.private-room-locked-label{color:#606080;margin-left:auto;font-size:.72rem;font-style:italic}@media (width<=600px){.detail-content{flex-direction:column;gap:20px}.detail-cover-col{align-self:center;width:140px}.detail-title{font-size:1.4rem}.detail-skeleton{flex-direction:column;gap:20px}.skeleton-cover{align-self:center;width:140px}.room-cards{flex-direction:column}.room-card{width:100%}.private-room-actions{flex-direction:column}.private-room-btn{text-align:center;width:100%}.detail-actions{flex-direction:column}.library-btn,.room-btn{text-align:center;width:100%}}.library-page{flex-direction:column;gap:24px;display:flex}.library-header{align-items:baseline;gap:16px;display:flex}.library-title{color:#e0e0e0;font-size:1.75rem;font-weight:700}.library-count{color:#606080;font-size:.9rem}.library-empty{text-align:center;color:#a0a0b0;flex-direction:column;align-items:center;gap:12px;padding:80px 24px;display:flex}.empty-icon{opacity:.4;font-size:4rem}.library-empty p{font-size:1rem;line-height:1.6}.library-list{flex-direction:column;gap:12px;display:flex}.lib-card{background:#16213e;border:1px solid #0f3460;border-radius:12px;gap:16px;transition:border-color .2s;display:flex;overflow:hidden}.lib-card:hover{border-color:#e94560}.lib-card-cover-wrapper{cursor:pointer;background:#0f3460;flex-shrink:0;width:72px;overflow:hidden}.lib-card-cover{object-fit:cover;width:100%;height:100%;transition:transform .2s;display:block}.lib-card-cover-wrapper:hover .lib-card-cover{transform:scale(1.05)}.lib-card-cover-placeholder{opacity:.4;justify-content:center;align-items:center;width:100%;height:100%;min-height:100px;font-size:1.5rem;display:flex}.lib-card-info{flex:1;justify-content:space-between;align-items:center;gap:16px;min-width:0;padding:14px 16px 14px 0;display:flex}.lib-card-text{cursor:pointer;flex:1;min-width:0}.lib-card-title{color:#e0e0e0;white-space:nowrap;text-overflow:ellipsis;font-size:1rem;font-weight:600;overflow:hidden}.lib-card-author{color:#a0c4ff;white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:.85rem;overflow:hidden}.lib-card-meta{flex-wrap:wrap;gap:4px;margin-top:6px;display:flex}.lib-remove-btn{color:#606080;cursor:pointer;background:0 0;border:1px solid #3a3a5a;border-radius:8px;flex-shrink:0;padding:6px 14px;font-size:.8rem;transition:all .2s}.lib-remove-btn:hover{color:#e94560;border-color:#e94560}@media (width<=600px){.lib-card-info{flex-wrap:wrap;gap:8px}.lib-remove-btn{align-self:flex-start}}.message-author--clickable{cursor:pointer;transition:opacity .15s}.message-author--clickable:hover{opacity:.75;text-decoration:underline}.user-tooltip{pointer-events:none;background:#0d1b2e;border:1px solid #0f3460;border-radius:10px;flex-direction:column;gap:6px;padding:12px 14px;animation:.15s tooltip-in;display:flex;box-shadow:0 8px 24px #0009}.user-tooltip-name{color:#e0e0e0;font-size:.9rem;font-weight:700}.user-tooltip-status{font-size:.8rem;font-weight:600}.user-tooltip-stats{color:#a0a0b0;gap:12px;font-size:.78rem;display:flex}.user-tooltip-loading{color:#606080;font-size:.78rem;font-style:italic}.user-tooltip-hint{color:#606080;border-top:1px solid #1a2a4a;margin-top:2px;padding-top:6px;font-size:.7rem}.profile-modal-overlay{z-index:2000;background:#000000b3;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.profile-modal{background:#16213e;border:1px solid #0f3460;border-radius:16px;flex-direction:column;gap:20px;width:100%;max-width:480px;max-height:80vh;padding:24px;display:flex;position:relative;overflow-y:auto}.profile-modal-close{color:#606080;cursor:pointer;background:0 0;border:none;font-size:1rem;line-height:1;transition:color .2s;position:absolute;top:16px;right:16px}.profile-modal-close:hover{color:#e0e0e0}.profile-modal-header{align-items:center;gap:16px;display:flex}.profile-modal-avatar{color:#fff;background:linear-gradient(135deg,#e94560,#0f3460);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.3rem;font-weight:700;display:flex}.profile-modal-name{color:#e0e0e0;font-size:1.3rem;font-weight:700}.profile-modal-status{margin-top:2px;font-size:.85rem;font-weight:600}.profile-modal-loading,.profile-modal-empty{color:#606080;text-align:center;padding:16px 0;font-size:.875rem;font-style:italic}.profile-modal-stats{flex-wrap:wrap;gap:16px;display:flex}.profile-modal-stat{background:#0f1e38;border-radius:10px;flex-direction:column;align-items:center;gap:2px;min-width:64px;padding:10px 16px;display:flex}.pms-value{color:#e0e0e0;font-size:1.2rem;font-weight:700}.pms-label{color:#606080;text-transform:uppercase;letter-spacing:.4px;font-size:.68rem}.profile-modal-section{flex-direction:column;gap:10px;display:flex}.profile-modal-section-label{text-transform:uppercase;letter-spacing:.5px;color:#606080;font-size:.72rem;font-weight:600}.profile-modal-books{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:10px;display:grid}.profile-modal-book{flex-direction:column;align-items:center;gap:4px;display:flex}.pmb-cover-wrapper{aspect-ratio:2/3;background:#0f3460;border-radius:6px;width:100%;position:relative;overflow:hidden}.pmb-cover{object-fit:cover;width:100%;height:100%;display:block}.pmb-cover-placeholder{opacity:.4;justify-content:center;align-items:center;width:100%;height:100%;font-size:1.2rem;display:flex}.pmb-status-badge{background:#0009;border-radius:4px;padding:1px 3px;font-size:.75rem;position:absolute;bottom:3px;right:3px}.pmb-title{color:#a0a0b0;text-align:center;-webkit-line-clamp:2;-webkit-box-orient:vertical;width:100%;font-size:.7rem;line-height:1.3;display:-webkit-box;overflow:hidden}.room-page{flex-direction:column;gap:0;height:calc(100vh - 90px);display:flex}.room-header{border-bottom:1px solid #1a2a4a;flex-shrink:0;align-items:flex-start;gap:16px;padding-bottom:16px;display:flex}.room-header-info{flex:1;min-width:0}.room-title{color:#e0e0e0;white-space:nowrap;text-overflow:ellipsis;font-size:1.25rem;font-weight:700;overflow:hidden}.room-subtitle{color:#606080;align-items:center;gap:6px;margin-top:2px;font-size:.82rem;display:flex}.change-name-btn{color:#e94560;cursor:pointer;background:0 0;border:none;padding:0;font-size:.78rem;text-decoration:underline}.room-messages{scrollbar-width:thin;scrollbar-color:#1a2a4a transparent;flex-direction:column;flex:1;gap:12px;padding:20px 0;display:flex;overflow-y:auto}.room-empty{color:#606080;flex:1;justify-content:center;align-items:center;font-size:.9rem;font-style:italic;display:flex}.message{flex-direction:column;align-self:flex-start;gap:3px;max-width:70%;display:flex}.message--own{align-self:flex-end}.message-meta{align-items:baseline;gap:8px;padding:0 4px;display:flex}.message--own .message-meta{flex-direction:row-reverse}.message-author{color:#a0c4ff;font-size:.78rem;font-weight:600}.message--own .message-author{color:#e94560}.message-time{color:#606080;font-size:.7rem}.message-bubble{background:#16213e;border:1px solid #0f3460;border-radius:12px;padding:10px 14px}.message--own .message-bubble{background:#1a1a3e;border-color:#e94560;border-radius:12px 12px 4px}.message-bubble p{color:#e0e0e0;word-break:break-word;font-size:.9rem;line-height:1.5}.room-input-bar{border-top:1px solid #1a2a4a;flex-shrink:0;gap:8px;padding-top:16px;display:flex}.room-input{color:#e0e0e0;background:#16213e;border:1px solid #0f3460;border-radius:10px;flex:1;padding:10px 14px;font-family:inherit;font-size:.9rem;transition:border-color .2s}.room-input:focus{border-color:#e94560;outline:none}.room-input::placeholder{color:#606080}.room-send-btn{color:#fff;cursor:pointer;background:#e94560;border:none;border-radius:10px;flex-shrink:0;padding:10px 24px;font-size:.9rem;font-weight:600;transition:background .2s}.room-send-btn:hover:not(:disabled){background:#c73652}.room-send-btn:disabled{opacity:.4;cursor:not-allowed}.username-overlay{z-index:1000;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.username-modal{background:#16213e;border:1px solid #0f3460;border-radius:16px;flex-direction:column;gap:12px;width:100%;max-width:400px;padding:32px;display:flex}.username-modal h2{color:#e0e0e0;font-size:1.3rem;font-weight:700}.username-modal p{color:#a0a0b0;font-size:.9rem}.username-input{color:#e0e0e0;background:#0f1e38;border:1px solid #0f3460;border-radius:8px;padding:10px 14px;font-family:inherit;font-size:1rem;transition:border-color .2s}.username-input:focus{border-color:#e94560;outline:none}.username-save-btn{color:#fff;cursor:pointer;background:#e94560;border:none;border-radius:10px;margin-top:4px;padding:12px;font-size:1rem;font-weight:600;transition:background .2s}.username-save-btn:hover:not(:disabled){background:#c73652}.username-save-btn:disabled{opacity:.4;cursor:not-allowed}.room-status-badge{font-weight:600}.room-blocked{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:40px;display:flex}.blocked-icon{font-size:3rem}.room-blocked h2{color:#e0e0e0;font-size:1.3rem;font-weight:700}.room-blocked p{color:#a0a0b0;max-width:360px;font-size:.9rem}.spoiler-modal{text-align:center;align-items:center;gap:14px}.spoiler-icon{font-size:2.5rem}.spoiler-modal h2{color:#f5a623}.spoiler-modal p{max-width:320px}.room-visiting-badge{color:#f5a623;font-size:.75rem;font-weight:600}@media (width<=600px){.room-page{height:calc(100vh - 129px)}.room-header{flex-wrap:wrap;gap:8px}.room-title{font-size:1rem}.message{max-width:85%}.username-modal{margin:16px;padding:24px 20px}}.message-author--self{color:#e94560;font-size:.78rem;font-weight:600}.message-delete-btn{cursor:pointer;opacity:0;color:#606080;background:0 0;border:none;padding:0 2px;font-size:.75rem;line-height:1;transition:opacity .15s}.message:hover .message-delete-btn{opacity:1}.message-delete-btn:hover{color:#e94560}.invite-code-btn{color:#a0c4ff;cursor:pointer;background:0 0;border:1px solid #4a6fa5;border-radius:8px;flex-shrink:0;padding:6px 14px;font-size:.82rem;font-weight:600;transition:all .2s}.invite-code-btn:hover{background:#a0c4ff1a;border-color:#a0c4ff}.invite-banner{color:#a0a0b0;background:#0f1e38;border:1px solid #0f3460;border-radius:10px;flex-shrink:0;align-items:center;gap:12px;padding:12px 16px;font-size:.875rem;display:flex}.invite-code{color:#e94560;letter-spacing:3px;background:#e945601a;border-radius:6px;padding:4px 10px;font-family:monospace;font-size:1.2rem;font-weight:700}.copy-btn{color:#fff;cursor:pointer;background:#e94560;border:none;border-radius:6px;margin-left:auto;padding:4px 12px;font-size:.78rem;font-weight:600;transition:background .2s}.copy-btn:hover{background:#c73652}.room-header-actions{flex-shrink:0;gap:8px;display:flex}.manage-room-btn{color:#a0a0b0;cursor:pointer;background:0 0;border:1px solid #3a3a5a;border-radius:8px;padding:6px 14px;font-size:.82rem;font-weight:600;transition:all .2s}.manage-room-btn:hover{color:#e0e0e0;border-color:#e0e0e0}.manage-panel{background:#0f1e38;border:1px solid #1a2a4a;border-radius:10px;flex-direction:column;flex-shrink:0;gap:16px;padding:16px;display:flex}.manage-section{flex-direction:column;gap:8px;display:flex}.manage-label{text-transform:uppercase;letter-spacing:.5px;color:#606080;font-size:.72rem;font-weight:600}.manage-members{flex-direction:column;gap:6px;display:flex}.manage-member-row{background:#16213e;border-radius:8px;justify-content:space-between;align-items:center;padding:6px 10px;display:flex}.manage-member-name{color:#e0e0e0;font-size:.875rem}.manage-you-badge{color:#606080;font-size:.75rem}.manage-creator-badge{font-size:.75rem}.kick-btn{color:#606080;cursor:pointer;background:0 0;border:1px solid #3a3a5a;border-radius:6px;padding:3px 10px;font-size:.75rem;transition:all .2s}.kick-btn:hover{color:#e94560;border-color:#e94560}.manage-danger{border-top:1px solid #1a2a4a;padding-top:12px}.delete-room-btn{color:#e94560;cursor:pointer;background:0 0;border:1px solid #e94560;border-radius:8px;align-self:flex-start;padding:7px 16px;font-size:.875rem;font-weight:600;transition:all .2s}.delete-room-btn:hover{background:#e945601a}.delete-confirm p{color:#a0a0b0;margin-bottom:10px;font-size:.85rem}.delete-confirm-actions{gap:8px;display:flex}@media (width<=600px){.room-header-actions{flex-wrap:wrap}.invite-banner{flex-wrap:wrap;gap:8px}.invite-code{letter-spacing:2px;font-size:1rem}}.profile-page{flex-direction:column;gap:36px;display:flex}.profile-header{align-items:center;gap:24px;display:flex}.profile-avatar{color:#fff;letter-spacing:1px;background:linear-gradient(135deg,#e94560,#0f3460);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;font-size:1.6rem;font-weight:700;display:flex}.profile-identity{flex-direction:column;gap:4px;display:flex}.name-display-row{align-items:center;gap:10px;display:flex}.profile-name{color:#e0e0e0;font-size:1.75rem;font-weight:700}.name-edit-btn{color:#a0a0b0;cursor:pointer;background:0 0;border:1px solid #3a3a5a;border-radius:6px;padding:4px 10px;font-size:.78rem;transition:all .2s}.name-edit-btn:hover{color:#e0e0e0;border-color:#e94560}.name-edit-row{align-items:center;gap:8px;display:flex}.name-input{color:#e0e0e0;background:#0f1e38;border:1px solid #e94560;border-radius:8px;outline:none;width:220px;padding:6px 12px;font-family:inherit;font-size:1.2rem;font-weight:700}.name-save-btn{color:#fff;cursor:pointer;background:#e94560;border:none;border-radius:8px;padding:6px 14px;font-size:.85rem;font-weight:600;transition:background .2s}.name-save-btn:hover{background:#c73652}.name-cancel-btn{color:#a0a0b0;cursor:pointer;background:0 0;border:1px solid #3a3a5a;border-radius:8px;padding:6px 12px;font-size:.85rem;transition:all .2s}.name-cancel-btn:hover{color:#e0e0e0;border-color:#a0a0b0}.profile-sub{color:#606080;font-size:.85rem}.stats-row{flex-wrap:wrap;gap:12px;display:flex}.stat-card{background:#16213e;border:1px solid #0f3460;border-radius:12px;flex-direction:column;align-items:center;gap:4px;min-width:90px;padding:16px 20px;display:flex}.stat-value{color:#e0e0e0;font-size:1.5rem;font-weight:700}.stat-label{color:#606080;text-transform:uppercase;letter-spacing:.5px;text-align:center;font-size:.72rem}.profile-section{flex-direction:column;gap:12px;display:flex}.profile-section-title{color:#e0e0e0;border-bottom:1px solid #1a2a4a;align-items:center;gap:8px;padding-bottom:8px;font-size:1.1rem;font-weight:700;display:flex}.section-count{color:#606080;background:#1a2a4a;border-radius:10px;padding:2px 8px;font-size:.78rem;font-weight:500}.profile-book-list{flex-direction:column;gap:8px;display:flex}.profile-book-row{cursor:pointer;background:#16213e;border:1px solid #0f3460;border-radius:10px;align-items:center;gap:14px;padding:10px 14px;transition:border-color .2s,transform .15s;display:flex}.profile-book-row:hover{border-color:#e94560;transform:translate(3px)}.profile-book-cover-wrapper{background:#0f3460;border-radius:4px;flex-shrink:0;width:44px;height:64px;overflow:hidden}.profile-book-cover{object-fit:cover;width:100%;height:100%;display:block}.profile-book-cover-placeholder{opacity:.4;justify-content:center;align-items:center;width:100%;height:100%;font-size:1.2rem;display:flex}.profile-book-info{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.profile-book-title{color:#e0e0e0;white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:600;overflow:hidden}.profile-book-author{color:#a0c4ff;font-size:.8rem}.profile-no-review{color:#606080;font-size:.75rem;font-style:italic}.profile-review-text{color:#b0b0c0;white-space:nowrap;text-overflow:ellipsis;flex:2;min-width:0;font-size:.8rem;font-style:italic;overflow:hidden}.profile-empty{text-align:center;color:#a0a0b0;flex-direction:column;align-items:center;gap:12px;padding:60px 24px;font-size:1rem;display:flex}.profile-empty span{opacity:.4;font-size:3rem}.browse-btn{color:#fff;cursor:pointer;background:#e94560;border:none;border-radius:10px;margin-top:4px;padding:10px 28px;font-size:.95rem;font-weight:600;transition:background .2s}.browse-btn:hover{background:#c73652}@media (width<=600px){.profile-name{font-size:1.3rem}.name-input{width:160px;font-size:1rem}.stats-row{gap:8px}.stat-card{min-width:72px;padding:12px 14px}.stat-value{font-size:1.2rem}.profile-review-text{display:none}}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{z-index:100;background:linear-gradient(135deg,#16213e 0%,#0f3460 100%);border-bottom:1px solid #0f3460;padding:16px 20px;position:sticky;top:0;box-shadow:0 2px 12px #0006}.header-content{justify-content:space-between;align-items:center;gap:16px;max-width:1200px;margin:0 auto;display:flex}.app-nav{gap:4px;display:flex}.nav-link{color:#a0a0b0;white-space:nowrap;border-radius:8px;padding:8px 12px;font-size:.9rem;font-weight:500;text-decoration:none;transition:color .2s,background .2s}.nav-link:hover{color:#e0e0e0;background:#ffffff0f}.nav-link.active{color:#e94560;background:#e945601a}.logo{color:#e94560;letter-spacing:-.5px;font-size:1.6rem;font-weight:700}.tagline{color:#a0a0b0;margin-top:4px;font-size:.9rem}.app-main{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:24px 16px 80px}.nav-link--avatar{padding:4px}.nav-avatar{color:#fff;letter-spacing:.5px;background:linear-gradient(135deg,#e94560,#0f3460);border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.75rem;font-weight:700;transition:transform .2s,box-shadow .2s;display:flex}.nav-link--avatar:hover .nav-avatar{transform:scale(1.08);box-shadow:0 0 0 2px #e94560}.nav-link--avatar.active .nav-avatar{box-shadow:0 0 0 2px #e94560}.logo-link{flex-shrink:0;text-decoration:none}.logo-link:hover .logo{opacity:.85}.bottom-nav{display:none}@media (width<=600px){.app-header .app-nav{display:none}.app-main{padding:16px 12px 80px}.bottom-nav{z-index:200;background:#16213e;border-top:1px solid #0f3460;padding:0;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 16px #0006}.bottom-nav-link{color:#606080;-webkit-tap-highlight-color:transparent;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:10px 4px 12px;font-size:.65rem;font-weight:500;text-decoration:none;transition:color .2s;display:flex}.bottom-nav-link.active{color:#e94560}.bottom-nav-icon{font-size:1.3rem;line-height:1}.bottom-nav-avatar{color:#fff;background:linear-gradient(135deg,#e94560,#0f3460);border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:.65rem;font-weight:700;display:flex}.bottom-nav-link.active .bottom-nav-avatar{box-shadow:0 0 0 2px #e94560}}@media (width>=601px){.app-main{padding-bottom:32px}}
