:root{--paper: #f4ede0;--paper-deep: #ebe2d1;--ink: #1a1410;--ink-soft: #3d3228;--ink-fade: #756a5a;--rule: #d4c8b0;--accent: #8b3a2f;--accent-deep: #6b2a22;--gold: #b8924a;--shadow: rgba(26, 20, 16, .08);--font-display: "Cormorant Garamond", "Times New Roman", Georgia, serif;--font-body: "Inter", system-ui, sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;background:var(--paper);color:var(--ink);font-family:var(--font-body);-webkit-font-smoothing:antialiased}body{background-image:radial-gradient(circle at 20% 30%,rgba(184,146,74,.04) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(139,58,47,.03) 0%,transparent 50%);padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea,select{font-family:inherit;font-size:1rem}a{color:var(--accent);text-decoration:none}.app{max-width:780px;margin:0 auto;min-height:100vh;padding:24px 20px 120px}.header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:32px;padding-bottom:16px;border-bottom:1px solid var(--rule)}.brand{font-family:var(--font-display);font-style:italic;font-weight:500;font-size:1.75rem;letter-spacing:-.01em}.brand:before{content:"❦  ";color:var(--gold);font-style:normal}.nav{display:flex;gap:18px;font-size:.85rem;text-transform:uppercase;letter-spacing:.12em}.nav a{color:var(--ink-fade);padding-bottom:2px;border-bottom:1px solid transparent;transition:all .2s}.nav a:hover,.nav a.active{color:var(--ink);border-bottom-color:var(--accent)}.login{max-width:360px;margin:18vh auto 0;text-align:center;padding:0 20px}.login h1{font-family:var(--font-display);font-weight:500;font-size:2.5rem;margin-bottom:8px;letter-spacing:-.01em}.login .tagline{font-style:italic;color:var(--ink-fade);margin-bottom:36px;font-family:var(--font-display);font-size:1.1rem}.login form{display:flex;flex-direction:column;gap:12px}.input{width:100%;padding:14px 16px;background:transparent;border:1px solid var(--rule);color:var(--ink);border-radius:0;transition:border-color .2s}.input:focus{outline:none;border-color:var(--ink)}.btn{padding:14px 20px;background:var(--ink);color:var(--paper);font-size:.85rem;text-transform:uppercase;letter-spacing:.15em;font-weight:500;transition:background .2s}.btn:hover{background:var(--accent)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--rule)}.btn-ghost:hover{border-color:var(--ink);background:var(--paper-deep)}.error{color:var(--accent);font-size:.9rem;font-style:italic}.upload-bar{display:flex;gap:12px;align-items:center;margin-bottom:32px;padding:16px;border:1px dashed var(--rule);background:var(--paper-deep)}.upload-bar label{flex:1;cursor:pointer;color:var(--ink-soft);font-style:italic}.upload-bar input[type=file]{display:none}.upload-bar select{padding:8px 12px;background:transparent;border:1px solid var(--rule)}.books{display:flex;flex-direction:column}.book-card{display:grid;grid-template-columns:60px 1fr auto;gap:16px;padding:20px 0;border-bottom:1px solid var(--rule);align-items:center;cursor:pointer;transition:background .15s}.book-card:hover{background:var(--paper-deep);margin:0 -12px;padding:20px 12px}.book-spine{width:50px;height:70px;background:linear-gradient(135deg,var(--accent-deep),var(--accent));box-shadow:2px 2px 4px var(--shadow);position:relative;display:flex;align-items:center;justify-content:center}.book-spine:after{content:"";position:absolute;top:8px;bottom:8px;left:4px;width:1px;background:#fff3}.book-spine span{color:var(--gold);font-family:var(--font-display);font-style:italic;font-size:.9rem;font-weight:600}.book-spine.var-1{background:linear-gradient(135deg,#2c3e2d,#4a6b4c)}.book-spine.var-2{background:linear-gradient(135deg,#2a3a52,#4a5a82)}.book-spine.var-3{background:linear-gradient(135deg,#5a3a1a,#8a5a2a)}.book-spine.var-4{background:linear-gradient(135deg,#4a2a4a,#6a3a6a)}.book-meta{min-width:0}.book-title{font-family:var(--font-display);font-size:1.35rem;font-weight:500;line-height:1.2;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.book-author{font-style:italic;color:var(--ink-fade);font-size:.95rem;margin-bottom:6px}.book-status{font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-fade)}.book-status.done{color:var(--gold)}.book-status.error{color:var(--accent)}.book-status.processing{color:var(--ink-soft)}.progress-bar{width:100%;height:2px;background:var(--rule);margin-top:8px;overflow:hidden}.progress-bar div{height:100%;background:var(--accent);transition:width .5s}.book-actions{display:flex;gap:8px}.icon-btn{width:36px;height:36px;display:grid;place-items:center;color:var(--ink-fade);border:1px solid transparent;transition:all .2s}.icon-btn:hover{color:var(--ink);border-color:var(--rule)}.empty{text-align:center;padding:80px 20px;color:var(--ink-fade)}.empty .ornament{font-family:var(--font-display);font-size:2rem;color:var(--gold);margin-bottom:16px}.empty h2{font-family:var(--font-display);font-weight:500;font-size:1.5rem;margin-bottom:8px;color:var(--ink)}.reader{display:flex;flex-direction:column}.reader-header{margin-bottom:24px}.reader-header h1{font-family:var(--font-display);font-weight:500;font-size:2rem;line-height:1.15;letter-spacing:-.01em;margin-bottom:4px}.reader-header .author{font-style:italic;color:var(--ink-fade)}.back-link{display:inline-block;margin-bottom:16px;font-size:.85rem;text-transform:uppercase;letter-spacing:.15em;color:var(--ink-fade)}.back-link:hover{color:var(--ink)}.chapter-list{border-top:1px solid var(--rule)}.chapter-row{display:grid;grid-template-columns:40px 1fr auto;padding:14px 0;border-bottom:1px solid var(--rule);cursor:pointer;gap:14px;align-items:center;transition:background .15s}.chapter-row:hover,.chapter-row.active{background:var(--paper-deep);margin:0 -12px;padding:14px 12px}.chapter-row.active .chapter-num{color:var(--accent)}.chapter-num{font-family:var(--font-display);font-style:italic;font-size:1.2rem;color:var(--ink-fade);text-align:center}.chapter-title{font-family:var(--font-display);font-size:1.1rem;font-weight:500}.chapter-dur{font-size:.85rem;color:var(--ink-fade);font-variant-numeric:tabular-nums}.player{position:fixed;bottom:0;left:0;right:0;background:var(--ink);color:var(--paper);padding:16px 20px calc(16px + env(safe-area-inset-bottom));box-shadow:0 -4px 20px #00000026;z-index:100}.player-inner{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:10px}.player-top{display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:.85rem}.player-title{font-family:var(--font-display);font-style:italic;font-size:1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.player-controls{display:flex;align-items:center;justify-content:center;gap:8px}.player-controls button{color:var(--paper);width:40px;height:40px;display:grid;place-items:center;border-radius:50%;transition:background .2s}.player-controls button:hover{background:#ffffff1a}.play-pause{width:52px!important;height:52px!important;background:var(--paper);color:var(--ink)!important}.play-pause:hover{background:var(--gold)!important}.player-progress{display:flex;align-items:center;gap:10px;font-size:.75rem;font-variant-numeric:tabular-nums;color:#f4ede0b3}.scrubber{flex:1;height:4px;background:#f4ede033;cursor:pointer;position:relative}.scrubber-fill{position:absolute;top:0;left:0;bottom:0;background:var(--gold)}.speed-pill{border:1px solid rgba(244,237,224,.3);padding:4px 10px;font-size:.75rem;border-radius:999px;letter-spacing:.05em}.speed-pill:hover{border-color:var(--gold);color:var(--gold)}.loader{display:flex;align-items:center;justify-content:center;padding:60px 20px;color:var(--ink-fade);font-style:italic;font-family:var(--font-display)}.loader:before{content:"";width:12px;height:12px;border-radius:50%;background:var(--accent);margin-right:12px;animation:pulse 1.4s infinite}@keyframes pulse{0%,to{opacity:.3;transform:scale(.85)}50%{opacity:1;transform:scale(1.1)}}@media (max-width: 600px){.app{padding:16px 16px 140px}.header{flex-direction:column;align-items:flex-start;gap:12px}.brand{font-size:1.5rem}.reader-header h1{font-size:1.6rem}.book-card{grid-template-columns:50px 1fr}.book-actions{grid-column:1 / -1;justify-content:flex-end;margin-top:-8px}}.reader{position:relative}.reader-toolbar{position:sticky;top:0;z-index:50;background:var(--paper);border-bottom:1px solid var(--rule);margin:-24px -20px 0;padding:10px 20px;display:flex;align-items:center;gap:16px}.reader-toolbar .back-link{margin:0;flex-shrink:0}.reader-title{flex:1;font-family:var(--font-display);font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:1.05rem}.reader-title .title-text{font-weight:500;color:var(--ink)}.reader-title .author-text{color:var(--ink-fade);margin-left:6px}.chapter-toggle{font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-fade);border:1px solid var(--rule);padding:6px 12px;flex-shrink:0;transition:all .2s}.chapter-toggle:hover{border-color:var(--ink);color:var(--ink)}.chapter-drawer{position:fixed;top:60px;right:20px;width:360px;max-width:calc(100vw - 40px);max-height:70vh;overflow-y:auto;background:var(--paper);border:1px solid var(--ink);box-shadow:0 8px 32px var(--shadow);z-index:60;padding:12px 16px}.chapter-drawer .chapter-row{display:grid;grid-template-columns:32px 1fr auto;padding:10px 0;border-bottom:1px solid var(--rule);gap:10px;align-items:center;cursor:pointer;font-size:.92rem;transition:opacity .2s}.chapter-drawer .chapter-row.pending{opacity:.4;cursor:not-allowed}.chapter-drawer .chapter-row:last-child{border-bottom:none}.chapter-drawer .chapter-row:hover:not(.pending){color:var(--accent)}.chapter-drawer .chapter-row.active{color:var(--accent)}.chapter-drawer .chapter-num{font-family:var(--font-display);font-style:italic;text-align:center;color:var(--ink-fade)}.chapter-drawer .chapter-dur{font-size:.78rem;color:var(--ink-fade);font-variant-numeric:tabular-nums}.reader-content{margin-top:20px}.pdf-pages{display:flex;flex-direction:column;align-items:center;gap:16px}.pdf-page-wrapper{background:#fff;box-shadow:0 4px 24px #1a14101f;border:1px solid var(--rule)}.pdf-page{position:relative;display:block}.pdf-page canvas{display:block}.pdf-overlay{position:absolute;top:0;left:0;pointer-events:none}.para-highlight{pointer-events:auto;background:#b8924a00;transition:background .4s ease;border-radius:2px}.para-highlight:hover{background:#b8924a1f}.para-highlight.active{background:#8b3a2f2e;box-shadow:0 0 0 2px #8b3a2f40}.para-highlight.active:hover{background:#8b3a2f47}.btn-reprocess{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;padding:4px 8px;border:1px solid var(--rule);color:var(--ink-fade);transition:all .2s}.btn-reprocess:hover{border-color:var(--accent);color:var(--accent)}@media (max-width: 600px){.reader-toolbar{gap:8px}.reader-title{font-size:.9rem}.chapter-toggle{font-size:.7rem;padding:5px 8px}.chapter-drawer{right:10px;left:10px;width:auto}.pdf-pages{gap:10px}.pdf-page canvas{max-width:100%;height:auto!important}.pdf-page{max-width:100%}}
