:root{--bg: #ffffff;--fg: #1f2937;--muted: #6b7280;--accent: #2563eb;--l2: #b45309;--border: #e5e7eb;--danger: #dc2626;--ok: #16a34a;--reader-bg: #faf8f3;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--fg)}*{box-sizing:border-box}html,body,#root{margin:0;height:100%}body{background:var(--bg)}button{font:inherit;cursor:pointer}.app-loading,.status,.reader-status{padding:2rem;text-align:center;color:var(--muted)}.status.error,.reader-error{color:var(--danger)}.app{display:flex;flex-direction:column;min-height:100%}.app-header{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--border)}.app-brand{font-weight:700}.app-nav{display:flex;gap:.25rem}.app-nav button,.admin-tabs button{background:transparent;border:none;padding:.4rem .75rem;border-radius:6px;color:var(--muted)}.app-nav button.active,.admin-tabs button.active{background:var(--accent);color:#fff}.app-user{margin-left:auto;display:flex;align-items:center;gap:.75rem;color:var(--muted)}.app-main{flex:1;padding:1rem;max-width:960px;margin:0 auto;width:100%}.link-btn{background:none;border:none;color:var(--accent);padding:0}.primary-btn{background:var(--accent);color:#fff;border:none;border-radius:6px;padding:.5rem .9rem}.primary-btn:disabled{opacity:.5;cursor:not-allowed}.danger-btn{background:transparent;color:var(--danger);border:1px solid var(--danger);border-radius:6px;padding:.35rem .7rem}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100%;padding:1rem}.login-card{width:100%;max-width:340px;display:flex;flex-direction:column;gap:.75rem;border:1px solid var(--border);border-radius:10px;padding:1.5rem}.login-card h1{margin:0}.login-sub{margin:0 0 .5rem;color:var(--muted)}.login-card label,.upload-form label,.user-form label{display:flex;flex-direction:column;gap:.25rem;font-size:.9rem;color:var(--muted)}.login-card input,.upload-form input,.upload-form select,.user-form input,select{padding:.45rem .5rem;border:1px solid var(--border);border-radius:6px;font:inherit}.login-error,.form-error{color:var(--danger);font-size:.9rem}.login-hint{font-size:.8rem;color:var(--muted)}.library-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.library-item{display:flex;align-items:center;gap:1rem;border:1px solid var(--border);border-radius:8px;padding:.75rem 1rem}.library-title{font-weight:600}.library-author,.library-status{font-size:.85rem;color:var(--muted)}.library-item .primary-btn{margin-left:auto}.status-ready{color:var(--ok)}.status-failed{color:var(--danger)}.reader{display:flex;flex-direction:column;height:100%;background:var(--reader-bg)}.reader-topbar{display:flex;align-items:center;gap:1rem;padding:.6rem 1rem;border-bottom:1px solid var(--border);background:#fff}.reader-title{font-weight:600}.offline-badge{margin-left:auto;font-size:.75rem;background:#fef3c7;color:#92400e;padding:.15rem .5rem;border-radius:999px}.reader-controls{display:flex;align-items:center;flex-wrap:wrap;gap:1rem;padding:.6rem 1rem;background:#fff;border-bottom:1px solid var(--border)}.density-control{display:flex;flex-direction:column;font-size:.8rem;color:var(--muted);min-width:180px}.l2-style-control{display:flex;flex-direction:column;font-size:.8rem;color:var(--muted)}.progress-display{margin-left:auto;font-size:.85rem;color:var(--accent);font-weight:600}.chapter-nav{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff;border-bottom:1px solid var(--border)}.chapter-nav select{flex:1}.reader-page{flex:1;overflow-y:auto;padding:1.5rem}.reader-text{max-width:42rem;margin:0 auto;font-size:1.15rem;line-height:1.9;white-space:pre-wrap}.reader-foliate{padding:0;overflow:hidden;display:flex}.foliate-host{flex:1;min-width:0;min-height:0}.reader-pager{display:flex;align-items:center;gap:.5rem;padding:.4rem 1rem;background:#fff;border-top:1px solid var(--border)}.reader-pager .progress-display{margin-left:auto}.toc-control{display:flex;flex-direction:column;font-size:.8rem;color:var(--muted);min-width:160px}.toc-control select{max-width:260px}.woven{cursor:pointer}.woven-subtle{color:var(--l2);font-style:italic}.woven-underline{text-decoration:underline dotted var(--l2);text-underline-offset:3px}.woven-none{color:inherit;font-style:inherit;text-decoration:none}.overlay-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:flex-end;justify-content:center;z-index:100}.overlay-card{position:relative;background:#fff;width:100%;max-width:32rem;border-radius:16px 16px 0 0;padding:1.5rem;box-shadow:0 -4px 24px #0003}@media (min-width: 640px){.overlay-backdrop{align-items:center}.overlay-card{border-radius:16px}}.overlay-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;font-size:1.5rem;line-height:1;color:var(--muted)}.overlay-spanish-row{display:flex;align-items:center;gap:.75rem}.overlay-spanish{font-size:1.5rem;font-weight:700;color:var(--l2)}.overlay-pron{background:none;border:1px solid var(--border);border-radius:8px;padding:.3rem .5rem}.overlay-source{margin-top:.75rem;display:flex;align-items:baseline;gap:.5rem}.overlay-label,.overlay-pos{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.overlay-source-word{font-size:1.1rem}.overlay-gloss{margin-top:1rem;border-top:1px solid var(--border);padding-top:.75rem}.overlay-gloss-meta{display:flex;gap:.5rem;align-items:baseline}.overlay-lemma{font-size:.85rem;color:var(--muted)}.overlay-gloss-text{margin:.4rem 0 0}.overlay-band{margin-top:.75rem;font-size:.75rem;color:var(--muted)}.admin-tabs{display:flex;gap:.25rem;margin-bottom:1rem;border-bottom:1px solid var(--border);padding-bottom:.5rem}.admin-build{display:grid;gap:1.5rem}.upload-form,.user-form{display:flex;flex-direction:column;gap:.6rem;max-width:420px;border:1px solid var(--border);border-radius:10px;padding:1.25rem}.checkbox-label{flex-direction:row!important;align-items:center;gap:.5rem}.admin-table{width:100%;border-collapse:collapse}.admin-table th,.admin-table td{text-align:left;padding:.5rem;border-bottom:1px solid var(--border);font-size:.9rem}.user-list{list-style:none;margin:0 0 1.5rem;padding:0;display:flex;flex-direction:column;gap:.4rem}.user-list li{display:flex;align-items:center;gap:.5rem}.user-admin-badge{font-size:.7rem;background:var(--accent);color:#fff;padding:.1rem .4rem;border-radius:999px}.job-card{border:1px solid var(--border);border-radius:10px;padding:1rem;margin-bottom:1rem}.job-monitor-head{display:flex;align-items:center;gap:.75rem}.job-state{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;padding:.1rem .5rem;border-radius:999px;background:var(--border)}.job-state-running{background:#dbeafe;color:#1e40af}.job-state-paused{background:#fef3c7;color:#92400e}.job-state-failed{background:#fee2e2;color:#991b1b}.job-state-done{background:#dcfce7;color:#166534}.job-stage{color:var(--muted)}.job-pct{margin-left:auto;font-weight:600}.job-bar{height:8px;background:var(--border);border-radius:999px;overflow:hidden;margin:.6rem 0}.job-bar-fill{height:100%;background:var(--accent);transition:width .3s ease}.job-stages{list-style:none;margin:.5rem 0;padding:0;display:flex;flex-wrap:wrap;gap:.4rem;font-size:.7rem}.job-stages li{padding:.1rem .45rem;border-radius:999px;background:var(--border);color:var(--muted)}.stage-done{background:#dcfce7!important;color:#166534!important}.stage-active{background:var(--accent)!important;color:#fff!important}.job-stats{display:flex;gap:1rem;font-size:.8rem;color:var(--muted);margin:.5rem 0}.job-actions{display:flex;gap:.5rem}.job-actions button{border:1px solid var(--border);background:#fff;border-radius:6px;padding:.35rem .7rem}
