@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@400;500&family=Fraunces:ital,opsz,wght@0,9..144,700;1,9..144,400&display=swap";pre code.hljs{padding:1em;display:block;overflow-x:auto}code.hljs{padding:3px 5px}.hljs{color:#24292e;background:#fff}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#d73a49}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#6f42c1}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#005cc5}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#032f62}.hljs-built_in,.hljs-symbol{color:#e36209}.hljs-comment,.hljs-code,.hljs-formula{color:#6a737d}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#22863a}.hljs-subst{color:#24292e}.hljs-section{color:#005cc5;font-weight:700}.hljs-bullet{color:#735c0f}.hljs-emphasis{color:#24292e;font-style:italic}.hljs-strong{color:#24292e;font-weight:700}.hljs-addition{color:#22863a;background-color:#f0fff4}.hljs-deletion{color:#b31d28;background-color:#ffeef0}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f5f6f8;--surface:#fff;--border:#e2e5eb;--accent:#2563eb;--accent-dim:#dbeafe;--text:#1a1d27;--muted:#7a8099;--code-bg:#f0f2f5;--green:#16a34a;--green-dim:#dcfce7;--radius:10px;--sidebar-w:270px;--toc-w:220px}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:Inter,sans-serif;font-size:15px;line-height:1.6}.auth-wrap{background:radial-gradient(ellipse at 60% 30%, #dbeafe 0%, var(--bg) 65%);justify-content:center;align-items:center;min-height:100vh;display:flex}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:360px;padding:44px 40px 40px;box-shadow:0 24px 60px #0000001a}.auth-logo{color:var(--accent);letter-spacing:-.3px;margin-bottom:6px;font-family:Fraunces,serif;font-size:22px}.auth-sub{color:var(--muted);margin-bottom:32px;font-size:13px}.auth-card label{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;font-size:12px;font-weight:500;display:block}.auth-card input{background:var(--code-bg);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);outline:none;margin-bottom:18px;padding:10px 14px;font-family:inherit;font-size:14px;transition:border-color .15s}.auth-card input:focus{border-color:var(--accent)}.auth-btn{background:var(--accent);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;width:100%;margin-top:4px;padding:11px;font-size:14px;font-weight:600;transition:opacity .15s}.auth-btn:hover{opacity:.88}.auth-error{color:#ef4444;text-align:center;margin-top:12px;font-size:13px}.mobile-bar{display:none}.app{height:100vh;display:flex;overflow:hidden}.overlay{display:none}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);flex-direction:column;transition:width .2s,min-width .2s,opacity .15s;display:flex;overflow:hidden}.sidebar.desktop-collapsed{opacity:0;pointer-events:none;border-right:none;width:0;min-width:0}.sidebar-header{border-bottom:1px solid var(--border);padding:18px 44px 16px 20px;position:relative}.sidebar-logo{color:var(--accent);font-family:Fraunces,serif;font-size:18px}.sidebar-tagline{color:var(--muted);margin-top:2px;font-size:11px}.brand-subtitle{color:var(--muted);margin-top:3px;font-size:11px;line-height:1.4}.sidebar-collapse-btn{border:1px solid var(--border);background:var(--bg);width:26px;height:26px;color:var(--muted);cursor:pointer;border-radius:7px;justify-content:center;align-items:center;font-size:14px;display:none;position:absolute;top:14px;right:14px}.sidebar-collapse-btn:hover{color:var(--accent);border-color:var(--accent)}.sidebar-reveal{z-index:50;background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:8px;flex-direction:column;gap:4px;padding:9px;display:none;position:fixed;top:16px;left:16px;box-shadow:0 4px 16px #0000001a}.sidebar-reveal span{background:var(--text);border-radius:2px;width:16px;height:2px;display:block}.sidebar-reveal:hover{border-color:var(--accent)}.progress-wrap{border-bottom:1px solid var(--border);padding:14px 16px 12px}.progress-label{color:var(--muted);justify-content:space-between;margin-bottom:7px;font-size:11px;font-weight:500;display:flex}.progress-track{background:var(--border);border-radius:99px;height:5px;overflow:hidden}.progress-fill{background:var(--green);border-radius:99px;height:100%;transition:width .4s}.sidebar-section{color:var(--muted);text-transform:uppercase;letter-spacing:.1em;padding:14px 12px 6px;font-size:10px;font-weight:600}.file-list{flex:1;padding:0 8px 12px;overflow-y:auto}.file-item{border-radius:var(--radius);color:var(--muted);align-items:center;gap:6px;padding:4px 8px;font-size:13px;transition:background .12s;display:flex}.file-item:hover{background:var(--border);color:var(--text)}.file-item.active{background:var(--accent-dim);color:var(--accent)}.file-select{cursor:pointer;text-align:left;color:inherit;background:0 0;border:none;flex:1;min-width:0;padding:5px 4px;font-size:13px}.file-item.active .file-select{font-weight:500}.file-name{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.read-circle{border:1.5px solid var(--border);cursor:pointer;color:#0000;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:11px;font-weight:700;transition:all .15s;display:flex}.read-circle:hover{border-color:var(--green);color:var(--green)}.read-circle.done{background:var(--green);border-color:var(--green);color:#fff}.mark-read-wrap{border-top:1px solid var(--border);justify-content:center;margin-top:48px;padding-top:24px;display:flex}.mark-read-btn{cursor:pointer;border:1.5px solid var(--border);color:var(--muted);background:0 0;border-radius:99px;padding:10px 28px;font-size:14px;font-weight:500;transition:all .15s}.mark-read-btn:hover{border-color:var(--green);color:var(--green)}.mark-read-btn.done{background:var(--green);border-color:var(--green);color:#fff}.sidebar-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 12px;display:flex}.user-info{color:var(--muted);font-size:12px}.user-name{color:var(--text);font-size:13px;font-weight:500}.logout-btn{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:6px;padding:5px 10px;font-size:11px;transition:all .12s}.logout-btn:hover{border-color:var(--muted);color:var(--text)}.main{flex-direction:column;flex:1;display:flex;overflow-y:auto}.empty-state{color:var(--muted);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:40px;display:flex}.empty-state .big-icon{opacity:.4;font-size:48px}.empty-state h2{color:var(--text);font-size:18px;font-weight:500}.empty-state p{max-width:300px;font-size:14px;line-height:1.6}.back-btn{background:var(--accent);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;margin-top:8px;padding:9px 18px;font-size:13px;font-weight:500}.back-btn:hover{opacity:.88}.doc-layout{gap:0;min-height:100%;display:flex}.doc-column{flex-direction:column;flex:1;min-width:0;display:flex}.doc-header{border-bottom:1px solid var(--border);background:var(--bg);z-index:10;padding:24px 48px 16px;position:sticky;top:0}.doc-title{margin-bottom:8px;font-family:Fraunces,serif;font-size:22px;font-weight:700}.doc-meta{align-items:center;gap:8px;display:flex}.meta-badge{background:var(--accent-dim);color:var(--accent);border-radius:20px;padding:3px 9px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:500}.read-badge{background:var(--green-dim)!important;color:var(--green)!important}.doc-content{padding:32px 48px 80px}.toc-column{width:var(--toc-w);min-width:var(--toc-w);padding:24px 20px 40px 0}.toc{position:sticky;top:24px}.toc-header{color:var(--muted);text-transform:uppercase;letter-spacing:.1em;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:10px;font-weight:600;display:flex}.toc-close{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:14px}.toc ul{list-style:none}.toc-item a{color:var(--muted);border-left:2px solid var(--border);padding:4px 0;font-size:12px;line-height:1.4;text-decoration:none;transition:all .12s;display:block}.toc-item a:hover{color:var(--accent);border-color:var(--accent)}.toc-h1 a{color:var(--text);padding-left:10px;font-weight:500}.toc-h2 a{padding-left:10px}.toc-h3 a{padding-left:22px;font-size:11px}.toc-drawer,.toc-toggle{display:none}.md h1,.md h2,.md h3,.md h4{color:var(--text);font-family:Fraunces,serif;font-weight:700;line-height:1.25}.md h1{margin:0 0 24px;font-size:2em}.md h2{border-bottom:1px solid var(--border);margin:40px 0 14px;padding-bottom:8px;font-size:1.45em}.md h3{margin:28px 0 10px;font-size:1.15em}.md h4{color:var(--muted);margin:20px 0 8px;font-size:1em}.md p{margin-bottom:16px}.md ul,.md ol{margin:0 0 16px 22px}.md li{margin-bottom:6px}.md a{color:var(--accent);text-decoration:none}.md a:hover{text-decoration:underline}.md strong{color:var(--text);font-weight:600}.md em{color:var(--muted);font-style:italic}.md blockquote{border-left:3px solid var(--accent);background:var(--surface);border-radius:0 var(--radius) var(--radius) 0;color:var(--muted);margin:20px 0;padding:12px 20px}.md hr{border:none;border-top:1px solid var(--border);margin:32px 0}.md img{border-radius:var(--radius);max-width:100%;margin:16px 0}.md code{background:var(--code-bg);color:#b45309;border-radius:4px;padding:2px 6px;font-family:JetBrains Mono,monospace;font-size:.85em}.md pre{border:1px solid var(--border);border-radius:var(--radius);margin:20px 0;padding:20px;position:relative;overflow-x:auto;background:var(--code-bg)!important}.md pre code{color:inherit;background:0 0;padding:0;font-size:.84em;line-height:1.7}.md table{border-collapse:collapse;width:100%;margin:20px 0;font-size:14px;display:block;overflow-x:auto}.md th{background:var(--surface);text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);border-bottom:2px solid var(--border);padding:10px 14px;font-size:12px;font-weight:600}.md td{border-bottom:1px solid var(--border);padding:10px 14px}.md tr:last-child td{border-bottom:none}.code-wrapper{position:relative}.copy-btn{background:var(--border);color:var(--muted);cursor:pointer;opacity:0;border:none;border-radius:6px;padding:4px 10px;font-family:Inter,sans-serif;font-size:11px;font-weight:500;transition:all .12s;position:absolute;top:10px;right:10px}.code-wrapper:hover .copy-btn{opacity:1}.copy-btn:hover{background:var(--accent);color:#fff}.copy-btn.copied{background:var(--green);color:#fff;opacity:1}.loading{height:200px;color:var(--muted);justify-content:center;align-items:center;gap:10px;font-size:14px;display:flex}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}@media (width>=769px){.sidebar-collapse-btn,.sidebar-reveal{display:flex}.app.sidebar-is-collapsed .doc-header,.app.sidebar-is-collapsed .doc-content,.app.sidebar-is-collapsed .empty-state{padding-left:64px}}@media (width<=768px){.mobile-bar{background:var(--surface);border-bottom:1px solid var(--border);z-index:100;align-items:center;gap:12px;height:56px;min-height:56px;padding:0 16px;display:flex;position:sticky;top:0}.mobile-brand{flex:1;min-width:0}.mobile-logo{color:var(--accent);font-family:Fraunces,serif;font-size:14px;line-height:1.2}.mobile-subtitle{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;margin-top:1px;font-size:10px;overflow:hidden}.hamburger{cursor:pointer;background:0 0;border:none;flex-direction:column;gap:4px;padding:4px;display:flex}.hamburger span{background:var(--text);border-radius:2px;width:20px;height:2px;display:block}.toc-toggle{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:6px;padding:4px 10px;font-size:16px}.overlay{z-index:150;background:#0000004d;display:block;position:fixed;inset:0}.app{flex-direction:column;height:auto;min-height:100vh;overflow:auto}.sidebar{z-index:200;width:80vw;max-width:300px;min-width:unset;opacity:1;pointer-events:auto;transition:transform .25s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%);box-shadow:4px 0 24px #0000001f}.sidebar.open{transform:translate(0)}.sidebar.desktop-collapsed{width:80vw;max-width:300px;min-width:unset;border-right:1px solid var(--border)}.main{flex:1;overflow:visible}.doc-layout{flex-direction:column}.toc-column{display:none}.doc-header{padding:20px 20px 14px;position:static}.doc-content{padding:20px 20px 60px}.toc-drawer{z-index:200;background:var(--surface);border-top:1px solid var(--border);border-radius:16px 16px 0 0;max-height:60vh;padding:20px;display:block;position:fixed;bottom:0;left:0;right:0;overflow-y:auto;box-shadow:0 -8px 32px #0000001f}.toc-drawer .toc{position:static}.auth-card{width:calc(100vw - 40px);padding:32px 24px}}.category{margin-bottom:4px}.category-header{cursor:pointer;border-radius:var(--radius);width:100%;color:var(--text);background:0 0;border:none;align-items:center;gap:7px;padding:7px 12px;transition:background .12s;display:flex}.category-header:hover{background:var(--border)}.category-icon{flex-shrink:0;font-size:13px}.category-name{text-transform:uppercase;letter-spacing:.07em;color:var(--muted);text-align:left;flex:1;font-size:11px;font-weight:600}.category-count{color:var(--muted);font-family:JetBrains Mono,monospace;font-size:10px}.category-chevron{color:var(--muted);font-size:14px;transition:transform .2s;display:inline-block;transform:rotate(0)}.category-chevron.open{transform:rotate(90deg)}.category-files{margin-bottom:4px;padding-left:8px}.empty-category{color:var(--muted);padding:6px 12px;font-size:12px;font-style:italic}.doc-category{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:6px;font-size:11px;font-weight:600}.courses-screen{background:var(--bg);min-height:100vh}.courses-topbar{border-bottom:1px solid var(--border);background:var(--surface);justify-content:space-between;align-items:center;padding:18px 40px;display:flex}.brand-block{flex-direction:column;display:flex}.courses-user{align-items:center;gap:12px;display:flex}.courses-hero{text-align:center;padding:48px 40px 28px}.courses-hero h1{margin-bottom:8px;font-family:Fraunces,serif;font-size:32px;font-weight:700}.courses-hero p{color:var(--muted);font-size:15px}.courses-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;max-width:1100px;margin:0 auto;padding:0 40px 60px;display:grid}.course-card{background:var(--surface);border:1px solid var(--border);text-align:left;cursor:pointer;border-radius:16px;flex-direction:column;gap:10px;padding:28px 24px;transition:all .15s;display:flex}.course-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 12px 28px #00000012}.course-card-icon{font-size:30px}.course-card-title{color:var(--text);font-family:Fraunces,serif;font-size:17px;font-weight:700;line-height:1.35}.course-card-desc{color:var(--muted);flex:1;font-size:13px;line-height:1.5}.course-card-footer{flex-direction:column;gap:6px;margin-top:8px;display:flex}.course-card-progress{color:var(--muted);font-family:JetBrains Mono,monospace;font-size:11px}.back-to-courses{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:0 0 8px;font-size:12px;font-weight:500;display:block}.back-to-courses:hover{color:var(--accent)}.course-name-clamp{-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:15px;line-height:1.3;display:-webkit-box;overflow:hidden}@media (width<=768px){.courses-topbar{padding:14px 18px}.courses-hero{padding:32px 20px 20px}.courses-hero h1{font-size:24px}.courses-grid{grid-template-columns:1fr;gap:14px;padding:0 18px 40px}}.course-card.locked{opacity:.6;cursor:not-allowed}.course-card.locked:hover{box-shadow:none;border-color:var(--border);transform:none}.lock-badge{color:var(--muted);background:var(--code-bg);vertical-align:middle;border-radius:20px;margin-left:8px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}.file-item.locked{opacity:.55}.file-item.locked .file-select{cursor:not-allowed}.lock-icon{margin-right:5px;font-size:11px}.auth-btn:disabled{opacity:.6;cursor:not-allowed}.google-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;width:100%;color:var(--text);justify-content:center;align-items:center;gap:10px;padding:11px 16px;font-family:Inter,sans-serif;font-size:14px;font-weight:500;transition:all .15s;display:flex}.google-btn:hover{border-color:var(--accent);background:var(--accent-dim)}.google-btn:disabled{opacity:.6;cursor:not-allowed}.auth-divider{color:var(--muted);align-items:center;gap:12px;margin:20px 0;font-size:12px;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-link{width:100%;color:var(--muted);cursor:pointer;text-align:center;background:0 0;border:none;padding:4px;font-family:Inter,sans-serif;font-size:13px}.auth-link:hover{color:var(--accent)}.admin-wrap{background:var(--bg);min-height:100vh}.admin-topbar{background:var(--surface);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 32px;display:flex}.admin-tabs{border-bottom:1px solid var(--border);background:var(--surface);gap:4px;padding:16px 32px 0;display:flex}.admin-tab{color:var(--muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 20px;font-family:Inter,sans-serif;font-size:14px;font-weight:500;transition:all .12s}.admin-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.admin-tab:hover:not(.active){color:var(--text)}.admin-body{max-width:1100px;padding:28px 32px}.admin-section-header{align-items:center;gap:12px;margin-bottom:20px;display:flex}.admin-section-header h2{font-size:18px;font-weight:600}.admin-count{color:var(--muted);background:var(--code-bg);border-radius:20px;padding:2px 8px;font-size:12px;font-weight:500}.admin-loading{text-align:center;color:var(--muted);padding:40px;font-size:14px}.admin-table-wrap{border:1px solid var(--border);border-radius:var(--radius);overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:13px}.admin-table th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);background:var(--surface);border-bottom:1px solid var(--border);padding:10px 14px;font-size:11px;font-weight:600}.admin-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:12px 14px}.admin-table tr:last-child td{border-bottom:none}.admin-table tr.row-inactive td{opacity:.5}.expand-row td{background:var(--bg);padding:0!important}.enroll-panel{flex-direction:column;gap:10px;padding:16px 20px;display:flex}.enroll-panel-title{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;font-size:12px;font-weight:600}.enroll-row{border-top:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:10px;padding:8px 0;display:flex}.enroll-course-title{font-size:13px;font-weight:500}.admin-inline-input{color:var(--text);background:0 0;border:none;border-bottom:1px solid #0000;outline:none;width:100px;padding:2px 4px;font-family:Inter,sans-serif;font-size:13px;transition:border-color .12s}.admin-inline-input:focus{border-bottom-color:var(--accent)}.admin-inline-input::placeholder{color:var(--muted)}.admin-btn{cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text);white-space:nowrap;border-radius:6px;padding:6px 12px;font-family:Inter,sans-serif;font-size:12px;font-weight:500;transition:all .12s}.admin-btn:hover{border-color:var(--accent);color:var(--accent)}.admin-btn:disabled{opacity:.5;cursor:not-allowed}.admin-btn-sm{padding:4px 9px;font-size:11px}.admin-btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.admin-btn-primary:hover{opacity:.88;color:#fff}.admin-btn-danger{color:#dc2626;border-color:#fca5a5}.admin-btn-danger:hover{background:#fee2e2}.admin-btn-ghost{color:var(--muted);background:0 0;border-color:#0000}.admin-btn-ghost:hover{background:var(--border);color:var(--text);border-color:#0000}.admin-expand-btn{border:1px solid var(--border);color:var(--muted);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;padding:4px 9px;font-family:Inter,sans-serif;font-size:11px}.admin-expand-btn:hover{border-color:var(--accent);color:var(--accent)}.content-cards{flex-direction:column;gap:14px;display:flex}.content-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}.content-card-header{align-items:center;gap:14px;padding:18px 20px;display:flex}.content-card-icon{flex-shrink:0;font-size:24px}.content-card-title{font-size:15px;font-weight:600}.tier-toggle{border:1px solid var(--border);border-radius:6px;display:flex;overflow:hidden}.tier-btn{cursor:pointer;color:var(--muted);background:0 0;border:none;padding:4px 12px;font-family:Inter,sans-serif;font-size:12px;font-weight:500;transition:all .12s}.tier-btn.active{background:var(--green);color:#fff}.tier-btn.paid.active{background:var(--accent)}.tier-btn:disabled{opacity:.5;cursor:not-allowed}.content-categories{border-top:1px solid var(--border);padding:4px 0}.content-category-row{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:12px;padding:10px 20px;font-size:13px;display:flex}.content-category-row:last-child{border-bottom:none}.admin-nav-btn{background:var(--code-bg);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:6px;padding:6px 14px;font-family:Inter,sans-serif;font-size:13px;font-weight:500;transition:all .12s}.admin-nav-btn:hover{border-color:var(--accent);color:var(--accent)}@media (width<=768px){.admin-topbar,.admin-body{padding:14px 16px}.admin-tabs{padding:12px 16px 0}.enroll-row{flex-direction:column;align-items:flex-start}.content-card-header{flex-wrap:wrap}}.modal-backdrop{z-index:500;background:#0006;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;max-width:420px;box-shadow:0 24px 60px #00000026}.modal-header{justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.modal-header h3{font-size:16px;font-weight:600}.modal-close{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:4px;font-size:16px;line-height:1}.modal-close:hover{color:var(--text)}.modal-field{padding:0 24px 14px}.modal-field label{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;font-size:12px;font-weight:500;display:block}.modal-field input{background:var(--code-bg);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);outline:none;padding:9px 12px;font-family:Inter,sans-serif;font-size:14px;transition:border-color .15s}.modal-field input:focus{border-color:var(--accent)}.modal-field-row{justify-content:space-between;align-items:center;display:flex}.modal-field-row label{margin-bottom:0}.modal-error{color:#dc2626;margin:0 24px 12px;font-size:13px}.modal-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:16px 24px;display:flex}.selection-comment-btn{z-index:100;background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:20px;padding:4px 10px;font-size:13px;transition:transform .1s;position:absolute;transform:translate(-50%);box-shadow:0 4px 12px #00000026}.selection-comment-btn:hover{transform:translate(-50%)scale(1.08)}.comment-popover-backdrop{z-index:300;background:#0003;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.comment-popover{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:100%;max-width:380px;padding:16px;box-shadow:0 12px 40px #00000026}.comment-popover-quote{color:var(--muted);border-left:3px solid var(--accent);margin-bottom:12px;padding-left:10px;font-size:12px;font-style:italic;line-height:1.5}.comment-textarea{border:1px solid var(--border);width:100%;color:var(--text);background:var(--code-bg);resize:vertical;border-radius:8px;outline:none;padding:10px 12px;font-family:Inter,sans-serif;font-size:14px;transition:border-color .15s}.comment-textarea:focus{border-color:var(--accent)}.comment-textarea.small{font-size:13px}.comment-popover-actions{justify-content:flex-end;gap:8px;margin-top:10px;display:flex}.comment-submit-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:7px 16px;font-family:Inter,sans-serif;font-size:13px;font-weight:500}.comment-submit-btn:disabled{opacity:.5;cursor:not-allowed}.comment-cancel-btn{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:6px;padding:7px 14px;font-family:Inter,sans-serif;font-size:13px}.comment-cancel-btn:hover{color:var(--text)}.comments-panel{opacity:0;border-left:1px solid #0000;flex-direction:column;width:0;min-width:0;transition:width .2s,min-width .2s,opacity .15s;display:flex;overflow:hidden}.comments-panel.open{opacity:1;border-left-color:var(--border);width:300px;min-width:300px}.comments-panel-header{border-bottom:1px solid var(--border);background:var(--bg);z-index:10;justify-content:space-between;align-items:center;padding:16px 16px 12px;font-size:13px;font-weight:600;display:flex;position:sticky;top:0}.comment-count{background:var(--accent-dim);color:var(--accent);border-radius:20px;margin-left:6px;padding:1px 7px;font-size:11px}.comments-close-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:2px;font-size:14px}.comments-close-btn:hover{color:var(--text)}.comments-panel-body{flex:1;padding:12px;overflow-y:auto}.comments-empty{text-align:center;color:var(--muted);padding:32px 0;font-size:13px}.comment-thread{border:1px solid var(--border);border-radius:10px;margin-bottom:10px;transition:border-color .15s;overflow:hidden}.comment-thread.highlighted{border-color:var(--accent)}.comment-thread.resolved{opacity:.6}.comment-quote{color:var(--muted);background:var(--code-bg);border-bottom:1px solid var(--border);padding:8px 12px;font-size:11px;font-style:italic;line-height:1.5}.comment-message,.comment-reply{border-bottom:1px solid var(--border);padding:10px 12px}.comment-reply{background:var(--bg)}.comment-message:last-child,.comment-reply:last-child{border-bottom:none}.comment-meta{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:5px;display:flex}.comment-author{color:var(--text);font-size:12px;font-weight:600}.comment-time{color:var(--muted);font-size:11px}.comment-body{white-space:pre-wrap;font-size:13px;line-height:1.5}.comment-action-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-family:Inter,sans-serif;font-size:11px}.comment-action-btn:hover{background:var(--border);color:var(--text)}.comment-action-btn.danger:hover{color:#dc2626;background:#fee2e2}.reply-form{border-top:1px solid var(--border);padding:10px 12px}.reply-trigger{text-align:left;width:100%;color:var(--muted);cursor:pointer;border:none;border-top:1px solid var(--border);background:0 0;padding:8px 12px;font-family:Inter,sans-serif;font-size:12px;display:block}.reply-trigger:hover{color:var(--accent);background:var(--accent-dim)}.resolved-section summary{color:var(--muted);cursor:pointer;padding:8px 4px;font-size:12px;font-weight:500}mark.comment-highlight{color:inherit;background:#fef08a;border-radius:2px;padding:0 1px}.comments-toggle-badge{cursor:pointer;border:none;font-family:Inter,sans-serif;transition:all .12s}.comments-toggle-badge.active{background:var(--accent-dim)!important;color:var(--accent)!important}.comments-toggle-badge:hover{opacity:.8}@media (width<=768px){.comments-panel.open{z-index:200;background:var(--bg);position:fixed;top:0;bottom:0;right:0;box-shadow:-8px 0 32px #0000001f;width:85vw!important;min-width:unset!important}}.content-category-section{border-bottom:1px solid var(--border)}.content-category-section:last-child{border-bottom:none}.content-note-row{border-top:1px solid var(--border);background:var(--bg);align-items:center;gap:10px;padding:8px 20px 8px 36px;font-size:12px;display:flex}.content-note-icon{flex-shrink:0;font-size:13px}.content-note-title{color:var(--muted);flex:1}.tier-btn.draft.active{background:var(--border);color:var(--text)}.draft-icon{margin-right:4px;font-size:11px}
