:root{--bg:#0f0f0f;--surface:#1a1a1a;--border:#2a2a2a;--text:#e0e0e0;--text-muted:#e0e0e073;--accent:#f59e0b;--danger:#ef4444;--radius:8px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);min-height:100dvh;font-family:system-ui,-apple-system,sans-serif}button{cursor:pointer;font-family:inherit}.library-screen{max-width:860px;margin:0 auto;padding:2rem 1rem}.library-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.library-header h1{font-size:1.8rem}.upload-btn{background:var(--accent);color:#000;border-radius:var(--radius);cursor:pointer;border:none;padding:.6rem 1.2rem;font-size:.95rem;font-weight:600;display:inline-block}.upload-btn:disabled{opacity:.5;cursor:not-allowed}.book-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;display:grid}.book-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:.4rem;padding:1rem;display:flex;position:relative}.book-card.has-warning{border-color:#713f12}.book-badges{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.warning-badge{color:var(--accent);margin-left:auto;font-size:1rem}.book-title{white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:600;overflow:hidden}.word-count{color:var(--text-muted);flex:1;font-size:.8rem}.warning-msg{color:var(--accent);font-size:.78rem;line-height:1.4}.book-actions{gap:.5rem;margin-top:.5rem;display:flex}.book-actions button{border:1px solid var(--border);color:var(--text);background:0 0;border-radius:5px;flex:1;padding:.45rem 0;font-size:.85rem}.book-actions .btn-read{background:var(--accent);color:#000;border-color:var(--accent);font-weight:600}.book-actions button:disabled{opacity:.4;cursor:not-allowed}.warning-msg-text{color:var(--accent);margin-top:.5rem;font-size:.8rem}.empty-state{text-align:center;color:var(--text-muted);grid-column:1/-1;padding:4rem 2rem}.toast{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);z-index:999;white-space:nowrap;padding:.75rem 1.5rem;font-size:.9rem;position:fixed;bottom:2rem;left:50%;transform:translate(-50%)}.reader-screen{flex-direction:column;height:100dvh;padding:.75rem 1rem;display:flex}.reader-top-bar{align-items:center;gap:1rem;margin-bottom:.5rem;display:flex}.back-btn{color:var(--text-muted);background:0 0;border:none;padding:0;font-size:.9rem}.book-title-bar{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.85rem;overflow:hidden}.finished-badge{text-align:center;color:var(--accent);padding:.25rem 0;font-size:.85rem;font-weight:600}.orp-stage{flex:1;justify-content:center;align-items:center;display:flex;overflow:hidden}.orp-wrapper{flex-direction:column;align-items:center;width:100%;display:flex}.guide-line{background:#f59e0b4d;border-radius:1px;width:2px;height:.55em}.word-row{align-items:baseline;width:92vw;max-width:960px;font-family:Courier New,Courier,monospace;font-weight:700;line-height:1;display:flex}.orp-before{text-align:right;color:var(--text-muted);white-space:nowrap;flex:1;overflow:hidden}.orp-letter{color:var(--accent);text-align:center;flex-shrink:0;min-width:.6ch}.orp-after{text-align:left;color:var(--text-muted);white-space:nowrap;flex:1;overflow:hidden}.progress-bar{background:var(--border);cursor:pointer;border-radius:3px;height:6px;margin:.6rem 0;position:relative}.progress-fill{background:var(--accent);pointer-events:none;border-radius:3px;height:100%;transition:width .1s linear}.control-bar{flex-wrap:wrap;align-items:center;gap:1rem;padding:.75rem 0 .25rem;display:flex}.play-btn{background:var(--accent);color:#000;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:2.8rem;height:2.8rem;font-size:1.2rem;display:flex}.wpm-control{flex-direction:column;flex:1;gap:.2rem;min-width:140px;display:flex}.wpm-label{color:var(--text-muted);font-size:.78rem}.wpm-control input[type=range]{width:100%;accent-color:var(--accent)}.font-size-btns{gap:.3rem;display:flex}.font-size-btns button{border:1px solid var(--border);color:var(--text-muted);background:0 0;border-radius:4px;padding:.4rem .6rem;font-size:.75rem;font-weight:600}.font-size-btns button.active{background:var(--accent);color:#000;border-color:var(--accent)}.reader-focused{padding:0}.reader-focused .orp-stage{cursor:none}.rewind-btn{border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius);background:0 0;flex-shrink:0;padding:.4rem .7rem;font-size:.82rem}.reader-error{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1.2rem;height:100dvh;padding:2rem;display:flex}.reader-error p{color:var(--text-muted)}.reader-error button{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:var(--radius);padding:.7rem 1.5rem}.login-screen{justify-content:center;align-items:center;min-height:100dvh;padding:1rem;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:1.2rem;width:100%;max-width:380px;padding:2rem;display:flex}.login-card h1{text-align:center;color:var(--accent);font-size:1.4rem}.login-card form{flex-direction:column;gap:.6rem;display:flex}.login-card label{color:var(--text-muted);font-size:.82rem}.login-card input{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);border-radius:5px;margin-bottom:.4rem;padding:.55rem .75rem;font-family:inherit;font-size:1rem}.login-card button[type=submit]{background:var(--accent);color:#000;border-radius:var(--radius);cursor:pointer;border:none;margin-top:.4rem;padding:.7rem;font-size:1rem;font-weight:600}.login-card button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.login-error{color:var(--danger);text-align:center;font-size:.85rem}.library-header-actions{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.admin-btn,.signout-btn{border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius);background:0 0;padding:.5rem 1rem;font-size:.9rem}.shared-badge{color:var(--accent);text-transform:uppercase;letter-spacing:.05em;background:#f59e0b26;border-radius:3px;padding:.1rem .4rem;font-size:.7rem;font-weight:600}.admin-screen{max-width:960px;margin:0 auto;padding:.75rem 1rem 2rem}.admin-top-bar{align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.admin-title{color:var(--text-muted);font-size:1rem;font-weight:600}.admin-tabs{border-bottom:1px solid var(--border);gap:.25rem;margin-bottom:1.5rem;display:flex}.admin-tab{color:var(--text-muted);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:.6rem 1rem;font-size:.9rem}.admin-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.admin-section-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.admin-section-header h2{font-size:1.1rem}.admin-add-btn{background:var(--accent);color:#000;border-radius:var(--radius);cursor:pointer;border:none;padding:.45rem 1rem;font-size:.88rem;font-weight:600}.admin-add-btn.disabled{opacity:.5;cursor:not-allowed}.admin-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:.4rem;max-width:400px;margin-bottom:1.5rem;padding:1rem;display:flex}.admin-form label{color:var(--text-muted);font-size:.8rem}.admin-form input,.admin-form select{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:5px;width:100%;margin-bottom:.2rem;padding:.45rem .7rem;font-family:inherit;font-size:.95rem}.admin-form button[type=submit]{background:var(--accent);color:#000;border-radius:var(--radius);cursor:pointer;border:none;margin-top:.4rem;padding:.5rem;font-weight:600}.admin-error{color:var(--danger);font-size:.82rem}.admin-table{border-collapse:collapse;width:100%;font-size:.88rem}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid var(--border);padding:.55rem .75rem}.admin-table th{color:var(--text-muted);font-weight:500}.admin-actions{gap:.4rem;display:flex}.admin-actions button{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:4px;padding:.3rem .6rem;font-size:.8rem}.btn-danger{color:var(--danger)!important;border-color:var(--danger)!important}.admin-modal-backdrop{z-index:100;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.admin-modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:.8rem;width:320px;padding:1.5rem;display:flex}.admin-modal h3{font-size:1rem}.admin-modal label{color:var(--text-muted);font-size:.8rem}.admin-modal input{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);border-radius:5px;margin-top:.25rem;padding:.45rem .7rem;font-family:inherit;font-size:.95rem}.admin-modal-btns{gap:.5rem;margin-top:.4rem;display:flex}.admin-modal-btns button{border-radius:var(--radius);border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;flex:1;padding:.5rem;font-size:.9rem}.admin-modal-btns button[type=submit]{background:var(--accent);color:#000;border-color:var(--accent);font-weight:600}
