:root{--bg: #120c0a;--surface: #1e1612;--surface-elevated: #2a201b;--border: #3a2c24;--text: #ede0d4;--text-secondary: #a89888;--accent: #d4873a;--accent-hover: #e8994f;--accent-dim: rgba(212, 135, 58, .15);--error: #c44a4a;--radius: 8px;--radius-lg: 16px}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:"Source Serif 4",serif;background:var(--bg);color:var(--text);min-height:100dvh;position:relative}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left: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.03'/%3E%3C/svg%3E");pointer-events:none;z-index:0}h1,h2,h3{font-family:Playfair Display,serif;font-weight:400;letter-spacing:-.02em}.screen{position:relative;z-index:1;min-height:100dvh;max-width:800px;margin:0 auto;padding:2rem 1.5rem}.api-key-screen{display:flex;align-items:center;justify-content:center}.key-container{text-align:center;max-width:400px;width:100%;animation:fadeUp .6s ease-out}.key-icon{color:var(--accent);margin-bottom:1.5rem}.key-title{font-size:2.5rem;color:var(--text);margin-bottom:.5rem}.key-subtitle{color:var(--text-secondary);font-size:1.05rem;margin-bottom:2.5rem}.key-form{display:flex;flex-direction:column;gap:1rem}.key-input-wrapper{position:relative}.key-input{width:100%;padding:1rem 1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:DM Sans,sans-serif;font-size:.95rem;outline:none;transition:border-color .2s}.key-input:focus{border-color:var(--accent)}.key-input::placeholder{color:var(--text-secondary);opacity:.6}.screen-error{padding:.75rem 1rem;background:#c44a4a1f;border:1px solid rgba(196,74,74,.35);border-radius:var(--radius);color:var(--error);font-family:DM Sans,sans-serif;font-size:.85rem;margin-bottom:1rem;animation:fadeUp .2s ease-out}.key-error{color:var(--error);font-size:.85rem;font-family:DM Sans,sans-serif}.key-btn{padding:.9rem 2rem;background:var(--accent);color:var(--bg);border:none;border-radius:var(--radius);font-family:DM Sans,sans-serif;font-weight:500;font-size:1rem;cursor:pointer;transition:background .2s}.key-btn:hover{background:var(--accent-hover)}.key-hint{margin-top:1.5rem;font-size:.85rem;color:var(--text-secondary);font-family:DM Sans,sans-serif}.key-hint a{color:var(--accent);text-decoration:none}.key-hint a:hover{text-decoration:underline}.library-screen{padding-top:1.5rem}.library-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}.library-title{font-size:1.75rem}.add-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;background:var(--accent-dim);color:var(--accent);border:1px solid var(--accent);border-radius:var(--radius);font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.add-btn:hover:not(:disabled){background:var(--accent);color:var(--bg)}.add-btn:disabled{opacity:.5;cursor:not-allowed}.books-grid{display:flex;flex-direction:column;gap:.75rem;animation:fadeUp .4s ease-out}.book-card-wrapper{position:relative}.book-card-wrapper:hover .book-remove{opacity:1}.book-remove{position:absolute;top:.4rem;right:.4rem;width:28px;height:28px;border-radius:50%;border:none;background:#0009;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s,color .2s,background .2s;z-index:2}.book-remove:hover{color:var(--error);background:#c44a4a33}.book-card{display:flex;align-items:center;gap:1rem;width:100%;padding:1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s;text-align:left;color:var(--text);font-family:inherit}.book-card:hover{background:var(--surface-elevated);border-color:var(--accent);transform:translateY(-1px)}.book-spine{width:48px;height:64px;background:linear-gradient(135deg,var(--accent-dim),var(--accent));border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.book-initial{font-family:Playfair Display,serif;font-size:1.4rem;font-weight:600;color:var(--accent)}.book-info{flex:1;min-width:0}.book-title{font-size:1.1rem;margin-bottom:.2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.book-meta{font-size:.8rem;color:var(--text-secondary);font-family:DM Sans,sans-serif;margin-bottom:.5rem}.book-progress-track{height:3px;background:var(--border);border-radius:2px;overflow:hidden}.book-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .4s ease}.empty-state{text-align:center;padding:4rem 1rem;color:var(--text-secondary)}.empty-icon{color:var(--border);margin-bottom:1.5rem}.empty-state h2{font-size:1.3rem;color:var(--text);margin-bottom:.5rem}.empty-state p{font-size:.95rem;font-family:DM Sans,sans-serif}.loading-state{display:flex;align-items:center;justify-content:center;padding:4rem}.loader{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.mini-loader{display:inline-block;width:12px;height:12px;border:1.5px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .6s linear infinite;margin-right:.3rem}.btn-loader{display:inline-block;width:14px;height:14px;border:2px solid var(--accent);border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite}.gen-header{margin-bottom:2rem}.back-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .75rem;background:none;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);font-family:DM Sans,sans-serif;font-size:.85rem;cursor:pointer;transition:all .2s}.back-btn:hover{color:var(--text);border-color:var(--text-secondary)}.gen-content{animation:fadeUp .5s ease-out}.gen-book-info{margin-bottom:1.5rem}.gen-title{font-size:1.6rem;margin-bottom:.3rem}.gen-meta{color:var(--text-secondary);font-family:DM Sans,sans-serif;font-size:.9rem}.gen-chapters{margin-top:2rem;display:flex;flex-direction:column;gap:.5rem}.gen-chapter{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:border-color .2s}.gen-chapter.done{border-color:#d4873a4d}.gen-chapter.generating{border-color:var(--accent)}.gen-chapter-left{display:flex;align-items:center;gap:.75rem}.gen-chapter-num{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--accent-dim);color:var(--accent);font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:500;flex-shrink:0}.gen-chapter-title{font-size:.95rem}.gen-badge{font-family:DM Sans,sans-serif;font-size:.75rem;padding:.3rem .6rem;border-radius:4px;display:inline-flex;align-items:center}.gen-badge.done,.gen-badge.generating{color:var(--accent);background:var(--accent-dim)}.gen-btn{padding:.4rem 1rem;background:var(--accent);color:var(--bg);border:none;border-radius:4px;font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:500;cursor:pointer;transition:background .2s}.gen-btn:hover:not(:disabled){background:var(--accent-hover)}.gen-btn:disabled{opacity:.4;cursor:not-allowed}.gen-player{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem 1.25rem;margin-top:1.5rem;animation:fadeUp .3s ease-out}.gen-player-info{margin-bottom:1rem;text-align:center}.gen-player-label{font-family:DM Sans,sans-serif;font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em}.gen-player-title{font-size:1.1rem;margin-top:.3rem}.gen-play-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--accent-dim);border:1px solid var(--accent);border-radius:50%;color:var(--accent);cursor:pointer;transition:background .2s,transform .15s}.gen-play-btn:hover{background:var(--accent);color:var(--bg);transform:scale(1.1)}.gen-chapter.current{border-color:var(--accent);background:var(--accent-dim)}.play-all-btn{display:inline-flex;align-items:center;gap:.6rem;margin-top:2rem;padding:.9rem 2rem;background:var(--accent);color:var(--bg);border:none;border-radius:var(--radius);font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .2s}.play-all-btn:hover{background:var(--accent-hover)}.progress-bar-wrapper{margin-top:1rem}.progress-label{font-family:DM Sans,sans-serif;font-size:.8rem;color:var(--text-secondary);margin-bottom:.4rem}.progress-bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .5s ease}.player-screen{display:flex;flex-direction:column}.player-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.player-header-right{display:flex;gap:.5rem}.icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--border);border-radius:50%;color:var(--text-secondary);cursor:pointer;transition:all .2s}.icon-btn:hover{color:var(--text);border-color:var(--accent);background:var(--surface-elevated)}.player-settings{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem 1.25rem;margin-bottom:1.5rem;animation:fadeUp .2s ease-out}.player-settings h3{font-size:.85rem;font-family:DM Sans,sans-serif;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin-bottom:.75rem}.setting-option{display:flex;gap:.5rem;margin-bottom:.5rem}.setting-btn{flex:1;padding:.5rem .75rem;font-family:DM Sans,sans-serif;font-size:.8rem;background:var(--surface-elevated);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;transition:all .2s}.setting-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.setting-btn:hover:not(.active){border-color:var(--text-secondary)}.setting-hint{font-size:.75rem;color:var(--text-secondary);font-family:DM Sans,sans-serif;line-height:1.4}.generating-badge{font-family:DM Sans,sans-serif;font-size:.75rem;color:var(--accent);animation:pulse 1.5s ease-in-out infinite;align-self:center}.chapter-status{font-family:DM Sans,sans-serif;font-size:.7rem}.chapter-status.generating{color:var(--accent);animation:pulse 1.5s ease-in-out infinite}.chapter-status.pending{color:var(--text-secondary)}.chapter-item.disabled{opacity:.5;cursor:not-allowed}.chapter-item.disabled:hover{background:none}.player-content{flex:1;text-align:center;padding:1rem 0}.player-book-title{font-size:1.3rem;margin-bottom:2rem;color:var(--text-secondary)}.player-chapter-info{margin-bottom:2rem}.player-chapter-label{font-family:DM Sans,sans-serif;font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em}.player-chapter-title{font-size:1.4rem;margin-top:.5rem}.audio-player{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);margin-bottom:1.5rem}.play-btn{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--accent);border:none;border-radius:50%;color:var(--bg);cursor:pointer;transition:background .2s,transform .15s;flex-shrink:0}.play-btn:hover{background:var(--accent-hover);transform:scale(1.05)}.play-btn svg{width:20px;height:20px}.player-progress{flex:1;cursor:pointer}.progress-track{height:4px;background:var(--border);border-radius:2px;overflow:hidden;margin-bottom:.4rem}.progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .1s linear}.progress-time{display:flex;justify-content:space-between;font-family:DM Sans,sans-serif;font-size:.75rem;color:var(--text-secondary)}.player-nav{display:flex;justify-content:center;gap:1rem}.nav-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:DM Sans,sans-serif;font-size:.85rem;cursor:pointer;transition:all .2s}.nav-btn:hover:not(:disabled){background:var(--surface-elevated);border-color:var(--accent)}.nav-btn:disabled{opacity:.3;cursor:not-allowed}.player-chapter-list{margin-top:2rem;border-top:1px solid var(--border);padding-top:1.5rem}.chapter-list-title{font-size:1rem;margin-bottom:1rem;font-family:DM Sans,sans-serif;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary)}.chapter-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.7rem .75rem;background:none;border:none;border-bottom:1px solid var(--border);color:var(--text);cursor:pointer;transition:all .15s;font-family:inherit;text-align:left}.chapter-item:hover{background:var(--surface)}.chapter-item.active{color:var(--accent)}.chapter-num{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--surface);font-family:DM Sans,sans-serif;font-size:.75rem;flex-shrink:0}.chapter-item.active .chapter-num{background:var(--accent-dim);color:var(--accent)}.chapter-name{flex:1;font-size:.9rem}.chapter-playing{font-family:DM Sans,sans-serif;font-size:.7rem;color:var(--accent);animation:pulse 1.5s ease-in-out infinite}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.book-card:nth-child(1){animation-delay:0s}.book-card:nth-child(2){animation-delay:.05s}.book-card:nth-child(3){animation-delay:.1s}.book-card:nth-child(4){animation-delay:.15s}.book-card:nth-child(5){animation-delay:.2s}
