*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #121212;--bg-surface: #1e1e1e;--bg-elevated: #2a2a2a;--text: #f0f0f0;--text-muted: #8a8a8a;--accent: #c9a84c;--accent-hover: #dfc06a;--success: #4ecca3;--border: #333333;--radius: 8px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased}h1{font-size:1.5rem;font-weight:600}h2{font-size:1.25rem;font-weight:600;margin-bottom:.75rem}h3{font-size:1rem;font-weight:500}input[type=text],input[type=file],textarea{width:100%;padding:12px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:1rem;margin-bottom:.75rem}textarea{resize:vertical}button{padding:10px 16px;border:none;border-radius:var(--radius);font-size:.9rem;cursor:pointer;background:var(--bg-elevated);color:var(--text);min-height:44px;min-width:44px;transition:background .15s}button:hover{background:var(--accent)}button:disabled{opacity:.5;cursor:not-allowed}button:disabled:hover{background:var(--bg-elevated)}.btn-primary{background:var(--accent);color:#000;font-weight:600}.btn-primary:hover{background:var(--accent-hover)}.loading,.error-page{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:1rem;padding:2rem;text-align:center}.error{color:var(--accent);margin-bottom:.5rem}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:1rem;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fade-in .15s ease-out}.modal-content{display:flex;flex-direction:column;background:var(--bg-surface);border:1px solid var(--border);border-radius:16px;box-shadow:0 24px 48px #0006;max-height:min(calc(100dvh - 2rem),90vh);overflow-y:auto;animation:modal-enter .2s ease-out}.modal-sm{width:100%;max-width:380px}.modal-md{width:100%;max-width:480px}.modal-lg{width:100%;max-width:640px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.modal-header h2{margin:0;font-size:1.15rem}.modal-header-text{flex:1;min-width:0}.modal-close{width:36px;height:36px;min-width:36px;min-height:36px;padding:0;display:flex;align-items:center;justify-content:center;font-size:1.4rem;line-height:1;border-radius:8px;color:var(--text-muted);background:transparent;margin-left:.75rem}.modal-close:hover{background:var(--bg-elevated);color:var(--text)}.modal-body{padding:1.5rem}.modal-footer{display:flex;gap:1rem;justify-content:flex-end;padding:1rem 1.5rem;border-top:1px solid var(--border)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-enter{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.home{min-height:100%;padding:var(--safe-top) 1rem var(--safe-bottom)}.home-header{padding:1rem 0;text-align:center}.club-tabs{display:flex;gap:.5rem;overflow-x:auto;padding:.5rem 0;-webkit-overflow-scrolling:touch}.club-tab{flex-shrink:0;padding:8px 16px;border-radius:20px;font-size:.85rem;background:var(--bg-surface)}.club-tab.active{background:var(--accent)}.club-tab.add{border:1px dashed var(--border);background:transparent}.member-count{margin-left:6px;font-size:.75rem;opacity:.7}.create-club-form{display:flex;gap:.5rem;padding:.75rem 0}.create-club-form input{flex:1;margin-bottom:0}.book-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem;padding:1rem 0}.book-card{display:flex;flex-direction:column;background:var(--bg-surface);border-radius:var(--radius);overflow:hidden;text-align:left;padding:0}.book-cover{width:100%;aspect-ratio:2/3;object-fit:cover}.book-cover-placeholder{width:100%;aspect-ratio:2/3;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);color:var(--text-muted);font-size:.85rem}.book-info{padding:.5rem}.book-info h3{font-size:.85rem;margin-bottom:2px}.book-info p{font-size:.75rem;color:var(--text-muted)}.empty-state{text-align:center;color:var(--text-muted);padding:3rem 1rem}.fab{position:fixed;bottom:calc(1.5rem + var(--safe-bottom));right:1.5rem;background:var(--accent);color:#fff;border-radius:28px;padding:14px 20px;font-weight:600;box-shadow:0 4px 12px #e945604d;z-index:10}.fab:hover{background:var(--accent-hover)}.club-link{display:block;text-align:center;margin:1rem 0;background:transparent;color:var(--accent);text-decoration:underline}.drop-zone{border:2px dashed var(--border);border-radius:12px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:border-color .2s,background .2s}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--accent);background:#c9a84c0d}.drop-zone-icon{font-size:2.5rem;line-height:1;color:var(--text-muted);margin-bottom:.75rem}.drop-zone-text{color:var(--text);font-size:1rem;margin-bottom:.25rem}.drop-zone-hint{color:var(--text-muted);font-size:.85rem}.upload-review{display:flex;gap:1.25rem;margin-bottom:1rem}.upload-cover-preview{width:100px;flex-shrink:0}.upload-cover-preview img{width:100%;border-radius:var(--radius);box-shadow:0 2px 8px #0000004d}.upload-fields{flex:1;display:flex;flex-direction:column;gap:.5rem}.format-badge{display:inline-block;align-self:flex-start;padding:3px 10px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-radius:4px;background:var(--bg-elevated);color:var(--accent)}.cover-upload-label{font-size:.85rem;color:var(--text-muted)}.text-muted{color:var(--text-muted)}.track-list{margin-top:1rem}.track-list-header{font-size:.85rem;color:var(--text-muted);margin-bottom:.5rem}.track-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:var(--bg-elevated);border-radius:var(--radius);margin-bottom:.25rem}.track-item span{flex:1;font-size:.85rem}.track-item button{min-width:auto;padding:6px 10px;font-size:.75rem}.actions{display:flex;gap:1rem;justify-content:flex-end}.progress-bar{height:6px;background:var(--bg-elevated);border-radius:3px;overflow:hidden;margin:1rem 0}.progress-fill{height:100%;background:var(--accent);transition:width .3s}.club-dashboard{min-height:100%;padding:var(--safe-top) 1rem var(--safe-bottom)}.dashboard-header{display:flex;align-items:center;gap:1rem;padding:1rem 0}.dashboard-header h1{flex:1}.back-btn{background:transparent;color:var(--text-muted)}.club-description{color:var(--text-muted);margin-bottom:1rem}.dashboard-section{margin-bottom:2rem}.member-list{display:flex;flex-wrap:wrap;gap:.5rem}.member-chip{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-surface);border-radius:20px;font-size:.85rem}.role-badge{font-size:.7rem;opacity:.6;text-transform:uppercase}.online-dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted);flex-shrink:0}.online-dot.online{background:var(--success)}.invite-flow{padding:1rem;background:var(--bg-surface);border-radius:var(--radius);margin-bottom:1rem}.invite-label{font-size:.85rem;color:var(--text-muted);margin-bottom:.5rem}.invite-row{display:flex;gap:.5rem}.invite-input{flex:1;margin-bottom:0;font-size:.8rem}.copy-btn{background:var(--accent);color:#fff}.invite-code{font-size:.85rem;color:var(--text-muted);margin-top:.5rem}.member-progress{display:flex;flex-direction:column;gap:.75rem}.member-row{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:var(--bg-surface);border-radius:var(--radius)}.member-name{display:flex;align-items:center;gap:6px;min-width:100px;font-size:.85rem}.progress-bar-container{flex:1;display:flex;align-items:center;gap:.5rem}.progress-bar-bg{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--success);transition:width .3s}.progress-label{font-size:.75rem;color:var(--text-muted);min-width:50px}.last-updated{font-size:.7rem;color:var(--text-muted)}.reader-page{height:100%;display:flex;flex-direction:column}.reader-header{display:flex;align-items:center;gap:.75rem;padding:calc(.5rem + var(--safe-top)) 1rem .5rem;background:var(--bg-surface);z-index:20}.reader-header h1{flex:1;font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.online-count{font-size:.75rem;color:var(--success);white-space:nowrap}.reader-content{flex:1;position:relative;overflow:hidden}.epub-reader,.pdf-reader{height:100%;display:flex;flex-direction:column}.reader-toolbar{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:var(--bg-surface)}.reader-toolbar button{min-width:36px;min-height:36px;padding:6px;font-size:.85rem}.reader-toolbar span{font-size:.85rem;color:var(--text-muted)}.toolbar-spacer{flex:1}.page-indicator{margin-left:auto}.bg-picker{display:flex;gap:4px;align-items:center}.bg-dot{width:24px;height:24px;min-width:24px;min-height:24px;border-radius:50%;padding:0;cursor:pointer}.bg-dot.active{box-shadow:0 0 0 2px var(--accent)}.chapters-toggle{white-space:nowrap}.chapter-nav{position:absolute;top:0;left:0;right:0;bottom:0;z-index:25;display:flex;flex-direction:column;overflow:hidden}.chapter-nav-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--border)}.chapter-nav-header h3{margin:0;color:inherit}.chapter-nav-header .close-btn{color:inherit}.chapter-list{flex:1;overflow-y:auto;padding:.5rem}.chapter-item{display:block;width:100%;text-align:left;padding:10px 12px;background:transparent;color:inherit;border-radius:var(--radius);font-size:.9rem;margin-bottom:2px}.chapter-item:hover{background:var(--bg-elevated)}.reader-container{flex:1;overflow:auto;display:flex;justify-content:center}.reader-container canvas{max-width:100%;height:auto}.reader-nav{display:flex;gap:.5rem;padding:.5rem;padding-bottom:calc(.5rem + var(--safe-bottom));justify-content:space-between;background:var(--bg-surface)}.reader-nav button{flex:1}.audio-player{height:100%;display:flex;flex-direction:column;align-items:center;padding:2rem 1rem;padding-bottom:calc(2rem + var(--safe-bottom));overflow-y:auto}.player-cover{width:60%;max-width:280px;aspect-ratio:1;margin-bottom:1.5rem}.player-cover img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius)}.cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border-radius:var(--radius);color:var(--text-muted);text-align:center;padding:1rem}.player-info{text-align:center;margin-bottom:1.5rem}.player-info h2{margin-bottom:.25rem}.player-info p{color:var(--text-muted);font-size:.9rem}.track-name{font-size:.85rem!important;margin-top:.5rem}.track-counter{font-size:.8rem!important}.player-scrubber{width:100%;display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem}.player-scrubber span{font-size:.75rem;color:var(--text-muted);min-width:40px}.player-scrubber span:last-child{text-align:right}.player-scrubber input[type=range]{flex:1;-webkit-appearance:none;height:4px;background:var(--border);border-radius:2px;outline:none;margin:0;padding:0;border:none}.player-scrubber input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent)}.player-controls{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem}.play-btn{width:56px;height:56px;border-radius:50%;background:var(--accent);color:#fff;font-weight:600}.speed-btn{font-size:.75rem;padding:6px 10px;border-radius:12px}.track-list-toggle{background:transparent;color:var(--accent);font-size:.85rem;margin-bottom:1rem}.track-list{width:100%;max-height:40vh;overflow-y:auto}.track-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:12px;text-align:left;background:var(--bg-surface);border-radius:var(--radius);margin-bottom:4px}.track-item.active{background:var(--bg-elevated);border-left:3px solid var(--accent)}.track-number{font-size:.85rem;color:var(--text-muted);min-width:24px}.track-filename{flex:1;font-size:.85rem}.track-duration{font-size:.75rem;color:var(--text-muted)}.comment-markers-bar{display:flex;gap:.25rem;padding:.5rem;overflow-x:auto;background:var(--bg-surface)}.comment-marker{position:relative;min-width:36px;min-height:36px;padding:4px 8px;border-radius:50%;background:var(--bg-elevated);font-size:.75rem}.comment-marker.active{background:var(--accent)}.marker-icon{font-size:1rem}.marker-count{position:absolute;top:-4px;right:-4px;background:var(--accent);color:#fff;font-size:.65rem;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center}.comment-popover{position:fixed;bottom:0;left:0;right:0;max-height:50vh;background:var(--bg-surface);border-top:1px solid var(--border);border-radius:var(--radius) var(--radius) 0 0;z-index:30;overflow-y:auto;padding-bottom:var(--safe-bottom)}.popover-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg-surface)}.close-btn{background:transparent;color:var(--text-muted);min-width:auto;padding:6px}.popover-body{padding:.5rem 1rem}.comment-item{padding:.75rem 0;border-bottom:1px solid var(--border)}.comment-item:last-child{border-bottom:none}.comment-meta{display:flex;gap:.5rem;align-items:baseline;margin-bottom:.25rem}.comment-meta strong{font-size:.85rem}.comment-time{font-size:.7rem;color:var(--text-muted)}.comment-text{font-size:.9rem;line-height:1.4}.delete-btn{font-size:.75rem;color:var(--accent);background:transparent;padding:4px 8px;min-height:auto;margin-top:.25rem}.add-comment-fab{position:fixed;bottom:calc(4rem + var(--safe-bottom));right:1.5rem;z-index:10}.add-comment-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:flex-end;z-index:40}.add-comment-form{width:100%;padding:1.5rem;padding-bottom:calc(1.5rem + var(--safe-bottom));background:var(--bg-surface);border-radius:var(--radius) var(--radius) 0 0}.add-comment-form h3{margin-bottom:.5rem}.anchor-hint{font-size:.8rem;color:var(--text-muted);margin-bottom:.75rem}.cache-progress{position:relative;height:20px;flex:0 0 auto;display:flex;align-items:center;gap:.5rem;padding:0 .5rem}.cache-progress-bar{position:absolute;left:0;top:0;bottom:0;background:var(--success);opacity:.15;border-radius:4px;transition:width .3s}.cache-progress-label{position:relative;font-size:.7rem;color:var(--success);white-space:nowrap}.cache-indicator{position:relative;display:flex;align-items:center;gap:4px;padding:4px 8px}.cache-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.cache-dot-complete{background:var(--success)}.cache-dot-partial{background:var(--accent)}.cache-partial-label{font-size:.7rem;color:var(--text-muted)}.cache-details-popover{position:absolute;bottom:100%;right:0;background:var(--bg-elevated);padding:.75rem;border-radius:var(--radius);font-size:.8rem;white-space:nowrap;z-index:20;box-shadow:0 4px 12px #0000004d}.cache-details-popover p{margin-bottom:.5rem}.cache-delete-btn{background:var(--accent);color:#fff;font-size:.75rem;padding:6px 12px;min-height:auto;width:100%}.reaction-picker{display:flex;gap:.5rem;margin-bottom:.75rem}.reaction-btn{font-size:1.5rem;padding:6px;min-width:44px;min-height:44px;background:var(--bg-elevated);border-radius:var(--radius);transition:transform .15s,background .15s}.reaction-btn.selected{background:var(--accent);transform:scale(1.15)}.reaction-btn:hover{transform:scale(1.1)}.comment-marker.has-reactions{border-radius:18px;padding:4px 10px;width:auto}.marker-reactions{display:flex;gap:2px;font-size:.85rem}.marker-reaction{white-space:nowrap}.comment-reaction{font-size:1.2rem}.club-progress-bar{position:relative;height:12px;background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:20}.progress-track{position:relative;height:100%;width:100%}.progress-marker{position:absolute;top:50%;width:10px;height:10px;border-radius:50%;transform:translate(-50%,-50%);cursor:pointer;transition:left .5s ease;opacity:.5}.progress-marker.online{opacity:1}.progress-marker.self{width:14px;height:14px;box-shadow:0 0 0 2px #fff;z-index:1}.progress-tooltip{position:absolute;top:100%;left:50%;transform:translate(-50%);background:var(--bg-elevated);padding:6px 10px;border-radius:var(--radius);font-size:.75rem;white-space:nowrap;display:flex;gap:.5rem;align-items:center;z-index:30;box-shadow:0 4px 12px #0000004d;margin-top:4px}.progress-tooltip strong{font-weight:600}.book-progress-bar{position:relative;height:6px;background:var(--border);margin:0 .5rem .5rem;border-radius:3px}.book-progress-dot{position:absolute;top:50%;width:8px;height:8px;border-radius:50%;transform:translate(-50%,-50%)}
