*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #1a1a2e;--bg-surface: #16213e;--bg-elevated: #0f3460;--text: #e0e0e0;--text-muted: #8a8a9a;--accent: #e94560;--accent-hover: #ff6b81;--success: #4ecca3;--border: #2a2a4a;--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)}.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}.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}.upload-flow{padding:1rem;max-width:500px;margin:0 auto}.upload-flow h2{text-align:center;margin-bottom:1rem}.type-select{display:flex;gap:.5rem;margin-bottom:1rem}.type-select button{flex:1}.type-select button.active{background:var(--accent)}.file-list{margin-bottom:1rem}.track-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:var(--bg-surface);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:.5rem;justify-content:flex-end}.progress-bar{height:6px;background:var(--bg-surface);border-radius:3px;overflow:hidden;margin:1rem 0}.progress-fill{height:100%;background:var(--success);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;justify-content: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)}.page-indicator{margin-left:auto}.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}
