
:root{--bg:#0c0c10;--bg2:#13131a;--bg3:#1a1a24;--bg4:#22222e;--border:rgba(255,255,255,.07);--border2:rgba(255,255,255,.13);--text:#eeeef5;--text2:#9090aa;--text3:#55556a;--blue:#5b9cf6;--blue-bg:rgba(91,156,246,.1);--teal:#34d4a4;--teal-bg:rgba(52,212,164,.1);--amber:#f5a623;--amber-bg:rgba(245,166,35,.1);--purple:#a78bfa;--purple-bg:rgba(167,139,250,.1);--coral:#f87171;--coral-bg:rgba(248,113,113,.1);--green:#4ade80;--green-bg:rgba(74,222,128,.1);--r:8px;--rlg:14px;--mono:'JetBrains Mono',monospace;--sans:'Outfit',sans-serif;--display:'Syne',sans-serif;--sw:240px;--th:54px}
*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden;-webkit-overflow-scrolling:touch}
body{font-family:var(--sans);background:var(--bg);color:var(--text);font-size:15px;line-height:1.6}
#app{display:flex;height:100vh;overflow:hidden;-webkit-overflow-scrolling:touch}
#sidebar{width:var(--sw);flex-shrink:0;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;transition:transform .3s;z-index:100}
#si{flex:1;overflow-y:auto;padding:1rem .75rem}
#si::-webkit-scrollbar{width:3px}#si::-webkit-scrollbar-thumb{background:var(--border2);border-radius:10px}
.brand{padding:.75rem .5rem 1rem;margin-bottom:.5rem;border-bottom:1px solid var(--border)}
.brand-top{display:flex;align-items:center;gap:8px}
.brand-back{background:var(--bg3);border:1px solid var(--border2);color:var(--text3);border-radius:6px;padding:3px 8px;font-size:11px;font-family:var(--sans);cursor:pointer;text-decoration:none;transition:color .15s,background .15s}
.brand-back:hover{color:var(--text);background:var(--bg4)}
.brand h1{font-family:var(--display);font-size:17px;font-weight:800;color:var(--text)}
.brand p{font-size:11px;color:var(--text3);margin-top:3px;letter-spacing:.05em;text-transform:uppercase}
.ng{margin-bottom:.5rem}.nl{font-size:10px;font-weight:600;color:var(--text3);letter-spacing:.1em;text-transform:uppercase;padding:.5rem .5rem .25rem}
.ni{display:flex;align-items:center;gap:9px;padding:7px 10px;border-radius:var(--r);font-size:13px;color:var(--text2);cursor:pointer;border:none;background:transparent;width:100%;text-align:left;transition:background .15s,color .15s}
.ni:hover{background:var(--bg3);color:var(--text)}.ni.on{background:var(--bg4);color:var(--text)}
.ndot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
#topbar{display:none;height:var(--th);background:var(--bg2);border-bottom:1px solid var(--border);align-items:center;padding:0 1rem;gap:12px;flex-shrink:0}
#mbtn{background:none;border:none;color:var(--text2);cursor:pointer;padding:6px;border-radius:6px}
#topbar h1{font-family:var(--display);font-size:16px;font-weight:800;flex:1}
#overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:99}
#main{flex:1;overflow-y:auto;display:flex;flex-direction:column}
#main::-webkit-scrollbar{width:4px}#main::-webkit-scrollbar-thumb{background:var(--border2);border-radius:10px}
.page{display:none;overflow:visible;padding:2.5rem 2rem;max-width:960px;width:100%}.page.on{display:block}
.ptitle{font-family:var(--display);font-size:26px;font-weight:800;color:var(--text);letter-spacing:-.03em;margin-bottom:.3rem}
.psub{font-size:13px;color:var(--text2);margin-bottom:2rem;padding-bottom:1.25rem;border-bottom:1px solid var(--border)}
h2.s{font-family:var(--display);font-size:17px;font-weight:700;color:var(--text);margin:2.5rem 0 .5rem;display:flex;align-items:center;gap:8px}
h2.s .bar{width:3px;height:17px;border-radius:2px;flex-shrink:0}
h3.ss{font-size:13px;font-weight:600;color:var(--text3);margin:1.25rem 0 .5rem;text-transform:uppercase;letter-spacing:.07em}
p.expl{font-size:14px;color:var(--text2);line-height:1.75;margin:.5rem 0 .75rem}
p.expl code{font-family:var(--mono);font-size:12px;background:var(--bg3);border:1px solid var(--border2);padding:1px 5px;border-radius:4px;color:var(--blue)}
p.expl strong{color:var(--text);font-weight:600}
ul.expl-list{padding-left:1.25rem;margin:.5rem 0 .75rem}
ul.expl-list li{font-size:14px;color:var(--text2);line-height:1.75;margin:.2rem 0}
ul.expl-list li::marker{color:var(--text3)}
ul.expl-list li code{font-family:var(--mono);font-size:12px;background:var(--bg3);padding:1px 5px;border-radius:4px;color:var(--blue)}
ul.expl-list li strong{color:var(--text)}
.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--rlg);padding:1.25rem 1.5rem;margin-bottom:1rem}
.g2{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:1rem;margin-bottom:1rem}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1rem}
.stat{background:var(--bg3);border-radius:var(--r);padding:1rem;text-align:center;border:1px solid var(--border)}
.stat-n{font-family:var(--display);font-size:28px;font-weight:800;line-height:1}
.stat-l{font-size:10px;color:var(--text3);margin-top:4px;text-transform:uppercase;letter-spacing:.06em}
.cw{position:relative;margin:.75rem 0}
.cl{font-size:10px;font-weight:600;color:var(--text3);letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px}
pre.code{font-family:var(--mono);font-size:12.5px;line-height:1.8;background:var(--bg);border:1px solid var(--border);border-radius:var(--r);padding:1rem 1.25rem;overflow-x:auto;color:var(--text2);tab-size:4}
pre.code::-webkit-scrollbar{height:3px}pre.code::-webkit-scrollbar-thumb{background:var(--border2)}
.cpbtn{position:absolute;top:26px;right:6px;background:var(--bg3);border:1px solid var(--border2);border-radius:5px;color:var(--text3);font-size:11px;padding:3px 8px;cursor:pointer;font-family:var(--mono);transition:color .15s,background .15s}
.cpbtn:hover{color:var(--text);background:var(--bg4)}
.kw{color:#a78bfa}.fn{color:#5b9cf6}.st{color:#34d4a4}.nb{color:#f5a623}.cm{color:#44445a;font-style:italic}.op{color:#f87171}.cl2{color:#fb923c}
.badge{display:inline-block;font-size:10px;font-weight:600;padding:2px 8px;border-radius:20px;letter-spacing:.03em}
.bb{background:var(--blue-bg);color:var(--blue)}.bt{background:var(--teal-bg);color:var(--teal)}.ba{background:var(--amber-bg);color:var(--amber)}.bp{background:var(--purple-bg);color:var(--purple)}.bc{background:var(--coral-bg);color:var(--coral)}.bg{background:var(--green-bg);color:var(--green)}
.callout{border-radius:var(--r);padding:10px 14px;margin:.75rem 0;font-size:13.5px;line-height:1.65;border-left:3px solid}
.ct{background:var(--amber-bg);color:#fbbf24;border-color:var(--amber)}.cw2{background:var(--coral-bg);color:#fca5a5;border-color:var(--coral)}.ci{background:var(--blue-bg);color:#93c5fd;border-color:var(--blue)}.cp{background:var(--purple-bg);color:#c4b5fd;border-color:var(--purple)}.cg{background:var(--green-bg);color:#86efac;border-color:var(--green)}
.callout strong{font-weight:600;color:inherit}.callout code{font-family:var(--mono);font-size:12px;background:rgba(255,255,255,.08);padding:1px 5px;border-radius:4px}
.row{display:flex;gap:12px;padding:8px 0;border-bottom:1px solid var(--border);align-items:flex-start;font-size:13.5px}
.row:last-child{border-bottom:none;padding-bottom:0}.row:first-child{padding-top:0}
.rk{font-weight:600;color:var(--text);min-width:150px;flex-shrink:0;padding-top:1px}
.rv{color:var(--text2);line-height:1.6}.rv code{font-family:var(--mono);font-size:12px;background:var(--bg);border:1px solid var(--border2);padding:1px 5px;border-radius:4px;color:var(--blue)}
.tbl{width:100%;border-collapse:collapse;font-size:13px;margin:.75rem 0}
.tbl th{text-align:left;padding:8px 12px;background:var(--bg3);color:var(--text3);font-size:11px;letter-spacing:.06em;text-transform:uppercase;font-weight:600;border-bottom:1px solid var(--border)}
.tbl td{padding:9px 12px;border-bottom:1px solid var(--border);color:var(--text2);vertical-align:top}
.tbl td:first-child{font-family:var(--mono);font-size:12px;color:var(--blue)}.tbl tr:last-child td{border-bottom:none}.tbl tr:hover td{background:var(--bg3)}
.formula{font-family:var(--mono);font-size:13px;color:var(--teal);background:var(--teal-bg);border:1px solid rgba(52,212,164,.2);border-radius:var(--r);padding:10px 14px;margin:.5rem 0;display:block}
.freq{display:flex;align-items:center;gap:10px;margin:5px 0}
.freq-l{font-size:13px;color:var(--text);min-width:210px;flex-shrink:0}
.freq-y{font-size:11px;color:var(--text3);min-width:90px;flex-shrink:0;text-align:right}
.freq-t{flex:1;background:var(--bg4);border-radius:3px;height:5px}
.freq-f{height:5px;border-radius:3px}
.itabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:1.25rem}
.itab{padding:5px 14px;border-radius:20px;border:1px solid var(--border2);font-size:12.5px;cursor:pointer;background:transparent;color:var(--text2);font-family:var(--sans);transition:all .15s}
.itab:hover{background:var(--bg3);color:var(--text)}.itab.on{background:var(--bg4);color:var(--text)}
.tpane{display:none}.tpane.on{display:block}
.ed-bar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;padding:.75rem 1rem;background:var(--bg3);border-radius:var(--r) var(--r) 0 0;border:1px solid var(--border);border-bottom:none}
.ed-bar span{font-size:12px;color:var(--text3);flex:1}
.run-btn{background:var(--teal);color:#0a1a14;font-family:var(--sans);font-weight:600;font-size:13px;border:none;border-radius:6px;padding:6px 16px;cursor:pointer;transition:opacity .15s;display:flex;align-items:center;gap:6px}
.run-btn:hover{opacity:.85}.run-btn:disabled{opacity:.4;cursor:not-allowed}
.spin{width:12px;height:12px;border:2px solid rgba(0,0,0,.2);border-top-color:#0a1a14;border-radius:50%;animation:spin .6s linear infinite;display:none}
.run-btn.ld .spin{display:block}.run-btn.ld .ri{display:none}
@keyframes spin{to{transform:rotate(360deg)}}
#ced{font-family:var(--mono);font-size:13px;line-height:1.7;background:var(--bg);color:var(--text);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--r) var(--r);padding:1rem;width:100%;resize:vertical;min-height:200px;max-height:500px;outline:none;tab-size:4}
#ced:focus{border-color:var(--border2)}
.owrap{background:var(--bg);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-top:1rem}
.ohdr{background:var(--bg2);padding:.5rem 1rem;font-size:11px;color:var(--text3);font-weight:600;letter-spacing:.06em;text-transform:uppercase;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border)}
.odot{width:6px;height:6px;border-radius:50%;background:var(--text3)}.odot.ok{background:var(--green)}.odot.err{background:var(--coral)}
#out{font-family:var(--mono);font-size:12.5px;padding:1rem;color:var(--text2);white-space:pre-wrap;min-height:80px;max-height:300px;overflow-y:auto;line-height:1.7}
#out.err{color:var(--coral)}
.snips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:.75rem}
.snip{padding:4px 12px;border-radius:20px;border:1px solid var(--border2);font-size:12px;cursor:pointer;background:transparent;color:var(--text2);font-family:var(--mono);transition:all .15s}
.snip:hover{background:var(--bg3);color:var(--text)}
.py-info{font-size:12px;color:var(--amber);padding:.5rem 1rem;background:var(--amber-bg);border-bottom:1px solid var(--border);border-radius:var(--r) var(--r) 0 0;display:none}
.exo{background:var(--bg2);border:1px solid var(--border);border-radius:var(--rlg);overflow:hidden;margin-bottom:1rem}
.exo-h{padding:1rem 1.25rem;display:flex;align-items:flex-start;gap:10px;cursor:pointer;transition:background .15s}
.exo-h:hover{background:var(--bg3)}
.exo-num{font-family:var(--display);font-size:11px;font-weight:800;background:var(--bg4);border-radius:5px;padding:3px 8px;color:var(--text2);flex-shrink:0}
.exo-ti{font-size:14px;font-weight:600;color:var(--text);flex:1}
.exo-meta{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}
.exo-body{padding:1.25rem;border-top:1px solid var(--border)}
.exo-en{font-size:14px;color:var(--text2);line-height:1.75;margin-bottom:.75rem}
.exo-en strong{color:var(--text)}.exo-en code{font-family:var(--mono);font-size:12px;background:var(--bg3);padding:1px 5px;border-radius:4px;color:var(--blue)}
.exo-par{background:var(--bg3);border-radius:var(--r);padding:.75rem 1rem;margin-bottom:.75rem;font-size:13px;color:var(--text2)}
.exo-par b{color:var(--amber)}
.hint-btn{background:var(--amber-bg);border:1px solid rgba(245,166,35,.2);color:var(--amber);border-radius:6px;padding:5px 12px;font-size:12.5px;cursor:pointer;font-family:var(--sans);transition:opacity .15s;margin-right:8px}
.hint-btn:hover{opacity:.8}
.hbox{background:var(--amber-bg);border-radius:var(--r);padding:.75rem 1rem;font-size:13px;color:#fbbf24;margin:.75rem 0;display:none;border:1px solid rgba(245,166,35,.15)}
.hbox.on{display:block}
.sol-btn{background:var(--teal-bg);border:1px solid rgba(52,212,164,.2);color:var(--teal);border-radius:6px;padding:5px 12px;font-size:12.5px;cursor:pointer;font-family:var(--sans);transition:opacity .15s}
.sol-btn:hover{opacity:.8}
.sbox{margin-top:.75rem;display:none}.sbox.on{display:block}
.regen{background:transparent;border:1px solid var(--border2);color:var(--text2);border-radius:6px;padding:5px 10px;font-size:12px;cursor:pointer;font-family:var(--sans);transition:all .15s;margin-left:auto}
.regen:hover{background:var(--bg3);color:var(--text)}
.qopt{display:block;width:100%;text-align:left;padding:.75rem 1rem;border:1px solid var(--border2);border-radius:var(--r);background:transparent;color:var(--text2);font-size:13.5px;font-family:var(--sans);cursor:pointer;transition:all .15s;margin:.4rem 0}
.qopt:hover{background:var(--bg3);color:var(--text)}.qopt.ok{background:var(--green-bg);border-color:rgba(74,222,128,.3);color:var(--green)}.qopt.ko{background:var(--coral-bg);border-color:rgba(248,113,113,.3);color:var(--coral)}
.qfb{font-size:13px;margin-top:.5rem;padding:.6rem .85rem;border-radius:6px}
.qnext{background:var(--blue);color:#fff;border:none;border-radius:6px;padding:7px 18px;font-size:13px;cursor:pointer;font-family:var(--sans);font-weight:600;margin-top:.75rem;transition:opacity .15s}
.qnext:hover{opacity:.85}
.proj-form{background:var(--bg2);border:1px solid var(--border);border-radius:var(--rlg);padding:1.5rem}
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;margin:1rem 0}
.proj-check{display:flex;align-items:center;gap:8px;padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--r);cursor:pointer;transition:border-color .15s,background .15s}
.proj-check:hover{border-color:var(--border2);background:var(--bg3)}.proj-check.sel{border-color:var(--blue);background:var(--blue-bg)}
.proj-check input{display:none}
.proj-check-dot{width:8px;height:8px;border-radius:50%;background:var(--text3);transition:background .15s}
.proj-check.sel .proj-check-dot{background:var(--blue)}
.proj-check span{font-size:13px;color:var(--text2)}.proj-check.sel span{color:var(--text)}
.proj-range{display:flex;align-items:center;gap:12px;margin:1rem 0}
.proj-range label{font-size:13px;color:var(--text2);min-width:140px}
.proj-range input[type=range]{flex:1}
.proj-range output{font-family:var(--mono);font-size:13px;color:var(--amber);min-width:50px;text-align:right}
.gen-btn{background:var(--blue);color:#fff;border:none;border-radius:8px;padding:10px 28px;font-size:14px;font-family:var(--sans);font-weight:600;cursor:pointer;transition:opacity .15s}
.gen-btn:hover{opacity:.85}
.proj-result{margin-top:1.5rem}
.proj-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--rlg);padding:1.25rem 1.5rem;margin-bottom:1rem;position:relative}
.proj-card h3{font-family:var(--display);font-size:16px;font-weight:700;color:var(--text);margin-bottom:.4rem}
.proj-card p{font-size:13.5px;color:var(--text2);line-height:1.7;margin-bottom:.75rem}
.proj-diff{position:absolute;top:1.25rem;right:1.5rem}
.proj-steps{list-style:none;padding:0;margin-top:.5rem;counter-reset:step}
.proj-steps li{font-size:13px;color:var(--text2);padding:4px 0;display:flex;gap:8px;align-items:flex-start}
.proj-steps li::before{content:counter(step);counter-increment:step;display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--bg4);color:var(--text3);font-size:10px;font-weight:700;flex-shrink:0;margin-top:2px}
@media(max-width:768px){html,body,#app{overflow:auto;-webkit-overflow-scrolling:touch}#sidebar{position:fixed;left:0;top:0;bottom:0;transform:translateX(-100%)}#sidebar.open{transform:translateX(0)}#topbar{display:flex}#app{flex-direction:column}#main{height:calc(100vh - var(--th))}.page{padding:1.5rem 1rem}.ptitle{font-size:22px}.g4{grid-template-columns:repeat(2,1fr)}.row{flex-direction:column;gap:4px}.rk{min-width:unset}}
