*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg0: #060810;--bg1: #0d1117;--bg2: #111827;--bg3: #1a2035;--bg4: #1f2942;--bg5: #263356;--b1: rgba(255,255,255,.05);--b2: rgba(255,255,255,.09);--b3: rgba(255,255,255,.15);--b4: rgba(255,255,255,.22);--amber: #f59e0b;--amber2: #fbbf24;--amberD: rgba(245,158,11,.12);--amberG: rgba(245,158,11,.25);--teal: #14b8a6;--tealD: rgba(20,184,166,.12);--blue: #3b82f6;--blueD: rgba(59,130,246,.12);--purple: #a78bfa;--purpleD: rgba(167,139,250,.12);--green: #22c55e;--greenD: rgba(34,197,94,.1);--red: #f87171;--redD: rgba(248,113,113,.12);--orange: #fb923c;--t1: #f1f5f9;--t2: #94a3b8;--t3: #64748b;--t4: #3f4d63;--mono: "JetBrains Mono","Cascadia Code","Fira Code",monospace;--sans: "Inter","Segoe UI",system-ui,sans-serif}html,body,#root{height:100%;overflow:hidden}body{background:var(--bg0);color:var(--t1);font-family:var(--sans);font-size:13px;line-height:1.6}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--b3);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--b4)}button,input,textarea,select{font-family:var(--sans)}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:220px;min-width:220px;height:100vh;background:var(--bg1);border-right:1px solid var(--b1);display:flex;flex-direction:column}.main{flex:1;display:flex;flex-direction:column;overflow:hidden}.topbar{height:48px;background:var(--bg1);border-bottom:1px solid var(--b1);display:flex;align-items:center;padding:0 16px;gap:10px;flex-shrink:0}.content{flex:1;overflow:hidden}.slogo{padding:12px 14px 10px;border-bottom:1px solid var(--b1);display:flex;align-items:center;gap:8px}.slogo-mark{width:28px;height:28px;background:var(--amber);border-radius:6px;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:11px;font-weight:800;color:#000;flex-shrink:0}.slogo-text{font-size:14px;font-weight:800;color:var(--t1);letter-spacing:-.3px}.slogo-ver{font-size:9px;color:var(--t3);font-family:var(--mono)}.snav{flex:1;padding:8px 6px;overflow-y:auto}.snav-sep{padding:8px 8px 3px;font-size:8.5px;font-weight:700;color:var(--t4);letter-spacing:1.6px;text-transform:uppercase;font-family:var(--mono);margin-top:4px}.nitem{display:flex;align-items:center;gap:8px;padding:7px 9px;border-radius:5px;cursor:pointer;color:var(--t3);font-size:12.5px;font-weight:500;transition:all .12s;position:relative;-webkit-user-select:none;user-select:none}.nitem:hover{background:var(--bg3);color:var(--t2)}.nitem.active{background:var(--amberD);color:var(--amber)}.nitem.active:before{content:"";position:absolute;left:0;top:5px;bottom:5px;width:2.5px;background:var(--amber);border-radius:0 2px 2px 0}.nitem-ico{width:15px;height:15px;flex-shrink:0}.nitem-badge{margin-left:auto;font-family:var(--mono);font-size:8.5px;font-weight:700;padding:1px 5px;border-radius:10px;background:var(--amberD);color:var(--amber);letter-spacing:.3px}.sfooter{padding:8px 6px;border-top:1px solid var(--b1)}.api-status{display:flex;align-items:center;gap:6px;padding:6px 9px;background:var(--bg3);border-radius:5px;font-family:var(--mono);font-size:9.5px;color:var(--t3)}.api-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.api-dot.ok{background:var(--green);box-shadow:0 0 5px var(--green)}.api-dot.err{background:var(--red)}.topbar-title{font-size:13px;font-weight:700;color:var(--t1)}.topbar-sub{font-size:10px;color:var(--t3);font-family:var(--mono)}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:6px}.btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:5px;border:1px solid var(--b2);background:var(--bg3);color:var(--t2);font-size:12px;font-weight:500;cursor:pointer;transition:all .12s;white-space:nowrap}.btn:hover{background:var(--bg4);color:var(--t1);border-color:var(--b3)}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.35;cursor:not-allowed;transform:none}.btn-primary{background:var(--amber);border-color:var(--amber);color:#000;font-weight:700}.btn-primary:hover{background:var(--amber2);border-color:var(--amber2);color:#000}.btn-teal{background:var(--tealD);border-color:var(--teal);color:var(--teal)}.btn-teal:hover{background:#14b8a633}.btn-green{background:var(--greenD);border-color:var(--green);color:var(--green)}.btn-danger{background:var(--redD);border-color:var(--red);color:var(--red)}.btn-ghost{background:transparent;border-color:transparent;color:var(--t3)}.btn-ghost:hover{background:var(--bg3);color:var(--t2);border-color:var(--b1)}.btn-sm{padding:4px 9px;font-size:11px}.btn-lg{padding:10px 20px;font-size:13px}.btn-icon{padding:6px}.spin{animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.fg{margin-bottom:12px}.flbl{display:block;font-size:10px;font-weight:700;color:var(--t2);margin-bottom:5px;font-family:var(--mono);letter-spacing:.6px;text-transform:uppercase}.finput,.ftextarea,.fselect{width:100%;background:var(--bg3);border:1px solid var(--b2);border-radius:5px;color:var(--t1);font-family:var(--sans);font-size:12.5px;padding:8px 11px;outline:none;transition:border-color .12s}.finput:focus,.ftextarea:focus,.fselect:focus{border-color:var(--amber)}.finput::placeholder,.ftextarea::placeholder{color:var(--t4)}.ftextarea{min-height:100px;resize:vertical;line-height:1.6}.fselect option{background:var(--bg2)}.finput-icon{position:relative}.finput-icon input{padding-right:36px}.finput-icon .ico{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--t3);background:none;border:none;cursor:pointer}.chips{display:flex;flex-wrap:wrap;gap:5px}.chip{padding:3px 9px;border-radius:20px;border:1px solid var(--b2);background:var(--bg3);color:var(--t3);font-size:10px;font-weight:700;cursor:pointer;transition:all .12s;font-family:var(--mono);-webkit-user-select:none;user-select:none}.chip:hover{border-color:var(--b3);color:var(--t2)}.chip.on{background:var(--amberD);border-color:var(--amber);color:var(--amber)}.chip.c-teal.on{background:var(--tealD);border-color:var(--teal);color:var(--teal)}.chip.c-blue.on{background:var(--blueD);border-color:var(--blue);color:var(--blue)}.chip.c-green.on{background:var(--greenD);border-color:var(--green);color:var(--green)}.chip.c-red.on{background:var(--redD);border-color:var(--red);color:var(--red)}.card{background:var(--bg2);border:1px solid var(--b1);border-radius:10px;overflow:hidden}.card-hd{padding:10px 16px;background:var(--bg3);border-bottom:1px solid var(--b1);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.card-ttl{font-family:var(--mono);font-size:9.5px;font-weight:700;color:var(--t2);letter-spacing:.8px;text-transform:uppercase;display:flex;align-items:center;gap:6px}.card-body{padding:14px}.tabs-bar{display:flex;border-bottom:1px solid var(--b1);background:var(--bg2);overflow-x:auto;flex-shrink:0}.titem{padding:9px 14px;font-size:10px;font-weight:700;color:var(--t3);cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap;transition:all .12s;font-family:var(--mono);letter-spacing:.4px;text-transform:uppercase;display:flex;align-items:center;gap:5px}.titem:hover{color:var(--t2)}.titem.active{color:var(--amber);border-bottom-color:var(--amber)}.tdot{width:5px;height:5px;border-radius:50%;flex-shrink:0}.badge{display:inline-flex;align-items:center;padding:2px 7px;border-radius:20px;font-size:9px;font-weight:700;font-family:var(--mono);letter-spacing:.4px}.b-amber{background:var(--amberD);color:var(--amber);border:1px solid rgba(245,158,11,.3)}.b-teal{background:var(--tealD);color:var(--teal);border:1px solid rgba(20,184,166,.3)}.b-blue{background:var(--blueD);color:var(--blue);border:1px solid rgba(59,130,246,.3)}.b-green{background:var(--greenD);color:var(--green);border:1px solid rgba(34,197,94,.3)}.b-red{background:var(--redD);color:var(--red);border:1px solid rgba(248,113,113,.3)}.b-purple{background:var(--purpleD);color:var(--purple);border:1px solid rgba(167,139,250,.3)}.b-gray{background:var(--bg4);color:var(--t3);border:1px solid var(--b2)}.b-orange{background:#fb923c1a;color:var(--orange);border:1px solid rgba(251,146,60,.3)}.alert{padding:9px 12px;border-radius:5px;border-left:3px solid;margin-bottom:8px;font-size:11.5px;line-height:1.6}.alert-ttl{font-weight:700;margin-bottom:2px;font-family:var(--mono);font-size:8.5px;letter-spacing:1px;text-transform:uppercase}.a-danger{background:var(--redD);border-color:var(--red);color:#fca5a5}.a-warn{background:#fb923c1a;border-color:var(--orange);color:#fdba74}.a-info{background:var(--blueD);border-color:var(--blue);color:#93c5fd}.a-success{background:var(--greenD);border-color:var(--green);color:#86efac}.code-wrap{background:#0a0d12;border:1px solid var(--b2);border-radius:7px;overflow:hidden}.code-bar{display:flex;align-items:center;justify-content:space-between;padding:7px 12px;background:var(--bg3);border-bottom:1px solid var(--b1)}.code-lang{font-family:var(--mono);font-size:9px;font-weight:700;color:var(--teal);letter-spacing:1px;text-transform:uppercase;display:flex;align-items:center;gap:6px}.code-lang:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--teal)}.code-pre{font-family:var(--mono);font-size:12px;line-height:1.75;padding:14px 16px;overflow:auto;max-height:500px;color:#cdd6f4;margin:0;white-space:pre}.terminal{background:#030508;border:1px solid var(--b2);border-radius:7px;font-family:var(--mono);font-size:12px;line-height:1.65;padding:12px;min-height:200px;max-height:400px;overflow-y:auto}.term-line{padding:0 0 1px;word-break:break-all}.term-out{color:#c9d1d9}.term-err{color:#f87171}.term-sys{color:#f59e0b}.term-ok{color:#22c55e}.term-meta{color:var(--t3);font-size:10px}.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 20px;gap:8px}.empty-ico{width:48px;height:48px;background:var(--bg3);border:1px solid var(--b2);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:5px}.empty-ttl{font-size:13px;font-weight:700;color:var(--t2)}.empty-sub{font-size:11px;color:var(--t3);max-width:240px;line-height:1.6}.toast-wrap{position:fixed;bottom:16px;right:16px;display:flex;flex-direction:column;gap:6px;z-index:9999}.toast{padding:9px 14px;background:var(--bg2);border:1px solid var(--b3);border-radius:7px;font-size:11.5px;color:var(--t1);display:flex;align-items:center;gap:8px;min-width:200px;animation:toastIn .18s ease;box-shadow:0 8px 24px #0009}.toast.ok{border-left:3px solid var(--green)}.toast.err{border-left:3px solid var(--red)}.toast.inf{border-left:3px solid var(--blue)}@keyframes toastIn{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:none}}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:900;padding:16px}.modal{background:var(--bg1);border:1px solid var(--b3);border-radius:12px;width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal-hd{padding:14px 18px;border-bottom:1px solid var(--b1);display:flex;align-items:center;justify-content:space-between;background:var(--bg2);flex-shrink:0}.modal-ttl{font-size:14px;font-weight:700}.modal-body{flex:1;overflow-y:auto;padding:18px}.row{display:flex;align-items:center;gap:6px}.row-sb{display:flex;align-items:center;justify-content:space-between}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.gap2{gap:8px}.mt1{margin-top:4px}.mt2{margin-top:8px}.mt3{margin-top:12px}.mt4{margin-top:16px}.mb1{margin-bottom:4px}.mb2{margin-bottom:8px}.mb3{margin-bottom:12px}.mb4{margin-bottom:16px}.text-sm{font-size:11.5px}.text-xs{font-size:10px}.text-muted{color:var(--t3)}.text-mono{font-family:var(--mono)}.w-full{width:100%}.flex1{flex:1}.hidden{display:none!important}.flex-col{display:flex;flex-direction:column}.section-ttl{font-size:11px;font-weight:700;color:var(--t2);margin-bottom:10px;display:flex;align-items:center;gap:8px;font-family:var(--mono);letter-spacing:.5px;text-transform:uppercase}.section-ttl:after{content:"";flex:1;height:1px;background:var(--b1)}.divider{height:1px;background:var(--b1);margin:12px 0}.stat-card{background:var(--bg2);border:1px solid var(--b1);border-radius:10px;padding:14px 16px;position:relative;overflow:hidden}.stat-card:after{content:"";position:absolute;top:0;left:0;right:0;height:2px}.stat-amber:after{background:var(--amber)}.stat-teal:after{background:var(--teal)}.stat-blue:after{background:var(--blue)}.stat-purple:after{background:var(--purple)}.stat-green:after{background:var(--green)}.stat-val{font-size:26px;font-weight:800;font-family:var(--mono);line-height:1;margin-bottom:2px}.stat-lbl{font-size:10px;color:var(--t3)}.scard{background:var(--bg2);border:1px solid var(--b1);border-radius:8px;padding:12px;transition:all .15s;cursor:pointer}.scard:hover{border-color:var(--b3);background:var(--bg3);transform:translateY(-1px)}.scard-title{font-size:12.5px;font-weight:700;color:var(--t1);margin-bottom:5px}.scard-preview{font-family:var(--mono);font-size:9.5px;color:var(--t4);background:var(--bg0);border:1px solid var(--b1);border-radius:4px;padding:6px 8px;margin:6px 0;max-height:48px;overflow:hidden;white-space:pre;line-height:1.5}.scard-footer{display:flex;align-items:center;justify-content:space-between;margin-top:8px}.chat-msg{display:flex;gap:8px;margin-bottom:12px}.chat-msg.user{flex-direction:row-reverse}.chat-bubble{background:var(--bg3);border:1px solid var(--b2);border-radius:8px;padding:9px 12px;max-width:80%;font-size:12.5px;line-height:1.65}.chat-bubble code{font-family:var(--mono);font-size:11px;background:var(--bg0);padding:1px 4px;border-radius:3px;color:var(--teal)}.chat-bubble pre{font-family:var(--mono);font-size:11px;background:var(--bg0);padding:8px;border-radius:5px;margin:6px 0;overflow-x:auto;color:#cdd6f4}.chat-msg.user .chat-bubble{background:var(--amberD);border-color:#f59e0b40;color:var(--t1)}.chat-avatar{width:26px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0;margin-top:2px}.chat-avatar.ai{background:var(--amberD);color:var(--amber);font-family:var(--mono);border:1px solid rgba(245,158,11,.25)}.chat-avatar.user{background:var(--blueD);color:var(--blue);border:1px solid rgba(59,130,246,.25)}.editor-layout{display:flex;height:100%}.editor-sidebar{width:200px;min-width:200px;border-right:1px solid var(--b1);background:var(--bg1);display:flex;flex-direction:column}.editor-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.editor-pane{flex:1;overflow:hidden}.output-pane{height:220px;border-top:1px solid var(--b1);display:flex;flex-direction:column;flex-shrink:0}.split-handle{height:4px;background:var(--b1);cursor:ns-resize;flex-shrink:0;transition:background .12s}.split-handle:hover{background:var(--amber)}.editor-tabs{display:flex;background:var(--bg1);border-bottom:1px solid var(--b1);overflow-x:auto;flex-shrink:0}.etab{display:flex;align-items:center;gap:6px;padding:7px 12px;font-size:11.5px;color:var(--t3);cursor:pointer;border-right:1px solid var(--b1);border-bottom:2px solid transparent;white-space:nowrap;transition:all .12s;min-width:120px;max-width:180px}.etab:hover{background:var(--bg2);color:var(--t2)}.etab.active{background:var(--bg2);color:var(--t1);border-bottom-color:var(--amber)}.etab-name{flex:1;overflow:hidden;text-overflow:ellipsis}.etab-close{width:14px;height:14px;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--t4);transition:all .12s;flex-shrink:0}.etab-close:hover{background:var(--redD);color:var(--red)}.etab-unsaved{width:6px;height:6px;border-radius:50%;background:var(--amber);flex-shrink:0}.progress-bar{height:4px;background:var(--bg4);border-radius:2px;overflow:hidden}.progress-fill{height:100%;border-radius:2px;transition:width .4s ease}.setting-row{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;background:var(--bg2);border:1px solid var(--b1);border-radius:6px;margin-bottom:6px}.toggle{width:34px;height:18px;border-radius:9px;background:var(--bg5);position:relative;cursor:pointer;transition:background .15s;flex-shrink:0}.toggle.on{background:var(--amber)}.toggle:after{content:"";width:12px;height:12px;border-radius:50%;background:#fff;position:absolute;top:3px;left:3px;transition:left .15s}.toggle.on:after{left:19px}.score-ring{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-direction:column;border:3px solid;flex-shrink:0}.issue-row{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;background:var(--bg3);border:1px solid var(--b1);border-radius:6px;margin-bottom:6px}.sev{font-family:var(--mono);font-size:8px;font-weight:700;padding:2px 6px;border-radius:3px;letter-spacing:.5px;text-transform:uppercase;flex-shrink:0;margin-top:2px}.sev-critical{background:#f8717138;color:var(--red);border:1px solid var(--red)}.sev-high{background:#fb923c26;color:var(--orange);border:1px solid var(--orange)}.sev-medium{background:#fbbf241f;color:#fbbf24;border:1px solid rgba(251,191,36,.4)}.sev-low{background:var(--blueD);color:var(--blue);border:1px solid var(--blue)}.repo-card{background:var(--bg2);border:1px solid var(--b1);border-radius:7px;padding:11px 13px;transition:all .15s}.repo-card:hover{border-color:var(--b3);background:var(--bg3)}.file-row{display:flex;align-items:center;gap:7px;padding:5px 8px;border-radius:4px;cursor:pointer;transition:background .12s}.file-row:hover{background:var(--bg4)}.panel-2col{display:grid;grid-template-columns:1fr 1fr;gap:14px;height:100%;overflow:hidden}.panel-scroll{overflow-y:auto;padding:16px}.fetch-layout{display:grid;grid-template-columns:1fr 1fr;gap:0;height:100%}.fetch-left{border-right:1px solid var(--b1);overflow-y:auto}.fetch-right{overflow-y:auto}.hamburger-btn{display:none;align-items:center;justify-content:center;width:34px;height:34px;background:var(--bg3);color:var(--t2);border:1px solid var(--b2);border-radius:6px;font-size:16px;cursor:pointer;flex-shrink:0;transition:all .12s}.hamburger-btn:hover{background:var(--bg4);color:var(--t1)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;z-index:700}@media (max-width: 768px){html{font-size:13px}.app{flex-direction:column}.sidebar{position:fixed;left:-100%;top:0;bottom:0;width:240px;z-index:750;transition:left .22s ease;box-shadow:4px 0 24px #0009}.sidebar.open{left:0}.sidebar-overlay{display:block}.sidebar-overlay.hidden{display:none}.main{width:100%;height:100vh}.topbar{padding:0 12px;height:48px}.topbar-sub{display:none}.topbar-title{font-size:14px}.hamburger-btn{display:flex!important}.page-wrap{padding:12px 12px 70px}.grid2,.grid3,.grid4,.stat-grid,.input-grid,.panel-2col,.fetch-layout,.grid-auto{grid-template-columns:1fr!important}.editor-layout{flex-direction:column}.editor-sidebar{width:100%;min-width:unset;max-height:200px;border-right:none;border-bottom:1px solid var(--b1);flex-direction:row;overflow-x:auto;overflow-y:hidden}.editor-sidebar>div:first-child{display:none}.editor-sidebar>div:last-child{display:none}.editor-main{flex:1;overflow:hidden}.output-pane{height:160px!important}.lesson-sidebar{display:none!important}#gen-layout{grid-template-columns:1fr!important}.panel-scroll{height:auto!important;overflow-y:visible}.chips{gap:4px}.chip{font-size:9.5px;padding:3px 8px}.card-hd{flex-wrap:wrap;gap:6px}.topbar-right{gap:5px}.topbar-right .btn:not(.btn-primary){display:none}.grid2{gap:10px}.chat-bubble{max-width:92%!important}.repo-card{padding:12px}.terminal,.code-pre{font-size:11px}[style*="gridTemplateColumns: repeat(auto-fill,minmax(290px"],[style*="gridTemplateColumns: repeat(auto-fill,minmax(300px"],[style*="gridTemplateColumns: repeat(auto-fill,minmax(320px"]{grid-template-columns:1fr!important}.sico{display:none}.stat-val{font-size:22px}[style*="gridTemplateColumns: 1fr 1fr"]{grid-template-columns:1fr!important}.editor-tabs{overflow-x:auto}.etab{min-width:100px;max-width:140px}}@media (max-width: 480px){.topbar-title{font-size:13px}.btn-lg{padding:9px 16px;font-size:12px}.modal{max-width:calc(100vw - 20px);margin:10px}.modal-body{padding:14px}.tabs-bar{overflow-x:auto}.titem{padding:9px 10px;font-size:9.5px}}.learning-catalog{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;padding:0 20px 24px}.learning-track-view{display:flex;flex-direction:column;height:100%;overflow:hidden}.learning-lesson-content{flex:1;padding:20px;max-width:820px;overflow-x:hidden}.learning-lesson-sidebar{width:220px;border-left:1px solid var(--b1);flex-shrink:0;overflow-y:auto;background:var(--bg1)}@media (max-width: 768px){.learning-catalog{grid-template-columns:1fr;padding:0 12px 80px}.learning-lesson-content{padding:14px;max-width:100%}.learning-lesson-sidebar{display:none}[class*=learning] [style*=gridTemplateColumns]{grid-template-columns:1fr!important}}@media (max-width: 640px){.chat-hist-sidebar{display:none!important}}.page-wrap{padding:16px}@media (max-width: 768px){.page-wrap{padding:12px}.content{overflow-y:auto!important}}.gen-layout{display:grid;grid-template-columns:320px 1fr;gap:0;height:100%;overflow:hidden}.explainer-layout,.auditor-layout{display:grid;grid-template-columns:1fr 1fr;height:100%;overflow:hidden}.auditor-result-layout,.split-layout{display:grid;grid-template-columns:1fr 1fr;flex:1;overflow:hidden}.learning-catalog-page{height:100%;overflow-y:auto;display:flex;flex-direction:column}.learning-hero{padding:20px 20px 14px;border-bottom:1px solid var(--b1);display:flex;align-items:flex-start;gap:16px;flex-wrap:wrap;flex-shrink:0;background:linear-gradient(180deg,var(--bg2) 0%,var(--bg1) 100%)}.learning-hero-left{flex:1;min-width:0}.learning-hero-title{font-size:22px;font-weight:900;color:var(--t1);letter-spacing:-.5px}.learning-hero-sub{font-size:12px;color:var(--t3);margin-top:4px}.learning-hero-progress{margin-top:10px;display:flex;align-items:center;gap:10px}.learning-hero-bar{height:4px;flex:1;max-width:200px;background:var(--bg4);border-radius:2px;overflow:hidden}.learning-hero-bar-fill{height:100%;background:var(--amber);border-radius:2px;transition:width .5s}.learning-hero-stat{font-size:10px;color:var(--t3);font-family:var(--mono)}.learning-search-wrap{min-width:200px;align-self:center}.learning-catalog{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:14px;padding:16px 20px 28px;flex:1}.track-card{background:var(--bg2);border:1px solid rgba(255,255,255,.06);border-radius:12px;overflow:hidden;cursor:pointer;transition:all .18s;display:flex;flex-direction:column;position:relative}.track-card:hover:not(.coming-soon){border-color:var(--track-color, var(--amber));transform:translateY(-2px);box-shadow:0 6px 20px #0006}.track-card.coming-soon{opacity:.6;cursor:default}.track-card-bar{height:3px;flex-shrink:0}.track-card-body{padding:16px;flex:1;display:flex;flex-direction:column;gap:10px}.track-card-top{display:flex;align-items:flex-start;gap:12px}.track-card-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.track-card-title{font-size:14px;font-weight:800;color:var(--t1);line-height:1.3}.track-card-desc{font-size:11.5px;color:var(--t3);line-height:1.6;flex:1}.track-card-footer{margin-top:auto}.track-card-progress-bar{height:3px;background:var(--bg4);border-radius:2px;overflow:hidden;margin-bottom:6px}.track-card-stats{display:flex;justify-content:space-between;font-size:10px;color:var(--t3);font-family:var(--mono)}.learning-track-header{padding:12px 16px;border-bottom:1px solid var(--b1);display:flex;align-items:center;gap:10px;flex-shrink:0;background:var(--bg2);flex-wrap:wrap}.learning-track-header-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.learning-track-progress-bar{width:100px;height:4px;background:var(--bg4);border-radius:2px;overflow:hidden;flex-shrink:0;align-self:center}.module-lesson-row{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background .1s}.module-lesson-row:hover{background:var(--bg3)}.lesson-num{width:22px;height:22px;border-radius:5px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-family:var(--mono);background:var(--bg4);border:1px solid var(--b2);color:var(--t3);transition:all .15s}.lesson-num.done{background:var(--greenD);border-color:var(--green);color:var(--green)}.learning-lesson-header{padding:9px 14px;border-bottom:1px solid var(--b1);background:var(--bg2);display:flex;align-items:center;gap:6px;flex-shrink:0;flex-wrap:wrap;min-height:46px}.learning-bc-sep{color:var(--t4);font-size:13px}.learning-bc-mod{font-size:11.5px;color:var(--t3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.learning-bc-lesson{font-size:11.5px;font-weight:600;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.learning-lesson-mod-progress{display:flex;gap:3px;padding:0 14px;height:6px;flex-shrink:0;align-items:center;background:var(--bg1);border-bottom:1px solid var(--b1)}.learning-lesson-layout{flex:1;overflow:auto;display:flex}.learning-lesson-content{flex:1;padding:24px;max-width:860px;overflow-x:hidden}.learning-lesson-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:20px;flex-wrap:wrap}.learning-lesson-title{font-size:21px;font-weight:900;color:var(--t1);letter-spacing:-.3px;line-height:1.2}.learning-quiz-header{font-size:16px;font-weight:800;color:var(--t1);margin-bottom:16px;padding-top:16px;border-top:2px solid var(--b2)}.learning-complete-box{margin-top:32px;padding:20px;background:var(--bg3);border-radius:10px;border:1px solid var(--b1);text-align:center}.learning-lesson-sidebar{width:230px;border-left:1px solid var(--b1);flex-shrink:0;overflow-y:auto;background:var(--bg1);display:flex;flex-direction:column}.learning-sidebar-header{padding:10px 13px;border-bottom:1px solid var(--b1);font-size:10.5px;font-weight:700;color:var(--t2);letter-spacing:.3px;flex-shrink:0}.learning-sidebar-item{padding:9px 13px;cursor:pointer;border-bottom:1px solid var(--b1);display:flex;align-items:flex-start;gap:8px;transition:background .1s}.learning-sidebar-item:hover{background:var(--bg3)}.learning-sidebar-item.active{background:var(--amberD)}.learning-sidebar-num{width:18px;height:18px;border-radius:4px;flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;font-size:9.5px;font-family:var(--mono);font-weight:700;background:var(--bg4);color:var(--t3);border:1px solid var(--b2)}.learning-sidebar-num.done{background:var(--greenD);color:var(--green);border-color:var(--green)}.learning-sidebar-num.current{background:var(--amberD);color:var(--amber);border-color:var(--amber)}.quiz-question{margin-bottom:18px;padding:16px;background:var(--bg3);border-radius:8px;border:1px solid var(--b1)}.quiz-q-text{font-size:13px;font-weight:700;color:var(--t1);margin-bottom:12px;line-height:1.5}.quiz-option{display:flex;align-items:center;gap:9px;padding:9px 12px;border-radius:6px;cursor:pointer;border:1px solid var(--b2);background:var(--bg2);transition:all .1s;color:var(--t1)}.quiz-option:hover{border-color:var(--b3);background:var(--bg3)}.quiz-option.selected{border-color:var(--amber);background:var(--amberD)}.quiz-result{padding:24px;border-radius:12px;text-align:center;margin-bottom:20px}.quiz-result.pass{background:var(--greenD);border:1px solid var(--green)}.quiz-result.fail{background:var(--redD);border:1px solid var(--red)}.quiz-result-score{font-size:42px;font-weight:900;font-family:var(--mono);margin-bottom:8px}.quiz-result-msg{font-size:13px;color:var(--t1);margin-bottom:16px}@media (max-width: 768px){.gen-layout{grid-template-columns:1fr!important;overflow-y:auto!important;height:auto!important;min-height:100%}.gen-layout>div:first-child{border-right:none!important;border-bottom:1px solid var(--b1);max-height:none!important;overflow:visible!important}.gen-layout>div:last-child{overflow:visible!important;min-height:400px}.explainer-layout,.auditor-layout,.auditor-result-layout,.split-layout{grid-template-columns:1fr!important;height:auto!important;overflow-y:auto!important;flex-direction:column!important}.explainer-layout>div,.auditor-layout>div,.split-layout>div{overflow:visible!important;min-height:200px;border-right:none!important;border-bottom:1px solid var(--b1)}.explainer-layout>div:last-child,.auditor-layout>div:last-child,.split-layout>div:last-child{border-bottom:none}.learning-catalog{grid-template-columns:1fr!important;padding:12px 12px 80px}.learning-hero{padding:14px 12px}.learning-hero-title{font-size:18px}.learning-search-wrap{width:100%}.learning-track-progress-bar{display:none}.learning-lesson-sidebar{display:none!important}.learning-lesson-content{padding:14px;max-width:100%}.learning-lesson-title{font-size:17px}.learning-bc-mod{display:none}.learning-bc-sep:first-of-type{display:none}.learning-track-header{flex-wrap:wrap;gap:8px}}@media (max-width: 480px){.learning-lesson-header{gap:4px}.learning-bc-lesson{max-width:120px}.quiz-result-score{font-size:32px}.track-card-icon{width:36px;height:36px;font-size:18px}}
