:root{--bg: #0f1115;--bg-elev: #171a21;--bg-elev-2: #1f242e;--border: #2a313d;--text: #e7ebf2;--muted: #8a93a3;--accent: #5b8cff;--accent-dim: #38507f;--good: #3ecf8e;--warn: #f0b429;--bad: #f06363;--reading: #3a3f4b;--shadow: 0 10px 30px rgba(0, 0, 0, .45);--bar-h: 52px;color-scheme:dark}*{box-sizing:border-box}html,body{margin:0;height:100%;background:var(--bg);color:var(--text);font:15px/1.5 system-ui,-apple-system,Segoe UI,Roboto,sans-serif;-webkit-text-size-adjust:100%;overscroll-behavior:none}#app,.tandem{height:100%}.tandem{display:flex;flex-direction:column}.topbar{flex:0 0 auto;height:var(--bar-h);display:flex;align-items:center;gap:10px;padding:0 10px;padding-top:env(safe-area-inset-top,0);background:linear-gradient(180deg,var(--bg-elev),var(--bg-elev-2));border-bottom:1px solid var(--border);z-index:20}.brand{display:flex;align-items:center;gap:8px;font-weight:700;letter-spacing:.02em;font-size:16px;padding-right:2px}.brand-logo{width:26px;height:26px;display:block}.brand-text{white-space:nowrap}.spacer{flex:1 1 auto}.chip{font:inherit;font-weight:600;letter-spacing:.06em;color:var(--text);background:var(--bg-elev-2);border:1px solid var(--border);border-radius:999px;padding:5px 12px;cursor:pointer}.chip:hover{border-color:var(--accent-dim)}.presence{display:flex;align-items:center;gap:6px}.presence-count{font-variant-numeric:tabular-nums;font-weight:700}.muted{color:var(--muted)}.dot{width:9px;height:9px;border-radius:50%;background:var(--muted);transition:background .2s}.dot.s-open{background:var(--good);box-shadow:0 0 8px var(--good)}.dot.s-connecting{background:var(--warn);animation:pulse 1s ease-in-out infinite}.dot.s-closed{background:var(--bad)}@keyframes pulse{50%{opacity:.35}}.page-indicator{color:var(--muted);font-variant-numeric:tabular-nums;font-size:14px}.btn{font:inherit;font-weight:600;color:var(--text);background:var(--bg-elev-2);border:1px solid var(--border);border-radius:8px;padding:7px 11px;cursor:pointer;white-space:nowrap}.btn:hover{border-color:var(--accent-dim)}.btn:active{transform:translateY(1px)}.btn.icon{width:38px;padding:7px 0;text-align:center;font-size:18px;line-height:1}.btn.icon.active,.sync-btn.on{color:#0b1220;background:var(--accent);border-color:var(--accent)}.sync-btn.off{color:var(--muted)}.drawer{flex:0 0 auto;overflow:hidden;max-height:0;background:var(--bg-elev);border-bottom:1px solid transparent;transition:max-height .25s ease,border-color .25s}.drawer.open{max-height:78vh;overflow-y:auto;border-bottom-color:var(--border)}.drawer .row,.drawer .help{margin:0 14px}.drawer .row:first-child{margin-top:14px}.drawer .help{margin-bottom:14px}.row{display:flex;gap:10px;align-items:flex-end;margin-bottom:10px;flex-wrap:wrap}.field{display:flex;flex-direction:column;gap:4px;flex:1 1 220px}.field-label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.text-input{font:inherit;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:9px 11px;width:100%}.text-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #5b8cff2e}.help{color:var(--muted);font-size:13px;margin:4px 0 0}.hidden-file{display:none}.btn.wide{align-self:stretch}.recents{margin:2px 14px 6px}.recents:empty{display:none}.recents-title{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.recent-item{display:flex;align-items:center;gap:6px;margin-bottom:6px}.recent-open{flex:1 1 auto;text-align:left;font:inherit;color:var(--text);background:var(--bg-elev-2);border:1px solid var(--border);border-radius:8px;padding:8px 11px;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recent-open:hover{border-color:var(--accent-dim)}.recent-del{flex:0 0 auto;font:inherit;color:var(--muted);background:transparent;border:1px solid var(--border);border-radius:8px;padding:8px 10px;cursor:pointer}.recent-del:hover{color:var(--bad);border-color:var(--bad)}.loader-row{flex-wrap:nowrap;align-items:stretch;gap:8px}.select-input{flex:0 0 auto;font:inherit;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:9px 10px;cursor:pointer}.select-input:focus{outline:none;border-color:var(--accent)}.loader-row .text-input{flex:1 1 auto;min-width:0}.loader-row .text-input:read-only{color:var(--muted);background:var(--bg-elev-2);cursor:default}.loader-row .btn{flex:0 0 auto}.drawer-collapse{display:block;width:100%;margin-top:6px;font:inherit;font-weight:600;font-size:13px;color:var(--muted);background:var(--bg-elev-2);border:0;border-top:1px solid var(--border);padding:10px 0;cursor:pointer}.drawer-collapse:hover{color:var(--text)}.section-header{display:block;width:calc(100% - 28px);margin:4px 14px 8px;text-align:left;font:inherit;font-weight:600;color:var(--text);background:transparent;border:0;border-top:1px solid var(--border);padding:10px 0 2px;cursor:pointer}.section-body.collapsed,.advanced-row{display:none}.drawer.show-advanced .advanced-row{display:flex}.link-btn{margin:0 14px 8px;font:inherit;font-size:13px;color:var(--accent);background:transparent;border:0;padding:0;cursor:pointer;text-align:left}.link-btn:hover{text-decoration:underline}.roster{margin:0 14px 8px}.roster:empty{display:none}.roster-title{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.roster-list{display:flex;flex-wrap:wrap;gap:6px}.roster-chip{font-size:13px;background:var(--bg-elev-2);border:1px solid var(--border);border-radius:999px;padding:4px 10px}.roster-chip.self{border-color:var(--accent-dim);color:var(--accent)}.roster-chip.sharing{border-color:var(--good);color:var(--good)}.share-dot{font-size:11px}button.presence{font:inherit;color:inherit;background:transparent;border:0;cursor:pointer}.modal-overlay{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px;background:#080a0eb3;backdrop-filter:blur(4px)}.modal-card{width:min(92vw,360px);background:var(--bg-elev);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:22px}.modal-title{margin:0 0 4px;font-size:18px}.modal-sub{margin:0 0 14px;color:var(--muted);font-size:14px}.modal-card .text-input{margin-bottom:12px}.screen-wrap{position:absolute;inset:0;z-index:30;display:none;background:#000}.tandem.watching-screen .screen-wrap{display:block}.screen-video{width:100%;height:100%;object-fit:contain;background:#000}.screen-label{position:absolute;top:10px;left:12px;font-size:12px;font-weight:600;color:#fff;background:#0000008c;border-radius:999px;padding:4px 10px}.screen-label:before{content:"";display:inline-block;width:8px;height:8px;margin-right:6px;border-radius:50%;background:var(--bad);vertical-align:middle;animation:pulse 1.2s ease-in-out infinite}.share-banner{display:none;position:fixed;bottom:calc(18px + env(safe-area-inset-bottom,0));left:50%;transform:translate(-50%);z-index:60;align-items:center;gap:12px;background:var(--bg-elev-2);border:1px solid var(--accent-dim);border-radius:999px;padding:8px 8px 8px 16px;box-shadow:var(--shadow);font-size:14px}.tandem.is-sharing .share-banner{display:flex}.btn.stop-share{background:var(--bad);border-color:var(--bad);color:#fff;border-radius:999px}.exit-immersive{display:none;position:fixed;top:calc(10px + env(safe-area-inset-top,0));right:12px;z-index:60;font:inherit;font-weight:600;color:var(--text);background:#1f242ed1;backdrop-filter:blur(6px);border:1px solid var(--border);border-radius:999px;padding:7px 14px;cursor:pointer;opacity:.5;transition:opacity .2s}.exit-immersive:hover{opacity:1}.tandem.immersive .topbar,.tandem.immersive .drawer{display:none}.tandem.immersive .exit-immersive{display:block}.view-host{position:relative;flex:1 1 auto;min-height:0}.pdf-scroller{position:absolute;inset:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;background:var(--reading);scrollbar-width:thin}.pdf-pages{display:flex;flex-direction:column;align-items:center;gap:16px;padding:16px 0 40vh}.pdf-page{position:relative;background:#fff;border-radius:2px;box-shadow:var(--shadow)}.pdf-canvas{display:block;border-radius:2px}.toast{position:fixed;left:50%;bottom:calc(20px + env(safe-area-inset-bottom,0));transform:translate(-50%,20px);max-width:min(90vw,420px);background:var(--bg-elev-2);border:1px solid var(--border);color:var(--text);padding:10px 16px;border-radius:10px;box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;z-index:50;text-align:center;word-break:break-word}.toast.show{opacity:1;transform:translate(-50%)}@media(max-width:560px){.brand-text{display:none}.sync-btn{padding:7px 9px}}
