.vb-practice{--bg:#0d0f12;--bg-elev:#14171c;--bg-elev-2:#1a1e24;--line:#1f242c;--line-strong:#2a313b;--ink:#e8ecf1;--ink-dim:#9aa3b0;--ink-faint:#5d6675;--accent:#d97757;--accent-2:#6ea8ff;--accent-soft:#d977571f;--accent-line:#d977574d;--ok:#7dd3a0;--warn:#e6b25c;--err:#e88080;--code-bg:#0a0c0f;--chip-bg:#1a1e24;--vb-mono:var(--font-jetbrains-mono),ui-monospace,"SF Mono",Menlo,monospace;--vb-sans:var(--font-inter),-apple-system,BlinkMacSystemFont,system-ui,sans-serif;--mono:var(--vb-mono);--sans:var(--vb-sans);background:var(--bg);color:var(--ink);font-family:var(--vb-sans);font-feature-settings:"ss01","cv11";-webkit-font-smoothing:antialiased}.vb-practice h1,.vb-practice h2,.vb-practice h3{font-family:var(--vb-sans);letter-spacing:-.015em;font-weight:600}.vb-practice code,.vb-practice pre{font-family:var(--vb-mono)}.vb-practice ::selection{background:var(--accent-soft);color:var(--ink)}.vb-practice ::-webkit-scrollbar{width:8px;height:8px}.vb-practice ::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:4px}.vb-practice ::-webkit-scrollbar-track{background:0 0}.vb-practice .code-inline{font-family:var(--vb-mono);background:var(--code-bg);border:1px solid var(--line);color:#e89a7d;border-radius:4px;padding:1px 6px;font-size:.86em}.vb-practice .vb-header{border-bottom:1px solid var(--line);background:var(--bg-elev);flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;height:44px;padding:0 14px;display:flex}.vb-practice .vb-header-left{align-items:center;min-width:0;display:flex}.vb-practice .vb-header-right{justify-content:flex-end;align-items:center;gap:6px;display:flex}.vb-practice .vb-crumbs{font-family:var(--vb-mono);color:var(--ink-faint);align-items:center;gap:6px;min-width:0;font-size:12px;display:flex}.vb-practice .vb-crumb{color:var(--ink-faint);white-space:nowrap;text-overflow:ellipsis;text-decoration:none;transition:color .12s;overflow:hidden}.vb-practice .vb-crumb:hover{color:var(--ink-dim)}.vb-practice .vb-crumb.is-current{color:var(--ink)}.vb-practice .vb-crumb-sep{opacity:.5}.vb-practice .vb-pill-beta{font-family:var(--vb-mono);letter-spacing:.12em;background:var(--accent-soft);color:var(--accent);border-radius:3px;margin-left:6px;padding:2px 5px;font-size:9px}.vb-practice .vb-stat{background:var(--bg);border:1px solid var(--line);height:26px;font-family:var(--vb-mono);color:var(--ink-dim);border-radius:5px;align-items:center;gap:6px;padding:0 10px;font-size:10.5px;text-decoration:none;display:inline-flex}.vb-practice .vb-stat-link:hover{border-color:var(--line-strong);color:var(--ink)}.vb-practice .vb-stat-dot{border-radius:50%;width:6px;height:6px;box-shadow:0 0 5px}.vb-practice .vb-stat-bar{background:var(--line);border-radius:2px;width:60px;height:3px;overflow:hidden}.vb-practice .vb-stat-bar>span{background:var(--accent);height:100%;display:block}.vb-practice .vb-iconbtn{width:28px;height:28px;color:var(--ink-faint);cursor:pointer;background:0 0;border:0;border-radius:5px;justify-content:center;align-items:center;transition:background .12s,color .12s;display:inline-flex}.vb-practice .vb-iconbtn:hover{background:var(--bg);color:var(--ink)}.vb-practice .vb-header-divider{background:var(--line);width:1px;height:18px;margin:0 4px}.vb-practice .vb-prevnext{height:28px;font-family:var(--vb-mono);color:var(--ink-dim);background:var(--bg);border:1px solid var(--line);cursor:pointer;border-radius:5px;align-items:center;gap:6px;padding:0 10px;font-size:11px;text-decoration:none;display:inline-flex}.vb-practice .vb-prevnext:hover{color:var(--ink);border-color:var(--line-strong)}.vb-practice .vb-prevnext.is-primary{background:var(--accent-soft);border-color:var(--accent-line);color:var(--accent)}.vb-practice .vb-prevnext.is-primary:hover{background:#d9775733}.vb-practice .vb-prevnext.is-disabled{opacity:.4;pointer-events:none;cursor:not-allowed}@media (max-width:768px){.vb-practice .vb-stat,.vb-practice .vb-header-divider,.vb-practice .vb-prevnext span{display:none}}.vb-practice .vb-body{flex:1;min-height:0;display:flex}.vb-practice .vb-body-main{flex-direction:column;flex:1;min-width:0;min-height:0;display:flex}.vb-practice .vb-rail{background:var(--bg-elev);border-right:1px solid var(--line);flex-direction:column;flex-shrink:0;align-items:center;width:44px;padding:8px 0;display:flex}.vb-practice .vb-rail-brand{border-bottom:1px solid var(--line);justify-content:center;width:100%;margin-bottom:8px;padding:4px 0 12px;display:flex}.vb-practice .vb-rail-mark{background:var(--accent);color:#14110d;width:26px;height:26px;font-family:var(--vb-mono);border-radius:6px;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex;box-shadow:0 0 12px #d977574d}.vb-practice .vb-rail-items{flex-direction:column;flex:1;align-items:center;gap:2px;width:100%;display:flex}.vb-practice .vb-rail-foot{border-top:1px solid var(--line);justify-content:center;width:100%;padding-top:8px;display:flex}.vb-practice .vb-rail-btn{width:30px;height:30px;color:var(--ink-faint);cursor:pointer;background:0 0;border:0;border-radius:6px;justify-content:center;align-items:center;transition:background .12s,color .12s;display:flex;position:relative}.vb-practice .vb-rail-btn:hover{background:var(--bg);color:var(--ink)}.vb-practice .vb-rail-btn.is-active{color:var(--accent);background:var(--bg)}.vb-practice .vb-rail-btn.is-active:before{content:"";background:var(--accent);border-radius:0 1px 1px 0;width:2px;position:absolute;top:6px;bottom:6px;left:-7px}.vb-practice .vb-rail-avatar{background:linear-gradient(135deg,var(--accent),#b85a3d);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;font-weight:600;display:flex}@media (max-width:768px){.vb-practice .vb-rail{display:none}}.vb-practice .vb-cols{flex:1;grid-template-columns:minmax(360px,460px) 1fr 230px;width:100%;min-width:0;height:100%;min-height:0;display:grid}.vb-practice .vb-desc{border-right:1px solid var(--line);background:var(--bg);flex-direction:column;min-width:0;min-height:0;display:flex;overflow:hidden}.vb-practice .vb-editor-stack{background:var(--bg);border-right:1px solid var(--line);flex-direction:column;min-width:0;min-height:0;display:flex;overflow:hidden}.vb-practice .vb-context{background:var(--bg-elev);flex-direction:column;gap:22px;min-height:0;padding:16px 14px;display:flex;overflow-y:auto}.vb-practice .vb-ctx-section{flex-direction:column;gap:7px;display:flex}.vb-practice .vb-ctx-head{font-family:var(--vb-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:2px;font-size:9.5px}.vb-practice .vb-progress-list{flex-direction:column;gap:1px;display:flex}.vb-practice .vb-prog-item{font-family:var(--vb-mono);color:var(--ink-faint);border-radius:4px;align-items:center;gap:8px;padding:5px 6px;font-size:11px;text-decoration:none;transition:background .12s,color .12s;display:flex}.vb-practice .vb-prog-item:hover{background:var(--bg);color:var(--ink-dim)}.vb-practice .vb-prog-item.is-done{color:var(--ink-dim)}.vb-practice .vb-prog-item.is-done>span:nth-child(2){text-decoration:line-through}.vb-practice .vb-prog-item.is-current{color:var(--ink);background:var(--bg);font-weight:500}.vb-practice .vb-prog-icon{width:13px;color:var(--ink-faint);flex-shrink:0;justify-content:center;align-items:center;display:flex}.vb-practice .vb-prog-item.is-done .vb-prog-icon{color:var(--ok)}.vb-practice .vb-prog-pulse{background:var(--accent);border-radius:50%;width:7px;height:7px;animation:1.6s infinite vb-pulse;display:block;box-shadow:0 0 #d9775799}@keyframes vb-pulse{0%{box-shadow:0 0 #d9775780}70%{box-shadow:0 0 0 6px #d9775700}to{box-shadow:0 0 #d9775700}}.vb-practice .vb-test-row{font-family:var(--vb-mono);align-items:center;gap:8px;padding:6px 0;font-size:11px;display:flex}.vb-practice .vb-test-dot{border:1.3px solid var(--line-strong);border-radius:50%;flex-shrink:0;width:8px;height:8px}.vb-practice .vb-test-name{color:var(--ink-dim);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.vb-practice .vb-test-status{color:var(--ink-faint);font-size:10px}.vb-practice .vb-stats-grid{grid-template-columns:repeat(3,1fr);gap:6px;display:grid}.vb-practice .vb-stats-grid>div{background:var(--bg);border:1px solid var(--line);text-align:center;border-radius:5px;padding:8px 6px}.vb-practice .vb-stat-num{font-family:var(--vb-mono);color:var(--ink);font-size:16px;font-weight:600}.vb-practice .vb-stat-lbl{font-family:var(--vb-mono);color:var(--ink-faint);text-transform:lowercase;letter-spacing:.04em;margin-top:2px;font-size:9.5px}@media (max-width:1024px){.vb-practice .vb-cols{grid-template-columns:minmax(320px,420px) 1fr}.vb-practice .vb-context{display:none}}.vb-practice .vb-desc-tabs{flex-direction:column;flex:1;height:100%;min-height:0;display:flex}.vb-practice .vb-tabs{border-bottom:1px solid var(--line);background:var(--bg-elev);flex-shrink:0;align-items:stretch;gap:2px;height:36px;padding:0 6px;display:flex}.vb-practice .vb-tab{font-family:var(--vb-mono);color:var(--ink-faint);cursor:pointer;text-transform:lowercase;letter-spacing:.02em;background:0 0;border:0;border-radius:5px;margin:5px 0;padding:0 12px;font-size:11.5px;transition:background .12s,color .12s}.vb-practice .vb-tab:hover{color:var(--ink-dim)}.vb-practice .vb-tab[data-state=active]{color:var(--ink);background:var(--bg);box-shadow:inset 0 -2px 0 0 var(--accent)}.vb-practice .vb-desc-scroll{flex:1;min-height:0;padding:24px 28px 32px;overflow-y:auto}.vb-practice .vb-tab-pane{outline:none}.vb-practice .vb-tab-pane[hidden]{display:none}.vb-practice .vb-pane-title{color:var(--ink);letter-spacing:-.02em;margin:0 0 16px;font-size:18px;font-weight:600}.vb-practice .vb-desc-body{flex-direction:column;display:flex}.vb-practice .vb-desc-head{margin-bottom:8px}.vb-practice .vb-tags-row{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.vb-practice .vb-tags{flex-wrap:wrap;gap:5px;min-width:0;display:flex}.vb-practice .vb-tag{font-family:var(--vb-mono);background:var(--bg-elev-2);color:var(--ink-dim);text-transform:lowercase;letter-spacing:.04em;border-radius:3px;padding:2px 7px;font-size:10px}.vb-practice .vb-tag-easy{color:var(--ok);background:#7dd3a01f}.vb-practice .vb-tag-medium{color:var(--warn);background:#e6b25c1f}.vb-practice .vb-tag-hard{color:var(--err);background:#e880801f}.vb-practice .vb-h1-row{flex-wrap:wrap;align-items:center;gap:14px;margin:0 0 8px;display:flex}.vb-practice .vb-completed{height:22px;color:var(--ok);font-family:var(--vb-mono);letter-spacing:.06em;text-transform:lowercase;white-space:nowrap;background:#7dd3a01a;border:1px solid #7dd3a04d;border-radius:999px;align-items:center;gap:6px;padding:0 8px 0 6px;font-size:10px;display:inline-flex}.vb-practice .vb-completed-check{background:var(--ok);color:#0d2417;border-radius:999px;justify-content:center;align-items:center;width:14px;height:14px;display:inline-flex}.vb-practice .vb-completed-label{font-weight:500}.vb-practice .vb-h1{letter-spacing:-.025em;color:var(--ink);margin:0;font-size:26px;font-weight:600;line-height:1.2}.vb-practice .vb-meta-row{font-family:var(--vb-mono);color:var(--ink-faint);flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;font-size:10.5px;display:flex}.vb-practice .vb-meta-row strong{color:var(--ink)}.vb-practice .vb-dot{background:var(--ink-faint);opacity:.5;border-radius:50%;width:3px;height:3px}.vb-practice .vb-success-rate{color:var(--ok)}.vb-practice .vb-desc-socials{margin:8px 0 18px}.vb-practice .vb-desc-socials:empty{display:none}.vb-practice .vb-desc-mdx{color:var(--ink-dim);font-size:13px;line-height:1.65}.vb-practice .vb-desc-mdx>div{color:var(--ink-dim);font-size:13px}.vb-practice .vb-desc-mdx p,.vb-practice .vb-desc-mdx li{color:var(--ink-dim);text-wrap:pretty;font-size:13px;line-height:1.65}.vb-practice .vb-desc-mdx p{margin:0 0 12px}.vb-practice .vb-desc-mdx h1,.vb-practice .vb-desc-mdx h2,.vb-practice .vb-desc-mdx h3,.vb-practice .vb-desc-mdx h4{color:var(--ink);letter-spacing:-.015em;margin:18px 0 8px;font-weight:600}.vb-practice .vb-desc-mdx h1{font-size:18px}.vb-practice .vb-desc-mdx h2{font-size:15px}.vb-practice .vb-desc-mdx h3{font-size:13.5px}.vb-practice .vb-desc-mdx strong{color:var(--ink);font-weight:600}.vb-practice .vb-desc-mdx a{color:var(--accent)}.vb-practice .vb-desc-mdx a:hover{text-decoration:underline}.vb-practice .vb-desc-mdx ul,.vb-practice .vb-desc-mdx ol{margin:0 0 12px;padding-left:1.25rem}.vb-practice .vb-desc-mdx ul{list-style:outside}.vb-practice .vb-desc-mdx ol{list-style:decimal}.vb-practice .vb-desc-mdx blockquote{border-left:2px solid var(--accent);background:var(--bg-elev);color:var(--ink-dim);border-radius:0 5px 5px 0;margin:12px 0;padding:10px 14px}.vb-practice .vb-desc-mdx code:not(pre code){font-family:var(--vb-mono);background:var(--code-bg);border:1px solid var(--line);color:#e89a7d;border-radius:4px;padding:1px 6px;font-size:.86em}.vb-practice .vb-desc-mdx pre{border:1px solid var(--line);font-family:var(--vb-mono);border-radius:6px;margin:12px 0;padding:10px 12px;font-size:12px;line-height:1.7;overflow-x:auto;background:var(--code-bg)!important}.vb-practice .vb-desc-mdx pre code{color:var(--ink);font-size:12px;background:0 0!important;border:0!important;padding:0!important}.vb-practice .vb-desc-mdx pre [data-line]{padding:0!important}.vb-practice .vb-task{background:var(--bg-elev);border:1px solid var(--accent-line);border-radius:8px;margin-top:28px;overflow:hidden}.vb-practice .vb-task-head{background:var(--accent-soft);border-bottom:1px solid var(--accent-line);padding:8px 14px}.vb-practice .vb-task-eyebrow{font-family:var(--vb-mono);letter-spacing:.18em;color:var(--accent);font-size:10px;font-weight:600}.vb-practice .vb-task-body{color:var(--ink);border-bottom:1px solid var(--line);padding:12px 14px;font-size:13px;line-height:1.55}.vb-practice .vb-task-spec{padding:8px 14px}.vb-practice .vb-spec-row{font-size:11.5px;font-family:var(--vb-mono);grid-template-columns:60px 1fr;align-items:center;padding:4px 0;display:grid}.vb-practice .vb-spec-row>span{color:var(--ink-faint)}.vb-practice .vb-spec-row>code{color:var(--ink);font-family:var(--vb-mono);background:0 0;border:0;padding:0}.vb-practice .vb-desc-footer{border-top:1px dashed var(--line);margin-top:24px;padding-top:12px}.vb-practice .vb-cloud-ad{border:1px solid var(--accent-line);color:var(--ink);background:linear-gradient(135deg,#d977571f,#d977570a);border-radius:10px;align-items:center;gap:12px;margin:20px 0 4px;padding:14px 16px;text-decoration:none;transition:background .15s,border-color .15s,transform .15s;display:flex;position:relative;overflow:hidden}.vb-practice .vb-cloud-ad:hover{background:linear-gradient(135deg,#d977572e,#d9775712);border-color:#d9775780}.vb-practice .vb-cloud-ad:hover .vb-cloud-ad-arrow{transform:translate(2px)}.vb-practice .vb-cloud-ad-icon{background:linear-gradient(135deg,var(--accent),#b85a3d);color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:inline-flex}.vb-practice .vb-cloud-ad-text{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.vb-practice .vb-cloud-ad-title{color:var(--ink);letter-spacing:-.005em;font-size:13px;font-weight:600}.vb-practice .vb-cloud-ad-desc{color:var(--ink-faint);font-size:12px;line-height:1.4}.vb-practice .vb-cloud-ad-cta{font-family:var(--vb-mono);letter-spacing:.04em;color:var(--accent);flex-shrink:0;align-items:center;gap:4px;font-size:11px;font-weight:600;display:inline-flex}.vb-practice .vb-cloud-ad-arrow{transition:transform .15s}.vb-practice .vb-improve{align-items:center;display:flex}.vb-practice .vb-improve-link{font-family:var(--vb-mono);color:var(--ink-faint);align-items:center;gap:6px;font-size:11px;text-decoration:none;transition:color .12s;display:inline-flex}.vb-practice .vb-improve-link:hover{color:var(--accent)}.vb-practice .vb-editor{flex-direction:column;flex:1;min-width:0;min-height:0;display:flex;overflow:hidden}.vb-practice .vb-tabbar{border-bottom:1px solid var(--line);background:var(--bg-elev);flex-shrink:0;justify-content:space-between;align-items:center;height:36px;padding-right:8px;display:flex}.vb-practice .vb-files{height:100%;display:flex}.vb-practice .vb-filetab{font-family:var(--vb-mono);color:var(--ink-faint);border:0;border-right:1px solid var(--line);cursor:pointer;background:0 0;align-items:center;gap:7px;height:100%;padding:0 14px;font-size:11.5px;display:inline-flex;position:relative}.vb-practice .vb-filetab svg{opacity:.5}.vb-practice .vb-filetab:hover:not(.is-active){color:var(--ink-dim)}.vb-practice .vb-filetab.is-active{background:var(--bg);color:var(--ink)}.vb-practice .vb-filetab.is-active:before{content:"";background:var(--accent);height:1.5px;position:absolute;inset:-1px 0 auto}.vb-practice .vb-filetab-dot{background:var(--accent);border-radius:50%;width:5px;height:5px}.vb-practice .vb-editor-actions{align-items:center;gap:4px;display:flex}.vb-practice .vb-action-mini{font-family:var(--vb-mono);color:var(--ink-faint);cursor:pointer;text-transform:lowercase;background:0 0;border:0;border-radius:4px;padding:4px 8px;font-size:10.5px;transition:background .12s,color .12s}.vb-practice .vb-action-mini:hover:not(:disabled){background:var(--bg);color:var(--ink)}.vb-practice .vb-action-mini:disabled{opacity:.4;cursor:not-allowed}.vb-practice .vb-action-divider{background:var(--line);width:1px;height:14px;margin:0 4px}.vb-practice .vb-action{font-family:var(--vb-mono);border:1px solid var(--line);background:var(--bg);color:var(--ink-dim);cursor:pointer;text-transform:lowercase;border-radius:5px;align-items:center;gap:6px;padding:5px 10px;font-size:11px;font-weight:500;text-decoration:none;transition:background .12s,color .12s,border-color .12s;display:inline-flex}.vb-practice .vb-action kbd{font-family:var(--vb-mono);background:var(--bg-elev-2);border:1px solid var(--line);color:var(--ink-faint);border-radius:3px;padding:1px 4px;font-size:9.5px}.vb-practice .vb-action-run{color:var(--ok);border-color:#7dd3a040}.vb-practice .vb-action-run:hover:not(:disabled):not(.is-disabled){background:#7dd3a014}.vb-practice .vb-action-submit{background:var(--accent);border-color:var(--accent);color:#14110d;font-weight:600}.vb-practice .vb-action-submit kbd{color:#14110db3;background:#0000002e;border-color:#0000002e}.vb-practice .vb-action-submit:hover:not(:disabled):not(.is-disabled){background:#e58468}.vb-practice .vb-action:disabled,.vb-practice .vb-action.is-disabled{opacity:.45;cursor:not-allowed}.vb-practice .vb-codewrap{background:var(--code-bg);flex:1;min-height:0;display:flex;position:relative}.vb-practice .vb-codewrap>div{flex:1;min-width:0;min-height:0}.vb-practice .vb-statusbar{border-top:1px solid var(--line);height:22px;font-family:var(--vb-mono);color:var(--ink-faint);background:var(--bg-elev);flex-shrink:0;justify-content:space-between;align-items:center;padding:0 12px;font-size:10px;display:flex}.vb-practice .vb-status-l,.vb-practice .vb-status-r{align-items:center;gap:8px;display:flex}.vb-practice .vb-status-sep{opacity:.5}.vb-practice .vb-status-pill{color:var(--ok)}.vb-practice .vb-status-toggle{font-family:var(--vb-mono);color:var(--ink-faint);cursor:pointer;text-transform:lowercase;background:0 0;border:0;padding:0;font-size:10px}.vb-practice .vb-status-toggle.is-on{color:var(--accent)}.vb-practice .vb-status-toggle:hover{color:var(--ink)}.vb-practice .vb-ai{background:var(--bg-elev);border:1px solid var(--line);height:calc(100vh - 220px);min-height:480px;font-family:var(--vb-sans);color:var(--ink);border-radius:6px;flex-direction:column;display:flex;overflow:hidden}.vb-practice .vb-ai-empty{text-align:center;height:auto;min-height:0;color:var(--ink-dim);justify-content:center;align-items:center;gap:12px;padding:32px;font-size:13px}.vb-practice .vb-ai-head{border-bottom:1px solid var(--line);background:var(--bg);justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.vb-practice .vb-ai-title{font-family:var(--vb-mono);text-transform:lowercase;letter-spacing:.04em;color:var(--ink-dim);font-size:11px}.vb-practice .vb-newchat-btn{border:1px solid var(--accent-line);background:linear-gradient(180deg,var(--accent-soft)0%,transparent 100%),var(--bg-elev);height:26px;color:var(--accent);font-family:var(--vb-mono);letter-spacing:.02em;cursor:pointer;border-radius:999px;align-items:center;gap:6px;padding:0 10px 0 7px;font-size:11px;font-weight:500;transition:background .18s,border-color .18s,color .18s,box-shadow .18s,transform .12s;display:inline-flex;position:relative}.vb-practice .vb-newchat-btn:hover:not(:disabled){background:var(--accent);border-color:var(--accent);color:#14110d;box-shadow:0 0 0 3px var(--accent-soft),0 4px 14px -4px #d9775773}.vb-practice .vb-newchat-btn:hover:not(:disabled) .vb-newchat-glyph{transform:rotate(90deg)}.vb-practice .vb-newchat-btn:active:not(:disabled){box-shadow:0 0 0 2px var(--accent-soft);transform:translateY(1px)}.vb-practice .vb-newchat-btn:focus-visible{box-shadow:0 0 0 3px var(--accent-soft);outline:none}.vb-practice .vb-newchat-btn:disabled,.vb-practice .vb-newchat-btn.is-pending{opacity:.7;cursor:not-allowed}.vb-practice .vb-newchat-btn.is-pending .vb-newchat-glyph{animation:.9s linear infinite vb-newchat-spin}.vb-practice .vb-newchat-glyph{color:currentColor;border-radius:999px;justify-content:center;align-items:center;width:16px;height:16px;transition:transform .25s;display:inline-flex}.vb-practice .vb-newchat-label{white-space:nowrap}@keyframes vb-newchat-spin{to{transform:rotate(360deg)}}.vb-practice .vb-ai>div:last-child{background:var(--bg-elev)}.vb-practice .vb-ai .border-t{background:var(--bg);border-top-color:var(--line)!important}.vb-practice .vb-ai textarea{background:var(--code-bg);border:1px solid var(--line);color:var(--ink);font-family:var(--vb-mono);font-size:12.5px}.vb-practice .vb-ai textarea::placeholder{color:var(--ink-faint)}.vb-practice .vb-ai textarea:focus-visible{border-color:var(--accent-line);box-shadow:0 0 0 2px var(--accent-soft);outline:none}.vb-practice .vb-ai .text-gray-400,.vb-practice .vb-ai .text-gray-500{color:var(--ink-faint)!important}.vb-practice .vb-ai .text-orange-500{color:var(--accent)!important}.vb-practice .vb-ai .bg-orange-500{background:var(--accent)!important;color:#fff!important}.vb-practice .vb-ai .bg-gray-100,.vb-practice .vb-ai .dark\:bg-gray-800{background:var(--bg-elev-2)!important;color:var(--ink)!important}.vb-practice .vb-ai .bg-gray-200,.vb-practice .vb-ai .dark\:bg-gray-800 code,.vb-practice .vb-ai code{background:var(--code-bg);color:#e89a7d;font-family:var(--vb-mono)}.vb-practice .vb-ai pre{font-family:var(--vb-mono);background:var(--code-bg)!important;border-color:var(--line)!important}.vb-practice .vb-ai .bg-red-50,.vb-practice .vb-ai .dark\:bg-red-950{color:var(--err)!important;background:#e8808014!important;border-color:#e880804d!important}.vb-practice .vb-ai-drawer{z-index:5;background:var(--bg-elev);border-top:1px solid var(--line);flex-direction:column;flex-shrink:0;height:44px;transition:height .28s cubic-bezier(.2,.8,.2,1);display:flex;position:relative;overflow:hidden;box-shadow:0 -8px 24px #00000040}.vb-practice .vb-ai-drawer.is-open{height:min(420px,60vh)}.vb-practice .vb-ai-drawer.is-resizing{transition:none}.vb-practice .vb-ai-drawer-resize{cursor:ns-resize;z-index:10;background:0 0;height:6px;transition:background .15s;position:absolute;top:0;left:0;right:0}.vb-practice .vb-ai-drawer-resize:after{content:"";background:var(--line);border-radius:2px;width:32px;height:3px;transition:background .15s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.vb-practice .vb-ai-drawer-resize:hover:after,.vb-practice .vb-ai-drawer.is-resizing .vb-ai-drawer-resize:after{background:var(--accent)}.vb-practice .vb-ai-drawer-head{cursor:pointer;-webkit-user-select:none;user-select:none;text-align:left;width:100%;height:44px;color:var(--ink);background:0 0;border:0;border-bottom:1px solid #0000;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 14px 0 16px;transition:background .15s,border-color .15s;display:flex}.vb-practice .vb-ai-drawer.is-open .vb-ai-drawer-head{border-bottom-color:var(--line);background:var(--bg-elev-2)}.vb-practice .vb-ai-drawer-head:hover{background:var(--bg-elev-2)}.vb-practice .vb-ai-drawer-head-left,.vb-practice .vb-ai-drawer-head-right{align-items:center;gap:10px;display:flex}.vb-practice .vb-ai-spark{background:var(--accent-soft);width:22px;height:22px;color:var(--accent);border:1px solid var(--accent-line);border-radius:6px;justify-content:center;align-items:center;display:flex}.vb-practice .vb-ai-drawer-title{color:var(--ink);letter-spacing:-.01em;font-size:13px;font-weight:600}.vb-practice .vb-ai-drawer-sub{color:var(--ink-faint);font-size:11.5px;font-family:var(--vb-mono);text-transform:lowercase}.vb-practice .vb-ai-drawer-kbd{gap:2px;display:flex}.vb-practice .vb-ai-drawer-kbd kbd{font-family:var(--vb-mono);background:var(--code-bg);border:1px solid var(--line);color:var(--ink-faint);text-align:center;border-radius:4px;min-width:17px;padding:2px 5px;font-size:10px}.vb-practice .vb-ai-drawer-chev{color:var(--ink-faint);justify-content:center;align-items:center;transition:transform .18s;display:inline-flex}.vb-practice .vb-ai-drawer-body{background:var(--bg-elev);flex-direction:column;flex:1;min-height:0;display:flex}.vb-practice .vb-ai-drawer-empty{text-align:center;color:var(--ink-dim);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:14px;padding:32px;font-size:13px;display:flex}.vb-practice .vb-start-chat-icon{background:var(--accent-soft);border:1px solid var(--accent-line);width:44px;height:44px;color:var(--accent);border-radius:12px;justify-content:center;align-items:center;display:inline-flex;box-shadow:0 4px 18px -10px #d977578c}.vb-practice .vb-start-chat-copy{flex-direction:column;gap:4px;max-width:280px;display:flex}.vb-practice .vb-start-chat-title{font-family:var(--vb-sans);color:var(--ink);letter-spacing:-.005em;font-size:13.5px;font-weight:600}.vb-practice .vb-start-chat-sub{font-family:var(--vb-sans);color:var(--ink-faint);font-size:12px;line-height:1.5}.vb-practice .vb-start-chat-btn{border:1px solid var(--accent-line);background:var(--accent-soft);height:32px;color:var(--accent);font-family:var(--vb-mono);text-transform:lowercase;letter-spacing:.015em;cursor:pointer;border-radius:999px;align-items:center;gap:7px;margin-top:2px;padding:0 14px 0 11px;font-size:12px;font-weight:500;transition:background .18s,border-color .18s,color .18s,box-shadow .18s,transform .12s;display:inline-flex;position:relative}.vb-practice .vb-start-chat-btn:hover:not(:disabled){background:var(--accent);border-color:var(--accent);color:#14110d;box-shadow:0 0 0 3px var(--accent-soft),0 6px 18px -6px #d977578c;transform:translateY(-1px)}.vb-practice .vb-start-chat-btn:active:not(:disabled){box-shadow:0 0 0 2px var(--accent-soft);transform:translateY(0)}.vb-practice .vb-start-chat-btn:focus-visible{box-shadow:0 0 0 3px var(--accent-soft);outline:none}.vb-practice .vb-start-chat-btn:disabled,.vb-practice .vb-start-chat-btn.is-pending{opacity:.75;cursor:not-allowed}.vb-practice .vb-start-chat-btn-glyph{justify-content:center;align-items:center;transition:transform .4s;display:inline-flex}.vb-practice .vb-start-chat-btn:hover:not(:disabled) .vb-start-chat-btn-glyph{transform:rotate(15deg)scale(1.08)}.vb-practice .vb-start-chat-btn.is-pending .vb-start-chat-btn-glyph{animation:1.1s linear infinite vb-newchat-spin}.vb-practice .vb-ai-drawer-body .border-t{background:var(--bg);border-top-color:var(--line)!important}.vb-practice .ai-input-row{border-top:1px solid var(--line);background:var(--bg-elev);flex-shrink:0;padding:8px 14px 14px}.vb-practice .ai-input-wrap{background:var(--bg-elev-2);border:1px solid var(--line);border-radius:8px;padding:10px 12px 8px;transition:border-color .15s}.vb-practice .ai-input-wrap:focus-within{border-color:var(--accent-line)}.vb-practice .ai-input-wrap textarea{width:100%;color:var(--ink);font-family:var(--vb-mono);resize:none;background:0 0;border:0;outline:none;min-height:22px;max-height:120px;font-size:12.5px;line-height:1.5;overflow-y:auto}.vb-practice .ai-input-wrap textarea::placeholder{color:var(--ink-faint)}.vb-practice .ai-input-meta{justify-content:space-between;align-items:center;gap:8px;margin-top:4px;display:flex}.vb-practice .ai-context{color:var(--ink-faint);align-items:center;gap:6px;font-size:11.5px;display:flex}.vb-practice .ai-context code{font-family:var(--vb-mono);background:var(--code-bg);border:1px solid var(--line);color:var(--ink-dim);border-radius:3px;padding:1px 5px;font-size:10.5px}.vb-practice .ai-context-dot{background:var(--ok);border-radius:50%;flex-shrink:0;width:6px;height:6px;box-shadow:0 0 6px #8fb98a99}.vb-practice .ai-send{background:var(--bg-elev);border:1px solid var(--line);font-family:var(--vb-mono);color:var(--ink-faint);cursor:pointer;border-radius:7px;align-items:center;gap:6px;padding:5px 11px;font-size:12px;font-weight:500;transition:all .15s;display:inline-flex}.vb-practice .ai-send.is-active{background:var(--accent);border-color:var(--accent);color:#14110d;font-weight:600}.vb-practice .ai-send.is-active:hover{background:#e58468;border-color:#e58468}.vb-practice .ai-send.is-stop{color:var(--err);border-color:#e880804d}.vb-practice .ai-send.is-stop:hover{background:#e8808014}.vb-practice .ai-send:disabled{cursor:not-allowed}.vb-practice .vb-ai-drawer-body .text-gray-400,.vb-practice .vb-ai-drawer-body .text-gray-500{color:var(--ink-faint)!important}.vb-practice .vb-ai-drawer-body .text-orange-500{color:var(--accent)!important}.vb-practice .vb-ai-drawer-body .bg-orange-500{background:var(--accent)!important;color:#fff!important}.vb-practice .vb-ai-drawer-body .bg-gray-100,.vb-practice .vb-ai-drawer-body .dark\:bg-gray-800{background:var(--bg-elev-2)!important;color:var(--ink)!important}.vb-practice .vb-ai-drawer-body .bg-gray-200,.vb-practice .vb-ai-drawer-body .dark\:bg-gray-800 code,.vb-practice .vb-ai-drawer-body code{background:var(--code-bg);color:#e89a7d;font-family:var(--vb-mono)}.vb-practice .vb-ai-drawer-body pre{font-family:var(--vb-mono);background:var(--code-bg)!important;border-color:var(--line)!important}.vb-practice .vb-ai-drawer-body .bg-red-50,.vb-practice .vb-ai-drawer-body .dark\:bg-red-950{color:var(--err)!important;background:#e8808014!important;border-color:#e880804d!important}.vb-practice .tabp{padding:0}.vb-practice .tabp-eyebrow{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);align-items:center;gap:8px;font-size:9.5px;display:flex}.vb-practice .tabp-eyebrow:after{content:"";background:var(--line);opacity:.7;flex:1;height:1px}.vb-practice .tabp-section{margin-bottom:18px}.vb-practice .r-summary{border:1px solid var(--line);border-left:2px solid var(--ok);background:linear-gradient(180deg,#7dd3a00f,transparent 80%)var(--bg-elev);border-radius:6px;justify-content:space-between;align-items:center;gap:14px;margin-bottom:18px;padding:11px 13px;display:flex}.vb-practice .r-summary.is-fail{border-left-color:var(--err);background:linear-gradient(180deg,#e880800f,transparent 80%)var(--bg-elev)}.vb-practice .r-summary-left{align-items:center;gap:11px;min-width:0;display:flex}.vb-practice .r-summary-icon{width:26px;height:26px;color:var(--ok);background:#7dd3a029;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.vb-practice .r-summary.is-fail .r-summary-icon{color:var(--err);background:#e8808024}.vb-practice .r-summary-title{color:var(--ink);letter-spacing:-.01em;font-size:13.5px;font-weight:600}.vb-practice .r-summary-meta{font-family:var(--mono);color:var(--ink-faint);margin-top:2px;font-size:10.5px}.vb-practice .r-summary-stats{font-family:var(--mono);color:var(--ink-dim);flex-shrink:0;gap:10px;font-size:10.5px;display:flex}.vb-practice .r-summary-stats>div{text-align:right}.vb-practice .r-summary-stats strong{color:var(--ink);font-size:13px;font-weight:600;display:block}.vb-practice .r-tests{border:1px solid var(--line);background:var(--bg);border-radius:6px;flex-direction:column;display:flex;overflow:hidden}.vb-practice .r-test{font-family:var(--mono);border-top:1px solid var(--line);cursor:pointer;grid-template-columns:22px 1fr auto;align-items:center;gap:10px;padding:9px 12px;font-size:11.5px;transition:background .12s;display:grid}.vb-practice .r-test:first-child{border-top:none}.vb-practice .r-test:hover{background:var(--bg-elev)}.vb-practice .r-test-icon{justify-content:center;align-items:center;width:14px;height:14px;display:inline-flex}.vb-practice .r-test.is-pass .r-test-icon{color:var(--ok)}.vb-practice .r-test.is-fail .r-test-icon{color:var(--err)}.vb-practice .r-test.is-pending .r-test-icon{color:var(--ink-faint)}.vb-practice .r-test-name{color:var(--ink-dim);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.vb-practice .r-test.is-fail .r-test-name{color:var(--ink)}.vb-practice .r-test-meta{color:var(--ink-faint);align-items:center;gap:8px;font-size:10.5px;display:flex}.vb-practice .r-test-time{font-variant-numeric:tabular-nums}.vb-practice .r-test-status{letter-spacing:.12em;text-transform:uppercase;font-size:9.5px}.vb-practice .r-test.is-pass .r-test-status{color:var(--ok)}.vb-practice .r-test.is-fail .r-test-status{color:var(--err)}.vb-practice .r-test.is-pending .r-test-status{color:var(--ink-faint)}.vb-practice .r-test-detail{background:var(--code-bg);border-top:1px solid var(--line);font-family:var(--mono);color:var(--ink-dim);padding:10px 14px 12px;font-size:11px}.vb-practice .r-diff{background:var(--bg);border:1px solid var(--line);border-radius:4px;grid-template-columns:60px 1fr;gap:4px 10px;margin-top:6px;padding:6px 8px;display:grid}.vb-practice .r-diff-label{letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);align-self:center;font-size:9.5px}.vb-practice .r-diff-val.is-expected{color:var(--ok)}.vb-practice .r-diff-val.is-actual{color:var(--err)}.vb-practice .r-sponsor{justify-content:center;margin:18px 0;display:flex}.vb-practice .r-log{border:1px solid var(--line);background:var(--code-bg);border-radius:6px;overflow:hidden}.vb-practice .r-log-head{background:var(--bg-elev);border-bottom:1px solid var(--line);font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);justify-content:space-between;align-items:center;padding:7px 12px;font-size:10px;display:flex}.vb-practice .r-log-actions{align-items:center;gap:6px;display:flex}.vb-practice .r-log-mini{font-family:var(--mono);text-transform:lowercase;letter-spacing:.04em;color:var(--ink-faint);cursor:pointer;background:0 0;border:0;border-radius:3px;padding:3px 7px;font-size:10px}.vb-practice .r-log-mini:hover{background:var(--bg-elev-2);color:var(--ink)}.vb-practice .r-log-body{font-family:var(--mono);color:var(--ink-dim);white-space:pre;max-height:220px;margin:0;padding:10px 14px;font-size:11px;line-height:1.55;overflow:auto}.vb-practice .r-log-body.is-wrap{white-space:pre-wrap;word-break:break-word}.vb-practice .r-log-body .l-info{color:var(--ink-dim)}.vb-practice .r-log-body .l-warn{color:var(--warn)}.vb-practice .r-log-body .l-err{color:var(--err)}.vb-practice .r-log-body .l-ok{color:var(--ok)}.vb-practice .r-log-body .l-dim{color:var(--ink-faint)}.vb-practice .r-log-body .l-acc{color:var(--accent)}.vb-practice .tabp-empty{text-align:center;color:var(--ink-faint);padding:48px 24px}.vb-practice .tabp-empty-icon{background:var(--bg-elev);border:1px solid var(--line);width:44px;height:44px;color:var(--ink-faint);border-radius:8px;justify-content:center;align-items:center;margin-bottom:14px;display:inline-flex}.vb-practice .tabp-empty-title{color:var(--ink);margin-bottom:5px;font-size:14px;font-weight:500}.vb-practice .tabp-empty-body{color:var(--ink-dim);max-width:280px;margin:0 auto 16px;font-size:12px;line-height:1.55}.vb-practice .tabp-empty-hint{font-family:var(--mono);color:var(--ink-faint);border:1px solid var(--line);background:var(--bg-elev);border-radius:5px;align-items:center;gap:6px;padding:5px 10px;font-size:10.5px;display:inline-flex}.vb-practice .tabp-empty-hint kbd{background:var(--bg);border:1px solid var(--line);color:var(--ink);border-radius:3px;padding:1px 5px;font-size:9.5px}.vb-practice .tabp-loading{flex-direction:column;gap:8px;padding:14px 0;display:flex}.vb-practice .tabp-shimmer{background:linear-gradient(90deg,var(--bg-elev)0%,var(--bg-elev-2)50%,var(--bg-elev)100%);background-size:200% 100%;border-radius:6px;height:36px;animation:1.2s ease-in-out infinite tabp-shimmer}.vb-practice .tabp-shimmer.is-tall{height:64px}.vb-practice .tabp-shimmer.is-short{height:22px}@keyframes tabp-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.vb-practice .tabp-loading-meta{font-family:var(--mono);color:var(--ink-faint);align-items:center;gap:8px;margin-top:10px;font-size:10.5px;display:flex}.vb-practice .tabp-loading-spinner{border:1.4px solid var(--line-strong);border-top-color:var(--accent);border-radius:50%;width:11px;height:11px;animation:.8s linear infinite tabp-spin}@keyframes tabp-spin{to{transform:rotate(360deg)}}.vb-practice .s-list{border:1px solid var(--line);background:var(--bg);border-radius:6px;flex-direction:column;display:flex;overflow:hidden}.vb-practice .s-row{border-top:1px solid var(--line);grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:10px 12px;transition:background .12s;display:grid}.vb-practice .s-row:first-child{border-top:none}.vb-practice .s-row:hover{background:var(--bg-elev)}.vb-practice .s-row.is-current{background:var(--accent-soft)}.vb-practice .s-row-status{color:var(--ok);font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;background:#7dd3a01f;border-radius:3px;align-items:center;gap:6px;padding:2px 8px;font-size:10px;font-weight:500;display:inline-flex}.vb-practice .s-row-status:before{content:"";background:currentColor;border-radius:50%;width:5px;height:5px;box-shadow:0 0 6px}.vb-practice .s-row-meta{font-family:var(--mono);color:var(--ink);align-items:baseline;gap:8px;min-width:0;font-size:11px;display:flex}.vb-practice .s-row-time{color:var(--ink-dim)}.vb-practice .s-row-id{color:var(--ink-faint);font-size:10px}.vb-practice .s-row-current{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-top:2px;font-size:9.5px}.vb-practice .s-row-actions{gap:2px;display:flex}.vb-practice .s-iconbtn{width:26px;height:26px;color:var(--ink-faint);cursor:pointer;background:0 0;border:0;border-radius:5px;justify-content:center;align-items:center;transition:background .12s,color .12s;display:inline-flex}.vb-practice .s-iconbtn:hover{background:var(--bg-elev-2);color:var(--ink)}.vb-practice .s-iconbtn.is-load:hover,.vb-practice .s-iconbtn.is-public{color:var(--accent)}.vb-practice .s-iconbtn.is-danger:hover{color:var(--err);background:#e8808014}.vb-practice .s-iconbtn:disabled{opacity:.5;cursor:not-allowed}.vb-practice .s-vis{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint);background:var(--bg-elev-2);border-radius:3px;align-items:center;gap:5px;padding:3px 7px;font-size:9.5px;display:inline-flex}.vb-practice .s-vis.is-public{color:var(--accent);background:var(--accent-soft)}.vb-practice .s-summary{font-family:var(--mono);color:var(--ink-faint);justify-content:space-between;align-items:center;margin-bottom:10px;font-size:10.5px;display:flex}.vb-practice .s-summary strong{color:var(--ink)}.vb-practice .s-auth{border:1px solid var(--line);background:var(--code-bg);border-radius:6px;margin-top:8px;overflow:hidden}.vb-practice .s-auth-head{background:var(--bg-elev);border-bottom:1px solid var(--line);font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);align-items:center;gap:8px;padding:7px 12px;font-size:10px;display:flex}.vb-practice .s-auth-head-dot{background:var(--warn);width:6px;height:6px;box-shadow:0 0 6px var(--warn);border-radius:50%}.vb-practice .s-auth-body{font-family:var(--mono);color:var(--ink-dim);padding:14px 14px 4px;font-size:11.5px;line-height:1.6}.vb-practice .s-auth-body .prompt{color:var(--ink-faint);-webkit-user-select:none;user-select:none;margin-right:6px}.vb-practice .s-auth-body .err{color:var(--err)}.vb-practice .s-auth-body .acc{color:var(--accent)}.vb-practice .s-auth-body .ok{color:var(--ok)}.vb-practice .s-auth-actions{border-top:1px dashed var(--line);gap:8px;margin-top:12px;padding:12px 14px 14px;display:flex}.vb-practice .s-auth-btn{font-family:var(--mono);cursor:pointer;border:0;border-radius:5px;align-items:center;gap:6px;padding:6px 11px;font-size:11px;font-weight:500;text-decoration:none;display:inline-flex}.vb-practice .s-auth-btn-primary{background:var(--accent);color:#14110d;font-weight:600}.vb-practice .s-auth-btn-primary:hover{background:#e58468}.vb-practice .s-auth-btn-ghost{border:1px solid var(--line);color:var(--ink-dim);background:0 0}.vb-practice .s-auth-btn-ghost:hover{color:var(--ink);border-color:var(--line-strong)}.vb-practice .sol-list{flex-direction:column;gap:12px;display:flex}.vb-practice .sol-card{border:1px solid var(--line);background:var(--bg-elev);border-radius:6px;transition:border-color .15s;overflow:hidden}.vb-practice .sol-card:hover{border-color:var(--line-strong)}.vb-practice .sol-head{justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;display:flex}.vb-practice .sol-author{align-items:center;gap:9px;min-width:0;display:flex}.vb-practice .sol-avatar{background:linear-gradient(135deg,var(--accent),#b85a3d);color:#fff;width:26px;height:26px;font-family:var(--mono);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11.5px;font-weight:600;display:flex;overflow:hidden}.vb-practice .sol-avatar img{-o-object-fit:cover;object-fit:cover;width:100%;height:100%}.vb-practice .sol-author-info{min-width:0}.vb-practice .sol-author-name{color:var(--ink);letter-spacing:-.005em;white-space:nowrap;align-items:center;gap:5px;font-size:12.5px;font-weight:600;line-height:1.2;display:flex}.vb-practice .sol-author-name>span:first-child{text-overflow:ellipsis;min-width:0;overflow:hidden}.vb-practice .sol-author-name-handle{font-family:var(--mono);color:var(--ink-faint);font-size:10.5px;font-weight:400}.vb-practice .sol-badge{background:var(--accent-soft);width:13px;height:13px;color:var(--accent);font-size:9px;font-family:var(--mono);border-radius:3px;justify-content:center;align-items:center;font-weight:700;display:inline-flex}.vb-practice .sol-badge.is-pro{color:var(--accent-2);background:#6ea8ff24}.vb-practice .sol-badge.is-streak{color:var(--warn);background:#e6b25c24}.vb-practice .sol-time{font-family:var(--mono);color:var(--ink-faint);flex-shrink:0;font-size:10.5px}.vb-practice .sol-scores{font-family:var(--mono);grid-template-columns:46px 1fr 56px;align-items:center;gap:9px 10px;padding:0 12px 10px;font-size:10.5px;display:grid}.vb-practice .sol-score-label{color:var(--ink-faint);text-transform:lowercase}.vb-practice .sol-score-bar{background:var(--bg);border-radius:3px;height:5px;position:relative;overflow:hidden}.vb-practice .sol-score-fill{border-radius:3px;height:100%;transition:width .4s}.vb-practice .sol-score-fill.is-good{background:var(--ok)}.vb-practice .sol-score-fill.is-mid{background:var(--warn)}.vb-practice .sol-score-fill.is-bad{background:var(--err)}.vb-practice .sol-score-val{text-align:right;color:var(--ink);font-variant-numeric:tabular-nums;font-weight:500}.vb-practice .sol-score-val .unit{color:var(--ink-faint);margin-left:1px;font-weight:400}.vb-practice .sol-codepreview{border-top:1px solid var(--line);background:var(--code-bg);position:relative}.vb-practice .sol-codepreview pre{font-family:var(--mono);color:var(--ink);white-space:pre;max-height:100px;margin:0;padding:10px 14px;font-size:11px;line-height:1.6;overflow:hidden}.vb-practice .sol-codepreview-fade{background:linear-gradient(180deg,transparent,var(--code-bg)70%);pointer-events:none;height:36px;position:absolute;inset:auto 0 0}.vb-practice .sol-expand{font-family:var(--mono);background:var(--bg-elev);border:1px solid var(--line);color:var(--ink-dim);z-index:1;cursor:pointer;border-radius:4px;align-items:center;gap:5px;padding:4px 9px;font-size:10.5px;display:inline-flex;position:absolute;bottom:7px;right:8px}.vb-practice .sol-expand:hover{color:var(--accent);border-color:var(--accent-line);background:var(--accent-soft)}.vb-practice .sol-modal-backdrop{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:60;background:#0d0f12b8;justify-content:center;align-items:center;padding:30px 20px;animation:.16s ease-out sol-modal-backdrop-in;display:flex;position:fixed;inset:0}.vb-practice .sol-modal{background:var(--bg-elev);border:1px solid var(--line-strong);border-radius:8px;flex-direction:column;width:100%;max-width:600px;max-height:100%;animation:.2s cubic-bezier(.16,1,.3,1) sol-modal-in;display:flex;overflow:hidden;box-shadow:0 30px 60px -20px #000000b3}@keyframes sol-modal-backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes sol-modal-in{0%{opacity:0;transform:translateY(8px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.vb-practice .sol-modal-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:12px;padding:13px 16px;display:flex}.vb-practice .sol-modal-close{width:24px;height:24px;color:var(--ink-faint);cursor:pointer;background:0 0;border:0;border-radius:5px;justify-content:center;align-items:center;display:inline-flex}.vb-practice .sol-modal-close:hover{background:var(--bg);color:var(--ink)}.vb-practice .sol-modal-scores{border-bottom:1px solid var(--line);background:var(--bg);padding:10px 16px}.vb-practice .sol-modal-scores .sol-scores{padding:0}.vb-practice .sol-modal-code{background:var(--code-bg);flex:1;position:relative;overflow:auto}.vb-practice .sol-modal-code pre{font-family:var(--mono);color:var(--ink);margin:0;padding:14px 18px 18px;font-size:12px;line-height:1.7}.vb-practice .sol-modal-foot{border-top:1px solid var(--line);background:var(--bg-elev);font-family:var(--mono);color:var(--ink-faint);justify-content:space-between;align-items:center;gap:10px;padding:11px 16px;font-size:11px;display:flex}.vb-practice .sol-modal-actions{gap:6px;display:flex}.vb-practice .sol-modal-btn{font-family:var(--mono);cursor:pointer;background:0 0;border:0;border-radius:5px;align-items:center;gap:6px;padding:6px 11px;font-size:11px;display:inline-flex}.vb-practice .sol-modal-btn-ghost{border:1px solid var(--line);color:var(--ink-dim)}.vb-practice .sol-modal-btn-ghost:hover{color:var(--ink);border-color:var(--line-strong);background:var(--bg)}.vb-practice .sol-modal-btn-primary{background:var(--accent);color:#14110d;font-weight:600}.vb-practice .sol-modal-btn-primary:hover{background:#e58468}.vb-practice .vb-openlocal{flex-shrink:0;display:inline-flex;position:relative}.vb-practice .vb-openlocal-btn{border:1px solid var(--accent-line);background:var(--accent-soft);height:22px;color:var(--accent);font-family:var(--vb-mono);letter-spacing:.01em;cursor:pointer;white-space:nowrap;border-radius:5px;align-items:center;gap:6px;padding:0 8px;font-size:10.5px;font-weight:500;transition:background .12s,border-color .12s;display:inline-flex}.vb-practice .vb-openlocal-btn:hover{background:#d977572e;border-color:#d9775780}.vb-practice .vb-openlocal-btn.is-open{background:#d9775738;border-color:#d977578c}.vb-practice .vb-openlocal-pop{z-index:30;background:var(--bg-elev);border:1px solid var(--line-strong);border-radius:8px;width:340px;padding:4px 0 0;animation:.14s ease-out vb-openlocal-in;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 18px 48px -16px #000000b3,0 2px 6px #0000004d}.vb-practice .vb-openlocal-pop:before{content:"";background:var(--bg-elev);border-top:1px solid var(--line-strong);border-left:1px solid var(--line-strong);width:9px;height:9px;position:absolute;top:-5px;right:18px;transform:rotate(45deg)}@keyframes vb-openlocal-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.vb-practice .vb-openlocal-head{border-bottom:1px dashed var(--line);justify-content:space-between;align-items:center;padding:10px 12px 8px;display:flex}.vb-practice .vb-openlocal-eyebrow{font-family:var(--vb-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);font-size:9.5px}.vb-practice .vb-openlocal-close{cursor:pointer;width:18px;height:18px;color:var(--ink-faint);background:0 0;border:0;border-radius:4px;justify-content:center;align-items:center;display:inline-flex}.vb-practice .vb-openlocal-close:hover{background:var(--bg);color:var(--ink)}.vb-practice .vb-openlocal-step{padding:10px 12px 4px}.vb-practice .vb-openlocal-step-label{color:var(--ink-dim);align-items:center;gap:8px;margin-bottom:6px;font-size:11.5px;display:flex}.vb-practice .vb-openlocal-step-num{font-family:var(--vb-mono);color:var(--accent);letter-spacing:.08em;font-size:9.5px}.vb-practice .vb-openlocal-cmd{background:var(--code-bg);border:1px solid var(--line);font-family:var(--vb-mono);border-radius:5px;align-items:center;gap:8px;padding:6px 8px;font-size:11.5px;display:flex}.vb-practice .vb-openlocal-cmd-prompt{color:var(--ink-faint);-webkit-user-select:none;user-select:none}.vb-practice .vb-openlocal-cmd code{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;background:0 0;border:0;flex:1;padding:0;overflow:hidden}.vb-practice .vb-openlocal-copy{cursor:pointer;width:22px;height:22px;color:var(--ink-faint);background:0 0;border:0;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.vb-practice .vb-openlocal-copy:hover{background:var(--bg-elev-2);color:var(--ink)}.vb-practice .vb-openlocal-foot{border-top:1px dashed var(--line);font-family:var(--vb-mono);color:var(--ink-faint);margin-top:6px;padding:10px 12px 12px;font-size:10.5px;line-height:1.5}.vb-practice .vb-openlocal-foot code{color:var(--accent);background:var(--code-bg);border:1px solid var(--line);border-radius:3px;padding:0 3px;font-size:10.5px}.vb-practice .vb-discord-cta{--discord:#5865f2;color:var(--ink);background:linear-gradient(135deg,#5865f21a,#5865f20a);border:1px solid #5865f247;border-radius:8px;align-items:center;gap:12px;margin:20px 0 16px;padding:12px 14px;text-decoration:none;transition:background .15s,border-color .15s,transform .15s;display:flex}.vb-practice .vb-discord-cta:hover{background:linear-gradient(135deg,#5865f229,#5865f212);border-color:#5865f273}.vb-practice .vb-discord-cta:hover .vb-discord-cta-arrow{transform:translate(2px)}.vb-practice .vb-discord-cta-icon{background:var(--discord);color:#fff;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:inline-flex}.vb-practice .vb-discord-cta-text{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.vb-practice .vb-discord-cta-eyebrow{font-family:var(--vb-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);font-size:9.5px}.vb-practice .vb-discord-cta-title{color:var(--ink);letter-spacing:-.005em;font-size:13px;font-weight:600}.vb-practice .vb-discord-cta-arrow{color:var(--ink-faint);flex-shrink:0;transition:transform .15s}.vb-rail-menu{font-family:var(--font-inter),-apple-system,BlinkMacSystemFont,system-ui,sans-serif;color:#e8ecf1!important;background:#14171c!important;border:1px solid #2a313b!important;border-radius:8px!important;padding:4px!important;box-shadow:0 12px 32px #0000008c,0 0 0 1px #ffffff05!important}.vb-rail-menu-label{flex-direction:column;gap:2px;display:flex;padding:8px 8px 6px!important}.vb-rail-menu-label-name{color:#e8ecf1;font-size:13px;font-weight:600;line-height:1.2}.vb-rail-menu-label-email{color:#9aa3b0;font-size:11px;font-weight:400;font-family:var(--font-jetbrains-mono),ui-monospace,"SF Mono",Menlo,monospace;letter-spacing:-.01em}.vb-rail-menu-sep{background:#1f242c!important;margin:4px 0!important}.vb-rail-menu-item{cursor:pointer;outline:none;align-items:center;gap:8px;display:flex;color:#9aa3b0!important;border-radius:5px!important;padding:7px 8px!important;font-size:12.5px!important;transition:background .12s,color .12s!important}.vb-rail-menu-item:hover,.vb-rail-menu-item:focus,.vb-rail-menu-item[data-highlighted]{color:#e8ecf1!important;background:#1a1e24!important}.vb-rail-menu-item-icon{color:#5d6675;flex-shrink:0;transition:color .12s}.vb-rail-menu-item:hover .vb-rail-menu-item-icon,.vb-rail-menu-item:focus .vb-rail-menu-item-icon,.vb-rail-menu-item[data-highlighted] .vb-rail-menu-item-icon{color:#d97757}.vb-rail-menu-item-danger:hover,.vb-rail-menu-item-danger:focus,.vb-rail-menu-item-danger[data-highlighted]{color:#e88080!important;background:#e8808014!important}.vb-rail-menu-item-danger:hover .vb-rail-menu-item-icon,.vb-rail-menu-item-danger:focus .vb-rail-menu-item-icon,.vb-rail-menu-item-danger[data-highlighted] .vb-rail-menu-item-icon{color:#e88080}
