:root{font-family:Noto Sans TC,PingFang TC,Microsoft JhengHei,Inter,system-ui,-apple-system,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#111827;background:#f4f7ff;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{width:100%;min-height:100%}html,body{margin:0;padding:0;min-width:320px}body{background:radial-gradient(circle at 100% 0%,#dbeafe,#dbeafe00 45%),radial-gradient(circle at 0% 100%,#e0e7ff,#e0e7ff00 40%),#f4f7ff;color:#0f172a}html[data-theme=dark] body{background:radial-gradient(circle at 100% 0%,#1e293ba6,#0f172a00 45%),radial-gradient(circle at 0% 100%,#312e8161,#0f172a00 40%),#020617;color:#e2e8f0}button,input{font:inherit}#root{--safe-bottom: env(safe-area-inset-bottom, 0px);--tap-size: 44px;--mobile-nav-height: 74px}#root{width:100%}.splash{min-height:100vh;display:grid;place-items:center;color:#475569;font-size:1rem}.auth-layout{min-height:100vh;display:grid;place-items:center;padding:1rem}.glass-card{width:min(100%,440px);border-radius:24px;padding:1.2rem;background:#ffffffd1;border:1px solid rgba(255,255,255,.85);box-shadow:0 22px 40px #0f172a1f,inset 0 1px #ffffff8c;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.brand{margin:0;font-size:.72rem;letter-spacing:.14em;font-weight:700;color:#4f46e5;text-transform:uppercase}.glass-card h1{margin:.4rem 0;font-size:1.55rem}.muted{margin:0;color:#64748b;font-size:.9rem}.stack{display:grid;gap:.8rem}.field{display:grid;gap:.35rem}.field span{font-size:.82rem;color:#475569;font-weight:600}input{width:100%;border:1px solid #cbd5e1;background:#fff;border-radius:12px;padding:.72rem .82rem;min-height:var(--tap-size);color:#0f172a}input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f129}.btn-primary,.btn-secondary,.btn-ghost{border:0;border-radius:12px;padding:.68rem .9rem;min-height:var(--tap-size);font-weight:700;cursor:pointer;transition:transform .16s ease,opacity .16s ease}button:focus-visible,input:focus-visible{outline:2px solid #6366f1;outline-offset:2px}.btn-primary{color:#fff;background:linear-gradient(135deg,#4f46e5,#7c3aed)}.btn-secondary{color:#1e293b;background:#e2e8f0}.btn-ghost{color:#334155;background:transparent}button:hover{transform:translateY(-1px);opacity:.95}button:disabled{opacity:.55;transform:none;cursor:not-allowed}.error-msg{color:#dc2626;font-size:.88rem}.auth-theme-toggle{margin:.65rem 0 .15rem}.app-shell{min-height:100vh;min-height:100dvh;padding-bottom:calc(var(--mobile-nav-height) + var(--safe-bottom))}.topbar{position:sticky;top:0;z-index:20;display:flex;flex-direction:column;justify-content:flex-start;align-items:stretch;gap:.9rem;background:#f4f7ffeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid #dbe3f4;padding:.9rem}.topbar--reader{padding:.62rem .75rem;gap:.45rem}.brand--reader{font-size:.66rem;letter-spacing:.1em}.page-title--reader{margin-top:.16rem;font-size:.96rem;line-height:1.28}.page-title{margin:.3rem 0 0;font-size:1.06rem}.top-actions{display:flex;gap:.4rem;align-items:center;flex-wrap:wrap}.session-actions{display:flex;gap:.4rem;width:100%}.session-actions .btn-ghost{flex:1}.top-actions .badge{width:100%;text-align:center}@media(max-width:767px){.topbar--reader{padding:.52rem .62rem;gap:.3rem}.topbar--reader .brand--reader{display:none}.topbar--reader .page-title--reader{margin:0;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.top-actions--reader{display:none}.content.reader-mode{padding:.55rem}.reader-panel{gap:.45rem}.reader-chapter-progress{display:none}.reader-content{height:calc(100vh - 178px - var(--safe-bottom));min-height:0;max-height:none;padding:.92rem}.reader-content--expanded{height:calc(100vh - 126px - var(--safe-bottom));min-height:0;max-height:none}@supports (height: 100dvh){.reader-content{height:calc(100dvh - 178px - var(--safe-bottom))}.reader-content--expanded{height:calc(100dvh - 126px - var(--safe-bottom))}}.reader-content-footer{margin-top:.72rem}.top-actions .badge{overflow:hidden;max-height:44px;opacity:1;transform:translateY(0);transition:max-height .22s ease,opacity .2s ease,transform .2s ease}.badge--hidden{max-height:0;opacity:0;transform:translateY(-6px);pointer-events:none;margin:0;padding-top:0;padding-bottom:0;border-width:0}.session-actions{overflow:hidden;max-height:56px;opacity:1;transform:translateY(0);transition:max-height .22s ease,opacity .2s ease,transform .2s ease}.session-actions--hidden{max-height:0;opacity:0;transform:translateY(-6px);pointer-events:none}}.badge{padding:.35rem .58rem;border-radius:999px;background:#e0e7ff;color:#3730a3;font-size:.74rem;font-weight:700;white-space:nowrap}.toast{margin:.8rem .9rem 0;padding:.66rem .85rem;border-radius:10px;font-size:.85rem;color:#1e293b;background:#e0f2fe;border:1px solid #bae6fd}.toast.error{background:#fee2e2;border-color:#fecaca;color:#7f1d1d}.content{padding:.9rem}.content.reader-mode{padding-top:.7rem}.card{background:#ffffffe6;border:1px solid #e2e8f0;border-radius:16px;padding:.9rem}.card h3{margin:0;font-size:1.03rem}.intro{font-size:.9rem;line-height:1.65;color:#334155}.row-between{display:flex;justify-content:space-between;align-items:center;gap:.8rem}.icon-btn{display:inline-flex;align-items:center;justify-content:center;min-width:var(--tap-size);width:var(--tap-size);padding:0}.icon-refresh{width:1.2rem;height:1.2rem}.refresh-btn{flex:0 0 auto}.refresh-btn.is-spinning .icon-refresh{animation:spin .8s linear infinite}.list{margin-top:.7rem;display:grid;gap:.56rem}.list-item{width:100%;min-height:var(--tap-size);text-align:left;border:1px solid #e2e8f0;border-radius:12px;background:#f8fafc;padding:.65rem;display:grid;gap:.24rem}.list-item strong{font-size:.95rem;color:#0f172a}.list-item span{font-size:.74rem;color:#64748b;overflow-wrap:anywhere}.library-item{display:grid;gap:.45rem}.library-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.45rem}.library-open{margin:0}.btn-sm{padding:.45rem .65rem;font-size:.8rem}.btn-danger{border:1px solid #fecaca;color:#b91c1c;background:#fff1f2}.chapter-tools{margin-top:.85rem;display:grid;gap:.58rem}.chapter-jump-form{display:grid;gap:.5rem}.chapter-pagination{margin-top:.7rem;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.45rem;align-items:center}.chapter-page-info{grid-column:1 / -1;text-align:center;font-size:.82rem}.chapter-list{max-height:45vh;overflow:auto}.inline-form{display:grid;gap:.45rem}.account-row{border:1px solid #e2e8f0;border-radius:12px;background:#f8fafc;padding:.72rem;display:grid;gap:.55rem}.reader-panel{display:grid;gap:.72rem}.reader-toolbar{display:grid;gap:.7rem}.reader-chapter-progress{margin:0}.reader-settings-panel{display:grid;gap:.7rem;overflow:hidden;max-height:360px;opacity:1;transform:translateY(0);transition:max-height .24s ease,opacity .2s ease,transform .2s ease}.reader-settings-panel--collapsed{max-height:84px}.reader-toolbar-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.7rem}.reader-settings-toggle{white-space:nowrap;min-width:96px}.toolbar-grid{display:grid;gap:.55rem}.toolbar-grid label{display:grid;gap:.28rem;font-size:.8rem;color:#475569}.toolbar-grid input[type=range]{width:100%;padding:0;border:0;background:transparent}.theme-pills{display:flex;gap:.42rem}.theme-pills button{flex:1;border:1px solid #cbd5e1;border-radius:999px;background:#f1f5f9;padding:.4rem}.theme-pills .active{background:#4f46e5;border-color:#4f46e5;color:#fff}.reader-nav-buttons{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.4rem}.reader-content{border-radius:16px;border:1px solid #e2e8f0;min-height:calc(100vh - 330px);max-height:calc(100vh - 206px - var(--safe-bottom));overflow:auto;padding:1.05rem}.reader-content--expanded{min-height:calc(100vh - 286px);max-height:calc(100vh - 162px - var(--safe-bottom))}@supports (height: 100dvh){.reader-content{min-height:calc(100dvh - 330px);max-height:calc(100dvh - 206px - var(--safe-bottom))}.reader-content--expanded{min-height:calc(100dvh - 286px);max-height:calc(100dvh - 162px - var(--safe-bottom))}}.reader-content pre{margin:0;font-family:Noto Sans TC,Microsoft JhengHei,sans-serif;white-space:pre-wrap;color:inherit}.reader-content-footer{margin-top:1rem;padding-top:.8rem;border-top:1px dashed #cbd5e1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.45rem}.reader-content.paper{background:#fffcf6;color:#2a2a2a}.reader-content.sepia{background:#f4ecd8;color:#4a3a20}.reader-content.dark{background:#0f172a;color:#dbeafe;border-color:#1e293b}.bottom-nav{position:fixed;left:0;right:0;bottom:0;background:#fffffff2;border-top:1px solid #dbe3f4;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.52rem .52rem calc(.52rem + var(--safe-bottom));display:grid;gap:.45rem;grid-template-columns:repeat(4,minmax(0,1fr))}.bottom-nav--user{grid-template-columns:repeat(3,minmax(0,1fr))}.bottom-nav--admin{grid-template-columns:repeat(4,minmax(0,1fr))}.bottom-nav button{border-radius:10px;border:1px solid transparent;background:transparent;min-height:var(--tap-size);padding:.5rem;font-size:.8rem;color:#475569}@media(prefers-reduced-motion:reduce){button{transition:none}.refresh-btn.is-spinning .icon-refresh{animation:none}.session-actions,.top-actions .badge,.reader-settings-panel{transition:none!important}}.bottom-nav button.active{background:#e0e7ff;color:#312e81;font-weight:700}html[data-theme=dark] .splash{color:#cbd5e1}html[data-theme=dark] .glass-card{background:#0f172ab3;border-color:#47556980;box-shadow:0 22px 40px #02061773,inset 0 1px #94a3b81f}html[data-theme=dark] .glass-card h1,html[data-theme=dark] .page-title,html[data-theme=dark] .card h3,html[data-theme=dark] .list-item strong,html[data-theme=dark] .account-row strong{color:#e2e8f0}html[data-theme=dark] .muted,html[data-theme=dark] .field span,html[data-theme=dark] .intro,html[data-theme=dark] .list-item span,html[data-theme=dark] .toolbar-grid label{color:#94a3b8}html[data-theme=dark] input{border-color:#334155;background:#0f172a;color:#e2e8f0}html[data-theme=dark] input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f13d}html[data-theme=dark] .btn-secondary{color:#e2e8f0;background:#1e293b}html[data-theme=dark] .btn-ghost{color:#cbd5e1}html[data-theme=dark] .btn-danger{border-color:#7f1d1d;color:#fecaca;background:#3f1010}html[data-theme=dark] .chapter-page-info{color:#94a3b8}html[data-theme=dark] .topbar{background:#0f172ad1;border-bottom-color:#1e293b}html[data-theme=dark] .badge{background:#1e1b4b;color:#c7d2fe}html[data-theme=dark] .toast{color:#dbeafe;background:#082f49;border-color:#0c4a6e}html[data-theme=dark] .toast.error{color:#fee2e2;background:#450a0a;border-color:#7f1d1d}html[data-theme=dark] .card,html[data-theme=dark] .list-item,html[data-theme=dark] .account-row{background:#0f172a;border-color:#1e293b}html[data-theme=dark] .theme-pills button{border-color:#334155;background:#0b1220;color:#cbd5e1}html[data-theme=dark] .theme-pills .active{background:#4f46e5;border-color:#4f46e5;color:#fff}html[data-theme=dark] .reader-content{border-color:#1e293b}html[data-theme=dark] .reader-content-footer{border-top-color:#334155}html[data-theme=dark] .reader-content.paper{background:#111827;color:#e5e7eb}html[data-theme=dark] .reader-content.sepia{background:#2f2618;color:#f5e8c8}html[data-theme=dark] .bottom-nav{background:#020617eb;border-top-color:#1e293b}html[data-theme=dark] .bottom-nav button{color:#94a3b8}html[data-theme=dark] .bottom-nav button.active{background:#312e81;color:#e0e7ff}@media(min-width:768px){.app-shell{max-width:880px;margin:0 auto;padding-bottom:20px}.content{padding:1rem}.topbar{flex-direction:row;justify-content:space-between;align-items:flex-start;border-radius:0 0 16px 16px}.top-actions{flex-wrap:nowrap}.session-actions{width:auto}.session-actions .btn-ghost{flex:0 0 auto}.top-actions .badge{width:auto;text-align:left}.bottom-nav{position:sticky;bottom:0;margin:1rem;border-radius:14px;border:1px solid #dbe3f4}.inline-form{grid-template-columns:1fr 1fr auto;align-items:center}.chapter-jump-form{grid-template-columns:1fr auto;align-items:center}.chapter-pagination{grid-template-columns:auto auto 1fr auto auto}.chapter-page-info{grid-column:auto;text-align:center}.reader-toolbar{grid-template-columns:1fr}.reader-toolbar-head{align-items:center}.reader-content-footer{display:grid}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
