:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#102a43;background:#f8fafc}html,body,#app{margin:0;min-height:100%;background:#f8fafc}.app-shell{display:flex;min-height:100vh;background:#eef5ff;color:#102a43;position:relative}.sidebar-toggle{position:absolute;top:24px;left:24px;z-index:30;width:44px;height:44px;border-radius:12px;border:1px solid rgba(15,23,42,.1);background:#fff;box-shadow:0 6px 18px #0f172a29;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:0;cursor:pointer;transition:background .15s ease,border-color .15s ease}.sidebar-toggle:hover{background:#f8fafc;border-color:#0f172a2e}.sidebar-toggle .burger-line{width:20px;height:2px;background:#102a43;border-radius:2px;transition:transform .25s ease,opacity .2s ease}.sidebar-toggle.is-open .burger-line:nth-child(1){transform:translateY(7px) rotate(45deg)}.sidebar-toggle.is-open .burger-line:nth-child(2){opacity:0}.sidebar-toggle.is-open .burger-line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.sidebar{flex:0 0 clamp(240px,24vw,320px);max-width:320px;padding:24px;background:#fff;border-right:1px solid rgba(15,23,42,.08);display:flex;flex-direction:column;gap:20px;overflow:hidden;transition:flex-basis .25s ease,max-width .25s ease,padding .25s ease,opacity .2s ease}.app-shell.sidebar-collapsed .sidebar{flex-basis:0;max-width:0;padding-left:0;padding-right:0;opacity:0;border-right:none;pointer-events:none}.brand{display:flex;align-items:center;padding-bottom:10px;padding-left:56px;min-height:44px;border-bottom:1px solid rgba(15,23,42,.08)}.brand-logo{width:170px;max-width:100%;height:auto;display:block}.screen-input,.screen-input input{display:none}.screen-input button,.footer-info button{width:100%;margin-top:12px;padding:12px;border-radius:14px;border:none;background:#2563eb;color:#fff;cursor:pointer;box-shadow:0 12px 30px #2563eb2e}.playlist{flex:1 1 auto;min-height:0;overflow:auto}.playlist h2{margin:0 0 16px;font-size:1.2rem;color:#0f172a}.playlist ul{list-style:none;padding:0;margin:0;display:grid;gap:12px}.playlist li{display:grid;grid-template-columns:96px 1fr;gap:12px;align-items:center;padding:14px;border-radius:18px;background:#f8fafc;border:1px solid rgba(15,23,42,.08);cursor:pointer;transition:background .2s ease,transform .2s ease}.playlist li.active,.playlist li:hover{background:#eef5ff;transform:translateY(-1px)}.playlist li strong{display:block}.thumb-wrap{width:96px;min-width:96px;height:72px;border-radius:16px;overflow:hidden;background:#dbeafe}.thumb{width:100%;height:100%;object-fit:cover}.thumb.placeholder{display:flex;align-items:center;justify-content:center;color:#334155;font-size:.85rem;text-transform:uppercase;padding:.5rem}.meta{min-width:0}.title{font-size:.96rem;font-weight:700;line-height:1.3;color:#102a43;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.muted{font-size:.8rem;color:#627d98;margin-top:4px}.viewport{flex:1 1 auto;min-height:0;padding:24px;display:flex;align-items:stretch;justify-content:stretch;touch-action:pan-y}.viewport-inner{width:100%;height:100%;background:#fff;border-radius:30px;box-shadow:0 30px 80px #0f172a1f;display:flex;align-items:stretch;justify-content:stretch;position:relative;overflow:hidden;padding:0}.viewport-inner>*{flex:1 1 auto;min-height:0}.video-embed{display:flex;align-items:stretch;justify-content:stretch;width:100%;height:100%;background:#000}.video-embed{width:100%;height:100%}.video-iframe{width:100%;height:100%;border:0;border-radius:0}.video-player,.image-view{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.viewer-message{color:#102a43;font-size:1.1rem;display:flex;align-items:center;justify-content:center;width:100%;height:100%;text-align:center;padding:1rem}.viewer-message.error,.notice.error{color:#b91c1c}.notice.offline{background:#fef3c7;color:#92400e}.pdf-viewer{width:100%;height:100%;position:relative;overflow:hidden;background:#0f172a}.pdf-page-backdrop{position:absolute;top:-20px;right:-20px;bottom:-20px;left:-20px;background-size:cover;background-position:center;filter:blur(24px) brightness(.55);transform:scale(1.1)}.pdf-page-fit{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain}.pdf-spread{position:absolute;top:0;right:0;bottom:0;left:0;display:flex}.pdf-spread-half{position:relative;flex:1 1 50%;min-width:0}.pdf-spread-half+.pdf-spread-half{border-left:1px solid rgba(255,255,255,.15)}.pdf-spread-half-empty{background:#0f172a}.pdf-nav{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;border:none;background:#0f172a8c;color:#fff;cursor:pointer;font-size:1.5rem;line-height:1;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);transition:background .15s ease,transform .15s ease;z-index:5}.pdf-nav:hover{background:#0f172abf}.pdf-nav.prev{left:24px}.pdf-nav.next{right:24px}.pdf-page-count{position:absolute;bottom:16px;left:50%;transform:translate(-50%);background:#0f172a99;color:#fff;padding:4px 12px;border-radius:999px;font-size:.8rem;z-index:5}.footer-info{display:grid;gap:10px}.conn-dot{font-size:.75rem;color:#b91c1c;text-align:center}.conn-dot.ok{color:#15803d}.notice{padding:14px;border-radius:14px;background:#e2e8f0;color:#102a43}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:#020617;color:#e2e8f0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,select,textarea{font:inherit}
