*,:before,:after{box-sizing:border-box}.ib{background:var(--surface);border-bottom:1px solid var(--border);flex-direction:column;min-height:0;display:flex;overflow:hidden}.ib.page{border-bottom:none;flex:1;width:100%}.ib.page .ib-inner{border-top:none;flex:1;max-height:none}.ib.page .ib-list{flex:1}.ib-bar{cursor:pointer;-webkit-user-select:none;user-select:none;background:linear-gradient(90deg,#f0a5000d,#0000 40%);flex-shrink:0;align-items:center;gap:12px;height:38px;padding:0 20px;display:flex}.ib-bar:hover{background:linear-gradient(90deg,#f0a50017,#0000 45%)}.ib-chevron{color:var(--accent);width:12px;font-size:11px}.ib-name{font-family:var(--font-title);color:var(--text);letter-spacing:.01em;font-size:13px;font-weight:600}.ib-sub{font-family:var(--font-ui);color:var(--muted);font-size:11px}.ib-total{font-family:var(--font-mono);color:var(--accent);background:var(--accent-dim);border:1px solid #f0a50040;border-radius:999px;margin-left:auto;padding:1px 9px;font-size:11px}.ib-inner{border-top:1px solid var(--border);background:repeating-linear-gradient(0deg, #ffffff03 0 1px, transparent 1px 3px), radial-gradient(700px 320px at 85% -40%, #f0a5000f, transparent 60%), var(--bg);flex-direction:column;min-height:0;max-height:46vh;display:flex}.ib-tabs{flex-wrap:wrap;flex-shrink:0;gap:8px;padding:12px 20px 10px;display:flex}.ib-tab{cursor:pointer;background:var(--surface);border:1px solid var(--border);color:var(--text-secondary);font-family:var(--font-ui);border-radius:9px;align-items:center;gap:8px;padding:7px 13px;font-size:12px;transition:border-color .15s,color .15s,box-shadow .15s;display:flex}.ib-tab .n{font-family:var(--font-mono);background:var(--surface2);color:var(--muted);border-radius:999px;padding:1px 7px;font-size:10.5px}.ib-tab:hover{border-color:var(--border2);color:var(--text)}.ib-tab.on{border-color:var(--accent);color:#fff;box-shadow:0 0 0 1px #f0a50059,0 10px 26px -18px #f0a500cc}.ib-tab.on .n{background:var(--accent-dim);color:var(--accent)}.ib-list{min-height:0;padding:0 20px 16px;overflow-y:auto}.ib-list::-webkit-scrollbar{width:4px}.ib-list::-webkit-scrollbar-track{background:0 0}.ib-list::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.ib-card{background:linear-gradient(180deg, var(--surface), #0c0e14);border:1px solid var(--border);border-radius:10px;margin-bottom:8px;transition:border-color .15s,box-shadow .15s}.ib-card:hover{border-color:var(--border2)}.ib-card.open{border-color:#34507a;box-shadow:0 16px 44px -30px #000000e6}.ib-head{cursor:pointer;align-items:center;gap:12px;padding:12px 15px;display:flex}.ib-arrow{color:var(--muted);flex-shrink:0;font-size:10px;transition:transform .18s,color .18s}.ib-card.open .ib-arrow{color:var(--accent);transform:rotate(90deg)}.ib-idx{font-family:var(--font-mono);color:var(--accent);flex-shrink:0;min-width:22px;font-size:12px;font-weight:700}.ib-title{font-family:var(--font-title);color:var(--text);flex:1;min-width:0;font-size:14px;font-weight:500}.ib-tags{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:5px;display:flex}.tg{font-family:var(--font-mono);background:var(--surface2);color:var(--text-secondary);border:1px solid var(--border);white-space:nowrap;border-radius:5px;padding:2px 7px;font-size:10px}.tg.lc{color:var(--todo-fg);border-color:#5b8cff4d}.tg.hard{color:var(--hard);border-color:#ff4d6b4d}.tg.easy{color:var(--easy);border-color:#00d4aa4d}.tg.med{color:var(--accent);border-color:#f0a5004d}.ib-src{font-family:var(--font-ui);color:var(--muted);white-space:nowrap;flex-shrink:0;font-size:10.5px}.ib-body{border-top:1px solid var(--border);padding:2px 15px 16px;animation:.22s ib-fade}@keyframes ib-fade{0%{opacity:0;transform:translateY(-4px)}to{opacity:1}}.ib-sec{margin-top:14px}.ib-lbl{font-family:var(--font-mono);letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:7px;font-size:10px}.ib-desc{color:var(--text);white-space:pre-wrap;font-size:13px;line-height:1.7}.ib-io{border:1px solid var(--border);font-family:var(--font-mono);white-space:pre-wrap;background:#0b0d13;border-radius:7px;margin-bottom:6px;padding:9px 12px;font-size:12px;line-height:1.6}.ib-io .k{color:var(--teal)}.ib-io .v{color:#e9c46a}.ib-codewrap{border:1px solid var(--border);background:#0b0d13;border-radius:8px;overflow:hidden}.ib-codetabs{border-bottom:1px solid var(--border);background:#0d1017;display:flex}.ib-ct{font-family:var(--font-mono);cursor:pointer;color:var(--muted);border-right:1px solid var(--border);padding:7px 15px;font-size:11px}.ib-ct.on{color:var(--accent);box-shadow:inset 0 -2px 0 var(--accent);background:#0b0d13}.ib-pre{font-family:var(--font-mono);color:#cfd6e4;white-space:pre;margin:0;padding:13px 15px;font-size:12px;line-height:1.7;overflow-x:auto}.ib-pre::-webkit-scrollbar{height:5px}.ib-pre::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.ib-line .cm{color:#5f6678;font-style:italic}.ib-explain{white-space:pre-wrap;color:var(--text);font-size:13px;line-height:1.75}.ib-lc{font-family:var(--font-ui);color:var(--text-secondary);border:1px solid var(--border);border-radius:5px;padding:4px 11px;font-size:11.5px;text-decoration:none;transition:border-color .12s,color .12s;display:inline-block}.ib-lc:hover{border-color:var(--accent);color:var(--accent)}:root{--bg:#09090d;--surface:#0f1117;--surface2:#171b25;--surface3:#1e2332;--border:#20263a;--border2:#2a3148;--accent:#f0a500;--accent-dim:#f0a5001a;--teal:#00d4aa;--teal-dim:#00d4aa1a;--purple:#b464ff;--text:#ccd0dc;--text-secondary:#8b93a8;--muted:#424d66;--easy:#00d4aa;--medium:#f0a500;--hard:#ff4d6b;--done-fg:#00d4aa;--prog-fg:#f0a500;--todo-fg:#5b8cff;--rail-width:210px;--topbar-height:52px;--statusbar-height:26px;--font-ui:"DM Mono", "Cascadia Code", monospace;--font-title:"Sora", system-ui, sans-serif;--font-mono:"JetBrains Mono", "Cascadia Code", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{margin:0}.app{font-family:var(--font-ui);background:var(--bg);color:var(--text);flex-direction:column;height:100vh;font-size:13px;display:flex;overflow:hidden}.topbar{height:var(--topbar-height);flex-shrink:0}.page{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.topnav{align-items:stretch;gap:2px;height:100%;margin-right:auto;display:flex}.navlink{height:100%;font-family:var(--font-ui);color:var(--text-secondary);white-space:nowrap;border-bottom:2px solid #0000;align-items:center;padding:0 14px;font-size:12.5px;text-decoration:none;transition:color .12s,border-color .12s;display:flex}.navlink:hover{color:var(--text)}.navlink.active{color:var(--accent);border-bottom-color:var(--accent)}.topbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:10;align-items:center;gap:20px;padding:0 20px;display:flex;position:relative}.topbar:before{content:"";pointer-events:none;background:linear-gradient(90deg,#0000,#f0a50033,#0000);height:1px;position:absolute;top:0;left:0;right:0}.topbar h1{font-family:var(--font-ui);color:var(--muted);letter-spacing:.2em;text-transform:uppercase;white-space:nowrap;flex-shrink:0;font-size:10.5px;font-weight:500}.stats{white-space:nowrap;flex-shrink:0;align-items:center;gap:6px;display:flex}.stat-chip{font-family:var(--font-mono);background:var(--surface2);border:1px solid var(--border);border-radius:20px;align-items:center;gap:6px;padding:2px 8px 2px 6px;font-size:14px;font-weight:500;display:flex}.stat-dot{flex-shrink:0;display:inline-block}.s-done{color:var(--done-fg);background:#00d4aa0f;border-color:#00d4aa33}.s-prog{color:var(--prog-fg);background:#f0a5000f;border-color:#f0a50033}.s-todo{color:var(--todo-fg);background:#5b8cff0f;border-color:#5b8cff33}.s-ns{color:var(--muted);border-color:var(--border)}.stat-total{font-family:var(--font-mono);color:var(--muted);padding:0 4px;font-size:13px}.search{background:var(--surface2);border:1px solid var(--border);min-width:140px;max-width:280px;color:var(--text);font-size:12.5px;font-family:var(--font-ui);border-radius:5px;outline:none;flex:1;padding:5px 11px;transition:border-color .12s,box-shadow .12s}.search:focus{border-color:var(--accent);box-shadow:0 0 0 3px #f0a5000f}.search::placeholder{color:var(--muted)}.help-btn{border:1px solid var(--border2);background:var(--surface2);width:26px;height:26px;color:var(--muted);font-family:var(--font-ui);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;font-size:13px;transition:border-color .1s,color .1s;display:flex}.help-btn:hover{border-color:var(--accent);color:var(--accent)}.lang-toggle{flex-shrink:0;gap:3px;display:flex}.fbtn{background:var(--surface2);border:1px solid var(--border);color:var(--muted);font-size:11.5px;font-family:var(--font-ui);cursor:pointer;white-space:nowrap;border-radius:4px;padding:3px 9px;transition:border-color .1s,color .1s}.fbtn:hover{border-color:var(--text-secondary);color:var(--text-secondary)}.fbtn.active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.problems-page{flex-direction:column;height:100%;min-height:0;display:flex;overflow:hidden}.main{flex:1;min-height:0;display:flex;overflow:hidden}.rail-search{background:var(--surface2);border:1px solid var(--border);width:calc(100% - 24px);color:var(--text);font-size:12px;font-family:var(--font-ui);border-radius:5px;outline:none;margin:10px 12px 4px;padding:6px 10px;transition:border-color .12s,box-shadow .12s;display:block}.rail-search:focus{border-color:var(--accent);box-shadow:0 0 0 3px #f0a5000f}.rail-search::placeholder{color:var(--muted)}.filter-rail{width:var(--rail-width);background:var(--surface);border-right:1px solid var(--border);flex-shrink:0;padding:4px 0 16px;overflow:hidden auto}.filter-rail::-webkit-scrollbar{width:3px}.filter-rail::-webkit-scrollbar-track{background:0 0}.filter-rail::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.rail-label{font-family:var(--font-ui);letter-spacing:.18em;text-transform:uppercase;color:var(--muted);opacity:.55;padding:14px 12px 5px;font-size:9px;font-weight:500;display:block}.rail-btn{text-align:left;width:100%;font-family:var(--font-ui);color:var(--text-secondary);cursor:pointer;white-space:nowrap;text-overflow:ellipsis;background:0 0;border:none;border-radius:0;align-items:center;gap:8px;padding:6px 12px;font-size:12px;transition:background .1s,color .1s;display:flex;overflow:hidden}.rail-btn:hover{background:var(--surface2);color:var(--text)}.rail-btn.active{background:var(--accent-dim);color:var(--accent)}.rail-btn.active-teal{background:var(--teal-dim);color:var(--teal)}.rail-btn.active-blue{color:var(--todo-fg);background:#5b8cff1a}.rail-dot{opacity:.55;background:currentColor;border-radius:50%;flex-shrink:0;width:5px;height:5px}.rail-divider{background:var(--border);opacity:.5;height:1px;margin:8px 12px}.rail-select{background:var(--surface2);border:1px solid var(--border);width:calc(100% - 24px);color:var(--text-secondary);font-size:11.5px;font-family:var(--font-ui);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23424d66' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;background-color:var(--surface2);border-radius:4px;outline:none;margin:2px 12px 0;padding:5px 24px 5px 8px;transition:border-color .12s;display:block}.rail-select:focus{border-color:var(--accent);color:var(--text)}.rail-select option{background:var(--surface2);color:var(--text)}.table-wrap{flex:1;min-width:0;overflow:hidden auto}.table-wrap::-webkit-scrollbar{width:4px}.table-wrap::-webkit-scrollbar-track{background:0 0}.table-wrap::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}table{border-collapse:collapse;table-layout:fixed;width:100%}thead tr{background:var(--surface2);border-bottom:1px solid var(--border);z-index:2;position:sticky;top:0}th{text-align:left;height:34px;font-family:var(--font-ui);color:var(--muted);text-transform:uppercase;letter-spacing:.13em;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;padding:0 12px;font-size:9px;font-weight:500;transition:color .1s}th:hover{color:var(--text-secondary)}th.sorted-asc:after{content:" ↑";color:var(--accent)}th.sorted-desc:after{content:" ↓";color:var(--accent)}tbody tr{cursor:pointer;border-bottom:1px solid #20263acc;transition:background 70ms}tbody tr:hover{background:var(--surface2)}tbody tr.focused{background:var(--surface2);box-shadow:inset 2px 0 0 var(--accent)}tbody tr.selected{box-shadow:inset 2px 0 0 var(--accent);background:#f0a5000a}td{white-space:nowrap;text-overflow:ellipsis;vertical-align:middle;max-width:0;height:50px;padding:0 12px;overflow:hidden}.c-status{text-align:center;width:42px;padding-right:0}.c-id{width:58px;font-family:var(--font-mono);font-variant-numeric:tabular-nums;color:var(--muted);font-size:11.5px}.c-title{font-family:var(--font-title);color:var(--text);font-size:13.5px;font-weight:400}.c-diff{width:70px;font-family:var(--font-ui);font-size:11.5px}.c-topic{width:160px;font-family:var(--font-ui);color:var(--muted);font-size:11.5px}.c-lists{width:140px}.diff-E{color:var(--easy)}.diff-M{color:var(--medium)}.diff-H{color:var(--hard)}.status-circle,.stat-dot{vertical-align:middle;border-radius:50%;flex-shrink:0;width:10px;height:10px;display:inline-block}.stat-dot{width:8px;height:8px}.sc-done{background:var(--done-fg);box-shadow:0 0 6px #00d4aa66}.sc-in_progress{background:linear-gradient(90deg, var(--prog-fg) 50%, transparent 50%);border:1.5px solid var(--prog-fg)}.sc-todo{border:1.5px solid var(--todo-fg);background:0 0}.sc-haventdone{border:1.5px solid var(--muted);opacity:.4;background:0 0}.badge{font-family:var(--font-mono);letter-spacing:.02em;border-radius:3px;margin-right:3px;padding:2px 5px;font-size:9.5px;font-weight:500;display:inline-block}.badge-hot{color:var(--teal);background:#00d4aa17;border:1px solid #00d4aa29}.badge-top{color:var(--accent);background:#f0a50017;border:1px solid #f0a50029}.detail-panel{border-left:1px solid var(--border);background:var(--surface);flex-direction:column;flex-shrink:0;width:400px;display:flex;overflow:hidden}.detail-header{border-bottom:1px solid var(--border);align-items:flex-start;gap:10px;padding:14px 16px 13px;display:flex}.detail-header h2{font-family:var(--font-title);color:var(--text);flex:1;font-size:14px;font-weight:500;line-height:1.45}.detail-close{color:var(--muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0;font-size:16px;line-height:1;transition:color .1s}.detail-close:hover{color:var(--text)}.detail-meta{border-bottom:1px solid var(--border);font-family:var(--font-ui);color:var(--muted);flex-wrap:wrap;align-items:center;gap:10px;padding:10px 16px;font-size:11.5px;display:flex}.detail-actions{border-bottom:1px solid var(--border);gap:7px;padding:10px 16px;display:flex}.action-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text-secondary);font-family:var(--font-ui);cursor:pointer;border-radius:4px;padding:5px 12px;font-size:11.5px;text-decoration:none;transition:border-color .1s,color .1s;display:inline-block}.action-btn:hover{border-color:var(--accent);color:var(--accent)}.detail-body{font-family:var(--font-ui);color:var(--muted);white-space:pre-wrap;flex:1;padding:14px 16px;font-size:12.5px;line-height:1.7;overflow-y:auto}.detail-body::-webkit-scrollbar{width:3px}.detail-body::-webkit-scrollbar-track{background:0 0}.detail-body::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.statusbar{background:var(--surface);border-top:1px solid var(--border);font-family:var(--font-ui);color:var(--muted);align-items:center;padding:0 16px;font-size:10.5px;display:flex}.help-overlay{z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0000008c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.help-modal{background:var(--surface);border:1px solid var(--border2);border-radius:8px;width:320px;overflow:hidden;box-shadow:0 24px 64px #0009}.help-header{border-bottom:1px solid var(--border);font-family:var(--font-ui);color:var(--text-secondary);letter-spacing:.1em;text-transform:uppercase;justify-content:space-between;align-items:center;padding:12px 16px;font-size:11px;font-weight:500;display:flex}.help-grid{font-family:var(--font-ui);color:var(--text-secondary);grid-template-columns:auto 1fr;align-items:center;gap:6px 16px;padding:16px;font-size:12.5px;display:grid}.help-grid kbd{background:var(--surface2);border:1px solid var(--border2);font-family:var(--font-mono);color:var(--text);white-space:nowrap;border-radius:4px;justify-self:start;padding:2px 7px;font-size:11.5px}.empty{text-align:center;font-family:var(--font-ui);color:var(--muted);opacity:.5;padding:80px 0;font-size:12.5px}.dashboard{flex:1;min-height:0;overflow-y:auto}.dashboard::-webkit-scrollbar{width:4px}.dashboard::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.dash-inner{max-width:880px;margin:0 auto;padding:32px 24px 56px}.dash-hero{background:radial-gradient(600px 200px at 90% -60%, #f0a5001a, transparent 60%), var(--surface);border:1px solid var(--border);border-radius:14px;margin-bottom:28px;padding:24px 26px}.dash-hero-text{align-items:baseline;gap:14px;margin-bottom:16px;display:flex}.dash-hero-pct{font-family:var(--font-title);color:var(--accent);font-size:46px;font-weight:700;line-height:1}.dash-hero-pct span{color:var(--text-secondary);margin-left:2px;font-size:22px}.dash-hero-sub{font-family:var(--font-ui);color:var(--text-secondary);font-size:13px}.dash-hero-bar{background:var(--surface3);border-radius:999px;height:8px;overflow:hidden}.dash-hero-fill{background:linear-gradient(90deg, var(--teal), var(--accent));border-radius:999px;height:100%;transition:width .4s}.dash-section{margin-bottom:26px}.dash-h{font-family:var(--font-ui);letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:11px;font-size:9.5px;font-weight:500}.dash-grid{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px;display:grid}.dash-stat{background:var(--surface);border:1px solid var(--border);border-radius:11px;flex-direction:column;gap:4px;padding:15px 16px;text-decoration:none;transition:border-color .12s,transform .12s;display:flex}.dash-stat:hover{border-color:var(--border2);transform:translateY(-2px)}.dash-stat-n{font-family:var(--font-mono);color:var(--text);font-variant-numeric:tabular-nums;font-size:26px;font-weight:600}.dash-stat-l{font-family:var(--font-ui);color:var(--text-secondary);font-size:11.5px}.dash-stat.s-done .dash-stat-n{color:var(--done-fg)}.dash-stat.s-prog .dash-stat-n{color:var(--prog-fg)}.dash-stat.s-todo .dash-stat-n{color:var(--todo-fg)}.dash-stat.d-easy .dash-stat-n{color:var(--easy)}.dash-stat.d-med .dash-stat-n{color:var(--medium)}.dash-stat.d-hard .dash-stat-n{color:var(--hard)}.dash-cards{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;display:grid}.dash-card{background:linear-gradient(180deg, var(--surface), #0c0e14);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:6px;padding:18px;text-decoration:none;transition:border-color .12s,transform .12s,box-shadow .12s;display:flex}.dash-card:hover{border-color:var(--border2);transform:translateY(-2px);box-shadow:0 16px 40px -28px #000000e6}.dash-card-title{font-family:var(--font-title);color:var(--text);font-size:15px;font-weight:600}.dash-card-sub{font-family:var(--font-ui);color:var(--muted);font-size:11.5px}.interview-page{flex:1;min-height:0;display:flex;overflow:hidden}.rail-add{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.rail-add .rail-search{flex:100%;margin:0}.rail-add .rail-btn{flex:none}.rail-add-msg{color:var(--muted);flex:100%;font-size:11px}.workspace-overlay{z-index:50;background:#040508b8;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.workspace{background:var(--surface);border:1px solid var(--border2);border-radius:10px;flex-direction:column;width:100%;max-width:1240px;height:100%;max-height:92vh;display:flex;overflow:hidden;box-shadow:0 24px 64px #00000080}.ws-loading{color:var(--muted);margin:auto;font-size:24px}.ws-header{border-bottom:1px solid var(--border);background:var(--surface2);align-items:center;gap:10px;padding:12px 16px;display:flex}.ws-header h2{font-family:var(--font-title);color:var(--text);margin:0;font-size:15px}.ws-lc{color:var(--accent);margin-left:auto;font-size:12px;text-decoration:none}.ws-lc:hover{text-decoration:underline}.ws-body{flex:1;grid-template-columns:1fr 1fr;min-height:0;display:grid}.ws-statement{border-right:1px solid var(--border);color:var(--text);padding:18px 22px;font-size:13px;line-height:1.62;overflow-y:auto}.ws-statement h1,.ws-statement h2,.ws-statement h3{font-family:var(--font-title);color:#e7eaf2;margin:1.1em 0 .5em}.ws-statement h1{font-size:16px}.ws-statement h2{font-size:14px}.ws-statement pre{background:var(--bg);border:1px solid var(--border);font-family:var(--font-mono);color:#b7c0d6;border-radius:6px;padding:10px 12px;font-size:12px;overflow-x:auto}.ws-statement code{font-family:var(--font-mono);color:var(--accent);font-size:12px}.ws-statement pre code{color:inherit}.ws-statement a{color:var(--accent)}.ws-statement img{max-width:100%}.ws-editor-pane{flex-direction:column;min-height:0;display:flex}.ws-toolbar{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:8px 12px;display:flex}.ws-langs{gap:4px;display:flex}.ws-lang-btn{font-family:var(--font-ui);cursor:pointer;background:var(--surface2);color:var(--muted);border:1px solid var(--border);border-radius:5px;padding:4px 10px;font-size:11.5px}.ws-lang-btn:hover{color:var(--text)}.ws-lang-btn.active{background:var(--accent-dim);color:var(--accent);border-color:#f0a5004d}.ws-actions{align-items:center;gap:10px;margin-left:auto;display:flex}.ws-savestate{color:var(--muted);text-align:right;min-width:48px;font-size:11px}.ws-run{font-family:var(--font-ui);cursor:pointer;background:var(--accent);color:#1a1200;border:none;border-radius:5px;padding:5px 14px;font-size:12px;font-weight:500}.ws-run:hover{filter:brightness(1.08)}.ws-run:disabled{opacity:.5;cursor:default}.ws-editor{resize:none;background:var(--bg);color:#d4dae8;min-height:0;font-family:var(--font-mono);tab-size:2;border:none;outline:none;flex:1;padding:12px 14px;font-size:13px;line-height:1.5}.ws-results{border-top:1px solid var(--border);background:var(--surface);max-height:38%;padding:8px 12px;overflow-y:auto}.ws-hint{color:var(--muted);font-size:11.5px}.ws-error{color:var(--hard);font-family:var(--font-mono);white-space:pre-wrap;margin:0;font-size:11.5px}.ws-summary{margin-bottom:6px;font-size:12.5px;font-weight:600}.ws-summary.ok{color:var(--teal)}.ws-summary.bad{color:var(--hard)}.ws-case{font-family:var(--font-mono);color:var(--text);align-items:baseline;gap:8px;padding:2px 0;font-size:11.5px;display:flex}.ws-case-i{color:var(--muted)}.ws-case.st-pass .ws-case-status{color:var(--teal)}.ws-case.st-fail .ws-case-status{color:var(--hard)}.ws-case.st-error .ws-case-status{color:var(--medium)}.ws-case.st-skip .ws-case-status{color:var(--muted)}.ws-diff{color:var(--muted);gap:12px;display:flex}.ws-diff .exp{color:var(--teal)}.ws-diff .act{color:var(--hard)}.ws-msg{color:var(--medium)}@media (width<=860px){.ws-body{grid-template-columns:1fr}.ws-statement{border-right:none;border-bottom:1px solid var(--border)}}.stat-strip{background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:14px;padding:9px 16px;display:flex}.stat-progress{align-items:center;gap:8px;display:flex}.stat-ring{display:block}.stat-progress-txt{flex-direction:column;line-height:1.15;display:flex}.stat-progress-txt b{font-family:var(--font-mono);color:var(--text);font-size:14px;font-weight:600}.stat-progress-txt span{color:var(--muted);font-size:10px}.stat-group{align-items:center;gap:3px;display:flex}.stat-sep{background:var(--border);width:1px;height:20px}.chip{cursor:pointer;color:var(--muted);font-family:var(--font-ui);background:0 0;border:1px solid #0000;border-radius:6px;align-items:center;gap:6px;padding:4px 9px;font-size:12px;transition:background .12s,color .12s;display:inline-flex}.chip:hover{background:var(--surface2);color:var(--text)}.chip.active{background:var(--accent-dim);color:var(--accent);border-color:#f0a50047}.chip-ic{color:var(--muted);display:inline-flex}.chip.active .chip-ic{color:var(--accent)}.chip-n{font-family:var(--font-mono);color:var(--text);font-size:12.5px}.chip.active .chip-n{color:var(--accent)}.chip-l{font-size:11px}.chip-dot{opacity:.55;border-radius:50%;flex-shrink:0;width:7px;height:7px}.filter-bar{background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:8px;padding:8px 16px;display:flex}.fb-search{background:var(--surface2);border:1px solid var(--border);min-width:200px;height:30px;color:var(--text);font-family:var(--font-ui);border-radius:6px;padding:0 10px;font-size:12.5px}.fb-search:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #f0a5000f}.fb-search::placeholder{color:var(--muted)}.fb-select{cursor:pointer;background:var(--surface2);border:1px solid var(--border);height:30px;color:var(--text);font-family:var(--font-ui);border-radius:6px;padding:0 8px;font-size:12.5px}.fb-select:focus{border-color:var(--accent);outline:none}.fb-clear{cursor:pointer;border:1px solid var(--border);height:30px;color:var(--muted);font-family:var(--font-ui);background:0 0;border-radius:6px;padding:0 12px;font-size:12px}.fb-clear:hover{color:var(--text);border-color:var(--border2)}.fb-spacer{flex:1}.fb-add{align-items:center;gap:6px;display:flex}.fb-add-input{min-width:120px}.fb-fetch{cursor:pointer;background:var(--accent);color:#1a1200;height:30px;font-family:var(--font-ui);border:none;border-radius:6px;padding:0 12px;font-size:12px;font-weight:500}.fb-fetch:hover{filter:brightness(1.08)}.fb-fetch:disabled{opacity:.5;cursor:default}.fb-add-msg{color:var(--muted);font-size:11px}html,body{max-width:100%;overflow-x:hidden}@media (width<=768px){.app{height:100dvh}.topbar{height:auto;min-height:var(--topbar-height);gap:10px;padding:0 12px}.topbar h1{letter-spacing:.14em;font-size:9.5px}.topnav{-webkit-overflow-scrolling:touch;scrollbar-width:none;overflow:auto hidden}.topnav::-webkit-scrollbar{display:none}.navlink{min-height:44px;padding:0 11px}.fbtn{min-height:36px;padding:6px 11px}.help-btn{width:34px;height:34px}.stat-strip{gap:10px;padding:8px 12px}.chip{min-height:40px;padding:6px 10px}.stat-sep{display:none}.filter-bar{gap:8px;padding:8px 12px}.fb-search{flex:100%;width:100%;min-width:0;height:40px;font-size:16px}.fb-select,.fb-clear{height:40px}.fb-spacer{display:none}.fb-add{flex:100%}.fb-add-input{flex:auto;height:40px}.fb-fetch{height:40px}.table-wrap{overflow-x:hidden}table{table-layout:auto}th:nth-child(5),td.c-topic,th:nth-child(6),td.c-lists{display:none}.c-title{white-space:normal;font-size:14px}td{height:52px}.c-id{width:48px}.c-diff{width:62px}.workspace-overlay{padding:0}.workspace{border:none;border-radius:0;max-width:100%;height:100%;max-height:100dvh}.ws-header{padding:10px 12px}.ws-header h2{font-size:14px}.ws-statement{padding:14px 16px;font-size:14px}.ws-toolbar{flex-wrap:wrap;gap:8px}.ws-lang-btn,.ws-run{min-height:36px}.ws-results{max-height:44%}.dash-inner{padding:20px 14px 40px}.dash-hero{padding:18px 16px}.dash-hero-pct{font-size:38px}}@media (width<=480px){.topbar h1{display:none}.stat-strip{gap:8px}.stat-progress-txt span,.chip-l{display:none}.filter-bar{gap:6px}th:nth-child(4),td.c-diff{display:none}.c-id{width:42px;font-size:11px}.c-title{font-size:13.5px}td,th{padding:0 10px}.ws-statement{padding:12px 13px;font-size:13.5px}.ws-statement pre{font-size:11.5px}.ws-editor{padding:10px 12px;font-size:12.5px}.help-modal{width:calc(100vw - 24px)}.dash-hero-text{flex-direction:column;gap:4px}}
