:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--navy:#16223c;--navy-deep:#0f1830;--coral:#2563eb;--coral-hover:#1d4ed8;--coral-soft:#2563eb1a;--sky:#c7d2fe;--mint-bg:#f5f7fb;--white:#fff;--info-bg:#e7eeff;--muted:#64748b;--placeholder:#9aa7ae;--line:#d8dee8;--line-soft:#eaeef4;--slate-50:#f1f4f9;--font-display:"Sora", system-ui, sans-serif;--font-body:"Inter", -apple-system, system-ui, "Segoe UI", Roboto, sans-serif;--font-serif:Georgia, "Iowan Old Style", "Times New Roman", serif;--r-lg:14px;--r-md:10px;--r-sm:8px;--sh-sm:0 1px 3px #16223c14, 0 1px 2px #16223c0f;--sh-md:0 4px 6px -1px #16223c1a, 0 2px 4px -2px #16223c1a;--sh-lg:0 10px 15px -3px #16223c1f, 0 4px 6px -4px #16223c1a;--sh-cta:0 6px 16px -8px #2563eb80}*{box-sizing:border-box;margin:0;padding:0}body{min-height:100vh;font-family:var(--font-body);background:var(--mint-bg);color:var(--navy);padding:68px 24px 64px}.page{background:var(--white);border-radius:var(--r-lg);max-width:800px;box-shadow:var(--sh-lg);min-height:60vh;margin:0 auto;padding:72px 48px;overflow:visible}.block{border-radius:var(--r-md);flex-direction:column;align-items:flex-start;margin:0 16px;padding:6px;transition:background .12s;display:flex;position:relative}.block:hover,.block:focus-within{background:var(--slate-50)}.block .editor{width:fit-content;max-width:100%;color:inherit;white-space:pre-wrap;overflow-wrap:anywhere;background:0 0;border:none;outline:none;padding:0;font-family:inherit;line-height:1.7}.block .editor:empty:before{content:attr(data-placeholder);color:var(--placeholder);pointer-events:none}.block[data-type=h1]{margin-top:8px;margin-bottom:4px}.block[data-type=h2]{margin-top:40px;margin-bottom:8px}.block[data-type=h3]{margin-top:28px;margin-bottom:4px}.block[data-type=p]{margin-bottom:14px}.block[data-type=h1] .editor{font-family:var(--font-display);color:var(--navy);font-size:2.1rem;font-weight:800;line-height:1.2}.block[data-type=h2] .editor{font-family:var(--font-display);color:var(--navy);font-size:1.6rem;font-weight:700;line-height:1.3}.block[data-type=h3] .editor{font-family:var(--font-display);color:var(--navy);font-size:1.25rem;font-weight:700;line-height:1.35}.block[data-type=p] .editor{font-family:var(--font-serif);color:var(--navy);font-size:1rem;font-weight:400;line-height:1.7}.cite{vertical-align:super;color:var(--coral);background:var(--info-bg);border-radius:var(--r-sm);cursor:pointer;-webkit-user-select:none;user-select:none;font-variant-numeric:tabular-nums;margin:0 1px;padding:1px 3px;font-size:.68em;font-weight:600;line-height:1;transition:background .12s,color .12s;display:inline-block}.cite:before{content:"["}.cite:after{content:"]"}.cite:hover{background:var(--coral);color:var(--white)}.cite-popover{z-index:50;background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-lg);width:320px;max-width:calc(100vw - 24px);padding:8px;display:none;position:absolute}.cite-popover.open{display:block}.cite-popover label{letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:5px;font-size:.62rem;font-weight:600;display:block}.cite-popover input{border:1px solid var(--line);border-radius:var(--r-md);width:100%;font:inherit;color:var(--navy);outline:none;padding:7px 9px;font-size:.9rem}.cite-popover input:focus{border-color:var(--coral);box-shadow:0 0 0 3px var(--coral-soft)}.popover-list{border:1px solid var(--line);border-radius:var(--r-md);max-height:180px;margin-top:6px;list-style:none;display:none;overflow:hidden auto}.popover-list.open{display:block}.popover-item{cursor:pointer;color:var(--navy);white-space:nowrap;text-overflow:ellipsis;border-bottom:1px solid var(--line-soft);padding:7px 10px;font-size:.88rem;transition:background .1s;overflow:hidden}.popover-item:last-child{border-bottom:none}.popover-item:hover,.popover-item.selected{background:var(--info-bg);color:var(--coral)}.type-select{z-index:20;background:var(--white);border:1px solid var(--line-soft);border-radius:var(--r-md);box-shadow:var(--sh-sm);opacity:0;pointer-events:none;flex-direction:column;align-items:stretch;gap:1px;min-width:112px;padding:3px;transition:opacity .15s,transform .15s;display:flex;position:absolute;top:4px;right:calc(100% + 12px);transform:translate(4px)}.block:focus-within .type-select{opacity:1;pointer-events:auto;transform:translate(0)}.type-opt{color:var(--muted);font:inherit;letter-spacing:.02em;border-radius:var(--r-sm);cursor:pointer;text-align:left;white-space:nowrap;background:0 0;border:none;padding:5px 8px;font-size:.72rem;font-weight:500;line-height:1;transition:color .12s,background .12s}.type-opt:hover{color:var(--navy);background:var(--slate-50)}.type-opt.active{color:var(--navy);background:var(--sky);font-weight:600}.type-select .type-opt:not(.active):not(.cite-add){display:none}.type-select:hover .type-opt:not(.cite-add){display:block}.toc{width:240px;max-height:calc(100vh - 96px);color:var(--muted);padding:16px 14px;font-size:.85rem;position:fixed;top:48px;right:24px;overflow-y:auto;-webkit-mask-image:linear-gradient(#000 calc(100% - 24px),#0000);mask-image:linear-gradient(#000 calc(100% - 24px),#0000)}.toc-title{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding:0 6px 10px;font-size:.7rem;font-weight:600}.toc-item{text-align:left;width:100%;font:inherit;color:var(--muted);cursor:pointer;border-radius:var(--r-sm);background:0 0;border:none;border-left:2px solid #0000;align-items:baseline;gap:8px;padding:4px 6px;line-height:1.3;transition:background .12s,color .12s;display:flex}.toc-num{color:var(--muted);font-variant-numeric:tabular-nums;flex:none;font-weight:500}.toc-label{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.toc-item:hover{background:var(--slate-50);color:var(--navy)}.toc-item:hover .toc-num{color:var(--muted)}.toc-item.active{color:var(--navy);border-left-color:var(--coral);background:var(--slate-50);font-weight:600}.toc-item.active .toc-num{color:var(--navy)}.toc-item[data-level=h1]{color:var(--navy);padding-left:6px;font-weight:600}.toc-item[data-level=h2]{padding-left:16px}.toc-item[data-level=h3]{padding-left:28px;font-size:.8rem}.toc-item.empty .toc-label{color:var(--placeholder);font-style:italic}.toc-sources{margin-top:22px}.src-item{border-radius:var(--r-sm);border-left:2px solid #0000;align-items:baseline;gap:8px;padding:3px 6px;line-height:1.3;display:flex}.src-num{color:var(--coral);font-variant-numeric:tabular-nums;cursor:pointer;flex:none;font-weight:600}.src-input{min-width:0;font:inherit;color:var(--muted);background:0 0;border:none;outline:none;flex:1;padding:0;font-size:.82rem}.src-input::placeholder{color:var(--placeholder);font-style:italic}.src-item:focus-within{background:var(--slate-50);border-left-color:var(--coral)}.src-item.target{background:var(--info-bg);border-left-color:var(--coral)}.type-opt.cite-add{color:var(--coral);border-top:1px solid var(--line-soft);border-radius:0 0 var(--r-sm) var(--r-sm);margin-top:3px;padding-top:7px;font-weight:600}.type-opt.cite-add:hover{color:var(--white);background:var(--coral)}@media (width<=1320px){.toc{display:none}}@media (width<=920px){.page{padding:72px 20px}.block{margin:0 8px;padding:6px}}.user-bar{z-index:200;background:var(--white);border-bottom:1px solid var(--line-soft);height:44px;box-shadow:var(--sh-sm);align-items:center;gap:16px;padding:0 20px;display:flex;position:fixed;top:0;left:0;right:0}.user-bar-title{font-family:var(--font-display);color:var(--navy);letter-spacing:.02em;flex-shrink:0;font-size:.78rem;font-weight:600}.user-toggle{align-items:center;gap:6px;margin-left:auto;display:flex}.user-toggle-label{color:var(--muted);flex-shrink:0;font-size:.72rem}.toggle-btn{border:1.5px solid var(--line-soft);background:var(--slate-50);color:var(--muted);font-family:var(--font-body);cursor:pointer;border-radius:20px;align-items:center;gap:6px;padding:4px 10px;font-size:.72rem;font-weight:500;transition:all .15s;display:flex}.toggle-btn:hover{color:var(--navy);border-color:var(--line)}.toggle-btn.active{background:var(--info-bg);border-color:var(--coral);color:var(--navy);font-weight:600}.toggle-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;font-size:.65rem;font-weight:700;display:inline-flex}.toggle-avatar.student{background:var(--sky);color:var(--navy)}.toggle-avatar.professor{color:#991b1b;background:#fee2e2}.comment-panel{z-index:20;background:var(--white);border:1px solid var(--line-soft);border-radius:var(--r-md);width:230px;box-shadow:var(--sh-sm);opacity:0;pointer-events:none;flex-direction:column;gap:0;transition:opacity .15s,transform .15s;display:flex;position:absolute;top:0;left:calc(100% + 14px);overflow:hidden;transform:translate(-4px)}.comment-panel.has-comments,.block:focus-within .comment-panel{opacity:1;pointer-events:auto;transform:translate(0)}.comment-panel-header{background:var(--slate-50);border-bottom:1px solid var(--line-soft);align-items:center;gap:5px;padding:6px 10px;display:flex}.comment-icon{font-size:.85rem}.comment-count{color:var(--muted);font-size:.7rem;font-weight:600}.comment-thread{flex-direction:column;gap:6px;max-height:220px;padding:8px;display:flex;overflow-y:auto}.comment-thread::-webkit-scrollbar{width:4px}.comment-thread::-webkit-scrollbar-track{background:0 0}.comment-thread::-webkit-scrollbar-thumb{background:var(--line);border-radius:2px}.bubble-row{display:flex}.bubble-row.mine{justify-content:flex-end}.bubble{background:var(--slate-50);border:1px solid var(--line-soft);border-radius:var(--r-sm);flex-direction:column;gap:2px;max-width:85%;padding:5px 8px;display:flex}.bubble.mine{background:var(--info-bg);border-color:var(--sky)}.bubble-author{color:var(--muted);font-size:.62rem;font-weight:700;line-height:1}.bubble.mine .bubble-author{color:var(--coral)}.bubble-text{color:var(--navy);word-break:break-word;font-size:.72rem;line-height:1.4}.bubble-time{color:var(--placeholder);text-align:right;font-size:.6rem;line-height:1}.comment-input-row{border-top:1px solid var(--line-soft);align-items:center;gap:4px;padding:6px 8px;display:flex}.comment-input{border:1px solid var(--line-soft);border-radius:var(--r-sm);font-family:var(--font-body);color:var(--navy);background:var(--white);outline:none;flex:1;padding:4px 8px;font-size:.72rem;transition:border-color .15s}.comment-input::placeholder{color:var(--placeholder)}.comment-input:focus{border-color:var(--coral)}.comment-send{background:var(--coral);width:26px;height:26px;color:var(--white);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;transition:background .15s,opacity .15s;display:flex}.comment-send:hover{background:var(--coral-hover)}.comment-send:disabled{background:var(--line);cursor:default;opacity:.6}
