:root{--bg-0: #080b12;--bg-1: #0e131e;--bg-2: #151c2b;--bg-3: #1d2638;--bg-hover: #232d44;--border: #283349;--border-soft: #1b2334;--text-0: #f3f6fb;--text-1: #c4cdde;--text-2: #8a96ab;--text-3: #5b667e;--accent: #6366f1;--accent-2: #22d3ee;--accent-soft: rgba(99, 102, 241, .15);--attacker: #ef4444;--attacker-soft: rgba(239, 68, 68, .13);--defender: #22d3ee;--defender-soft: rgba(34, 211, 238, .13);--green: #22c55e;--green-soft: rgba(34, 197, 94, .14);--amber: #f59e0b;--amber-soft: rgba(245, 158, 11, .14);--red: #ef4444;--red-soft: rgba(239, 68, 68, .14);--blue: #3b82f6;--blue-soft: rgba(59, 130, 246, .14);--radius: 14px;--radius-sm: 9px;--shadow: 0 12px 34px rgba(0, 0, 0, .4);--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--mono: "JetBrains Mono", ui-monospace, "SF Mono", monospace}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg-0);color:var(--text-1);line-height:1.6;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-1)}::-webkit-scrollbar-thumb{background:var(--bg-3);border-radius:6px}::-webkit-scrollbar-thumb:hover{background:var(--border)}h1,h2,h3,h4{color:var(--text-0);line-height:1.22;font-weight:700;letter-spacing:-.01em}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}b{color:var(--text-0);font-weight:600}code{font-family:var(--mono);font-size:.88em;background:var(--bg-2);border:1px solid var(--border-soft);padding:1px 6px;border-radius:5px;color:var(--accent-2)}.app{display:flex;height:100vh;overflow:hidden}.main{flex:1;overflow-y:auto;position:relative}.main-inner{max-width:1000px;margin:0 auto;padding:40px 40px 140px}.sidebar{width:296px;flex-shrink:0;background:var(--bg-1);border-right:1px solid var(--border-soft);display:flex;flex-direction:column;padding:22px 14px;overflow-y:auto}.sb-brand{display:flex;flex-direction:column;align-items:flex-start;gap:10px;padding:4px 8px 18px;border-bottom:1px solid var(--border-soft);margin-bottom:14px;cursor:pointer}.sb-logo{width:40px;height:40px;border-radius:11px;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:grid;place-items:center;font-weight:800;color:#fff;font-size:18px;flex-shrink:0}.sb-logo-img{height:34px;width:auto;max-width:200px;object-fit:contain;display:block}.sb-brand-course{font-size:13px;font-weight:700;color:var(--text-1);letter-spacing:-.01em;padding-left:2px}.sb-brand-text strong{display:block;color:var(--text-0);font-size:14.5px;font-weight:700;letter-spacing:-.01em}.sb-brand-text small{display:block;color:var(--text-3);font-size:11px;letter-spacing:.09em;text-transform:uppercase;margin-top:2px}.sb-section-label{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);padding:14px 10px 7px;font-weight:700}.sb-item{display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-2);font-size:13.5px;font-weight:500;transition:background .13s,color .13s;border:1px solid transparent}.sb-item:hover{background:var(--bg-2);color:var(--text-1)}.sb-item.active{background:var(--bg-2);color:var(--text-0);border-color:var(--border)}.sb-item.active.attacker{border-color:#ef444459}.sb-item.active.defender{border-color:#22d3ee59}.sb-num{width:24px;height:24px;border-radius:7px;display:grid;place-items:center;font-size:12px;font-weight:700;font-family:var(--mono);background:var(--bg-3);color:var(--text-2);flex-shrink:0}.sb-item.active .sb-num{background:var(--accent);color:#fff}.sb-item .sb-label{flex:1;line-height:1.25}.sb-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;background:transparent;border:1.5px solid var(--border)}.sb-dot.done{background:var(--green);border-color:var(--green)}.sb-dot.partial{background:var(--amber);border-color:var(--amber)}.sb-progress{margin:16px 10px 4px}.sb-progress-bar{height:6px;border-radius:4px;background:var(--bg-3);overflow:hidden}.sb-progress-bar>span{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width .4s ease}.sb-progress-label{font-size:11px;color:var(--text-3);margin-top:7px;display:flex;justify-content:space-between}.sb-side-tag{font-size:9.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:2px 6px;border-radius:4px}.sb-side-tag.attacker{color:var(--attacker);background:var(--attacker-soft)}.sb-side-tag.defender{color:var(--defender);background:var(--defender-soft)}.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:11.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-2);margin-bottom:14px}.eyebrow.attacker{color:var(--attacker)}.eyebrow.defender{color:var(--defender)}.page-title{font-size:30px;margin-bottom:10px}.page-sub{font-size:16px;color:var(--text-2);max-width:70ch;margin-bottom:26px}.card{background:var(--bg-1);border:1px solid var(--border-soft);border-radius:var(--radius);padding:22px;margin-bottom:18px}.card h3{font-size:17px;margin-bottom:10px}.card p{color:var(--text-1);margin-bottom:10px}.card p:last-child{margin-bottom:0}.callout{border-left:3px solid var(--accent);background:var(--accent-soft);border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding:14px 18px;margin:16px 0;font-size:14px;color:var(--text-1)}.callout.attacker{border-color:var(--attacker);background:var(--attacker-soft)}.callout.defender{border-color:var(--defender);background:var(--defender-soft)}.callout.warn{border-color:var(--amber);background:var(--amber-soft)}.callout.good{border-color:var(--green);background:var(--green-soft)}.callout strong{color:var(--text-0)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font);font-size:14px;font-weight:600;padding:11px 20px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-2);color:var(--text-1);cursor:pointer;transition:all .15s}.btn:hover{background:var(--bg-hover);color:var(--text-0)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn.primary:hover{filter:brightness(1.08)}.btn.attacker{background:var(--attacker);border-color:var(--attacker);color:#fff}.btn.defender{background:var(--defender);border-color:var(--defender);color:#04222a}.btn.ghost{background:transparent}.btn.lg{font-size:15.5px;padding:14px 28px}.btn-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}.tag{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:20px;background:var(--bg-3);color:var(--text-2)}.tag.red{background:var(--red-soft);color:var(--red)}.tag.green{background:var(--green-soft);color:var(--green)}.tag.amber{background:var(--amber-soft);color:var(--amber)}.tag.blue{background:var(--blue-soft);color:var(--blue)}.tag.cyan{background:var(--defender-soft);color:var(--defender)}.terminal{background:#05070c;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--mono);font-size:13px;overflow:hidden;margin:16px 0}.terminal-bar{display:flex;align-items:center;gap:7px;padding:9px 13px;background:var(--bg-2);border-bottom:1px solid var(--border)}.terminal-bar .dot{width:11px;height:11px;border-radius:50%}.terminal-bar .dot.r{background:#ff5f56}.terminal-bar .dot.y{background:#ffbd2e}.terminal-bar .dot.g{background:#27c93f}.terminal-bar .ttl{margin-left:8px;color:var(--text-3);font-size:11.5px}.terminal-body{padding:14px 16px;white-space:pre-wrap;line-height:1.7;color:#c8d3e6;max-height:360px;overflow-y:auto}.terminal-body .prompt{color:var(--green)}.terminal-body .cmd{color:var(--text-0)}.terminal-body .out{color:var(--text-2)}.terminal-body .ok{color:var(--green)}.terminal-body .err{color:var(--red)}.terminal-body .hl{color:var(--accent-2)}.cursor-blink:after{content:"▋";color:var(--green);animation:blink 1s steps(2) infinite}@keyframes blink{50%{opacity:0}}.choices{display:grid;gap:10px;margin:16px 0}.choice{text-align:left;padding:14px 16px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-1);color:var(--text-1);cursor:pointer;font-size:14px;font-family:var(--font);transition:all .14s;display:flex;align-items:center;gap:12px}.choice:hover{background:var(--bg-2);border-color:var(--accent)}.choice.selected{border-color:var(--accent);background:var(--accent-soft)}.choice.correct{border-color:var(--green);background:var(--green-soft)}.choice.wrong{border-color:var(--red);background:var(--red-soft)}.choice .ico{width:22px;flex-shrink:0;text-align:center}.reveal{animation:revealUp .45s cubic-bezier(.2,.7,.3,1) both}@keyframes revealUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.pop{animation:pop .32s cubic-bezier(.2,.8,.2,1.2) both}@keyframes pop{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.pulse{animation:pulse 1.8s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 0 #ef444480}50%{box-shadow:0 0 0 8px #ef444400}}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin:16px 0}.stat{background:var(--bg-1);border:1px solid var(--border-soft);border-radius:var(--radius-sm);padding:16px}.stat .v{font-size:24px;font-weight:800;color:var(--text-0);font-family:var(--mono)}.stat .l{font-size:12px;color:var(--text-3);margin-top:4px}.quiz-q{font-size:16px;font-weight:600;color:var(--text-0);margin-bottom:14px}.quiz-explain{margin-top:14px;padding:13px 16px;border-radius:var(--radius-sm);font-size:13.5px;border:1px solid var(--border-soft);background:var(--bg-2);color:var(--text-1)}.landing{max-width:1000px;margin:0 auto;padding:60px 40px 120px}.hero{text-align:center;padding:30px 0 10px}.hero-badge{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-2);background:var(--bg-2);border:1px solid var(--border);padding:6px 14px;border-radius:20px;margin-bottom:24px}.hero h1{font-size:46px;letter-spacing:-.02em;margin-bottom:16px;background:linear-gradient(120deg,#fff 30%,var(--accent-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.hero p{font-size:18px;color:var(--text-2);max-width:60ch;margin:0 auto 28px}.killchain{margin:50px 0}.kc-row{display:flex;gap:18px;align-items:stretch;margin-bottom:14px;cursor:pointer;border-radius:var(--radius);transition:transform .15s}.kc-row:hover{transform:translate(4px)}.kc-rail{display:flex;flex-direction:column;align-items:center;width:44px;flex-shrink:0}.kc-node{width:44px;height:44px;border-radius:13px;display:grid;place-items:center;font-family:var(--mono);font-weight:800;font-size:16px;color:#fff;flex-shrink:0;z-index:1}.kc-line{width:2px;flex:1;background:var(--border);margin:2px 0}.kc-card{flex:1;background:var(--bg-1);border:1px solid var(--border-soft);border-radius:var(--radius);padding:16px 20px;transition:border-color .15s,background .15s}.kc-row:hover .kc-card{background:var(--bg-2);border-color:var(--border)}.kc-card .kc-top{display:flex;align-items:center;gap:10px;margin-bottom:5px;flex-wrap:wrap}.kc-card h4{font-size:16px}.kc-card .kc-domain{font-size:12px;color:var(--text-3);font-weight:600}.kc-card p{font-size:13.5px;color:var(--text-2);margin:0}.phase-divider{display:flex;align-items:center;gap:14px;margin:30px 0 20px;font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.phase-divider .ln{flex:1;height:1px;background:var(--border)}.phase-divider.attacker{color:var(--attacker)}.phase-divider.defender{color:var(--defender)}.mod-band{display:flex;align-items:center;gap:16px;padding:16px 20px;border-radius:var(--radius);margin-bottom:24px;border:1px solid var(--border-soft);background:var(--bg-1)}.mod-band.attacker{border-left:4px solid var(--attacker)}.mod-band.defender{border-left:4px solid var(--defender)}.mod-band .mb-num{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;font-family:var(--mono);font-weight:800;font-size:18px;color:#fff;flex-shrink:0}.mod-band .mb-meta small{display:block;font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);font-weight:700}.mod-band .mb-meta h2{font-size:20px}.mod-footer{display:flex;justify-content:space-between;gap:14px;margin-top:40px;padding-top:24px;border-top:1px solid var(--border-soft)}.muted{color:var(--text-3)}.center{text-align:center}.mt-0{margin-top:0}.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.spacer{flex:1}.hidden{display:none}.fact-list{list-style:none;display:grid;gap:9px;margin:12px 0}.fact-list li{display:flex;gap:10px;font-size:14px;color:var(--text-1)}.fact-list li:before{content:"▸";color:var(--accent-2);flex-shrink:0}.kv{display:grid;grid-template-columns:max-content 1fr;gap:6px 18px;font-size:13.5px;margin:10px 0}.kv dt{color:var(--text-3);font-family:var(--mono)}.kv dd{color:var(--text-1)}.score-ring{font-size:44px;font-weight:800;font-family:var(--mono);color:var(--accent-2)}.cast-photo{position:relative;display:inline-block;border-radius:50%;overflow:hidden;flex-shrink:0;box-shadow:0 0 0 2px var(--cloth)}.cast-photo img{width:100%;height:100%;object-fit:cover;display:block}.cast-photo.speaking{box-shadow:0 0 0 2px var(--cloth),0 0 16px -2px var(--cloth);animation:castBob 2.4s ease-in-out infinite}.cast-bot{display:grid;place-items:center;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 0 0 2px #6366f166}.cast-bot.speaking{box-shadow:0 0 0 2px #6366f180,0 0 16px -2px var(--accent);animation:castBob 2.4s ease-in-out infinite}@keyframes castBob{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.byte-launcher{position:fixed;right:26px;bottom:26px;width:60px;height:60px;border-radius:50%;border:none;cursor:pointer;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 10px 30px #6366f173;display:grid;place-items:center;z-index:9000;animation:byteFloat 3.2s ease-in-out infinite}@keyframes byteFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.byte-launcher-face{font-size:28px}.byte-launcher-badge{position:absolute;top:-3px;right:-3px;min-width:22px;height:22px;padding:0 5px;border-radius:11px;background:var(--attacker);color:#fff;font-size:12px;font-weight:800;font-family:var(--mono);display:grid;place-items:center;border:2px solid var(--bg-0)}.byte-panel{position:fixed;right:26px;bottom:26px;width:370px;max-height:78vh;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);z-index:9500;display:flex;flex-direction:column;overflow:hidden;animation:pop .28s cubic-bezier(.2,.8,.2,1.2) both}.byte-head{display:flex;align-items:center;gap:11px;padding:13px 14px;background:var(--bg-2);border-bottom:1px solid var(--border-soft);cursor:grab;-webkit-user-select:none;user-select:none}.byte-head:active{cursor:grabbing}.byte-who{flex:1;line-height:1.2}.byte-who strong{display:block;color:var(--text-0);font-size:14px;font-weight:700}.byte-who small{display:block;color:var(--text-3);font-size:11px}.byte-x{background:none;border:none;color:var(--text-3);font-size:14px;cursor:pointer;padding:4px 6px;border-radius:6px}.byte-x:hover{background:var(--bg-3);color:var(--text-1)}.byte-progress{height:3px;background:var(--bg-3)}.byte-progress>span{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width .4s ease}.byte-step-meta{display:flex;align-items:center;gap:10px;padding:11px 16px 4px}.byte-step-n{font-size:10.5px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);font-family:var(--mono)}.byte-step-title{font-size:13px;font-weight:700;color:var(--text-0)}.byte-body{padding:6px 16px 14px;overflow-y:auto;font-size:13.6px;color:var(--text-1);line-height:1.62}.byte-body code{font-size:.86em}.byte-typing{display:flex;gap:5px;padding:8px 0}.byte-typing span{width:7px;height:7px;border-radius:50%;background:var(--text-3);animation:byteDot 1.1s infinite ease-in-out}.byte-typing span:nth-child(2){animation-delay:.18s}.byte-typing span:nth-child(3){animation-delay:.36s}@keyframes byteDot{0%,60%,to{opacity:.25;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}.byte-action{display:flex;align-items:center;gap:9px;margin:0 14px 12px;padding:10px 13px;background:var(--accent-soft);border:1px solid rgba(99,102,241,.3);border-radius:var(--radius-sm);font-size:12.5px;font-weight:600;color:var(--text-0)}.byte-action-dot{width:9px;height:9px;border-radius:50%;background:var(--accent-2);flex-shrink:0;animation:pulse 1.8s ease-in-out infinite}.byte-foot{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;border-top:1px solid var(--border-soft);background:var(--bg-1)}.byte-btn{font-family:var(--font);font-size:13px;font-weight:600;padding:8px 16px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-2);color:var(--text-1);cursor:pointer;transition:all .14s}.byte-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-0)}.byte-btn:disabled{opacity:.4;cursor:not-allowed}.byte-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.byte-btn.ghost{background:transparent}.console-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:18px 0}@media (max-width: 860px){.console-grid{grid-template-columns:1fr}}.req-panel,.res-panel{background:var(--bg-1);border:1px solid var(--border-soft);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column}.panel-head{display:flex;align-items:center;gap:8px;padding:11px 15px;background:var(--bg-2);border-bottom:1px solid var(--border-soft);font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-2)}.panel-body{padding:15px}.field-label{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-3);margin:12px 0 6px}.field-label:first-child{margin-top:0}.req-line{display:flex;align-items:stretch;gap:0;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;font-family:var(--mono);font-size:13px}.req-method{background:var(--green-soft);color:var(--green);font-weight:800;padding:10px 12px;display:grid;place-items:center;border-right:1px solid var(--border)}.req-host{background:var(--bg-2);color:var(--text-3);padding:10px 6px 10px 12px;display:grid;place-items:center;white-space:nowrap}.req-path{flex:1;background:var(--bg-2);border:none;color:var(--accent-2);font-family:var(--mono);font-size:13px;padding:10px 12px 10px 0;outline:none;cursor:pointer}.req-path:disabled{cursor:not-allowed}.cmd-input{width:100%;background:#05070c;border:1px solid var(--border);border-radius:var(--radius-sm);color:#c8d3e6;font-family:var(--mono);font-size:13px;padding:10px 12px;outline:none}.cmd-input:focus{border-color:var(--attacker)}.chip-row{display:flex;flex-wrap:wrap;gap:7px;margin-top:8px}.chip{font-family:var(--mono);font-size:12px;padding:5px 11px;border-radius:16px;border:1px solid var(--border);background:var(--bg-2);color:var(--text-2);cursor:pointer;transition:all .13s}.chip:hover{border-color:var(--attacker);color:var(--attacker)}.chip.danger{border-color:#ef444466;color:var(--attacker)}.auth-toggle{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-2);cursor:pointer;font-size:13px;-webkit-user-select:none;user-select:none}.auth-toggle.on{border-color:var(--attacker);background:var(--attacker-soft)}.auth-toggle .box{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--border);display:grid;place-items:center;flex-shrink:0;font-size:12px;color:#fff}.auth-toggle.on .box{background:var(--attacker);border-color:var(--attacker)}.auth-toggle code{font-size:11px}.res-status{display:flex;align-items:center;gap:9px;padding:11px 15px;border-bottom:1px solid var(--border-soft);font-family:var(--mono);font-size:13px}.res-code{font-weight:800;padding:2px 9px;border-radius:5px}.res-code.ok{background:var(--green-soft);color:var(--green)}.res-code.err{background:var(--red-soft);color:var(--red)}.res-empty{padding:40px 20px;text-align:center;color:var(--text-3);font-size:13px}.res-out{font-family:var(--mono);font-size:12.5px;white-space:pre-wrap;line-height:1.65;color:#c8d3e6;padding:14px 16px;max-height:280px;overflow-y:auto;background:#05070c}.res-out .k{color:var(--accent-2)}.res-out .v{color:var(--text-1)}.res-out .ok{color:var(--green)}.res-out .warn{color:var(--amber)}.topo{margin:14px 0 2px;width:100%}.topo-track{position:relative;display:flex;align-items:center;gap:0;background:var(--bg-1);border:1px solid var(--border-soft);border-radius:var(--radius);padding:16px 22px}.topo-node{text-align:center;flex-shrink:0;min-width:120px;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-2)}.topo-node .tn-label{font-size:13px;font-weight:700;color:var(--text-0)}.topo-node .tn-sub{font-size:11px;color:var(--text-3);font-family:var(--mono);margin-top:2px}.topo-node.attacker{border-color:#ef444466}.topo-node.attacker .tn-label{color:var(--attacker)}.topo-node.mid{border-color:var(--border)}.topo-node.target{border-color:#22d3ee59}.topo-node.pwned{border-color:var(--attacker);background:var(--attacker-soft);animation:pulse 1.8s ease-in-out infinite}.topo-node.pwned .tn-label{color:var(--attacker)}.topo-wire{flex:1;height:2px;background:repeating-linear-gradient(90deg,var(--border) 0 6px,transparent 6px 12px);margin:0 4px}.topo-packet{position:absolute;top:50%;left:130px;width:12px;height:12px;border-radius:50%;margin-top:-6px;background:var(--amber);box-shadow:0 0 12px 2px var(--amber);animation:packetGo .85s ease-in-out forwards}.topo-packet.blocked{background:var(--red);box-shadow:0 0 12px 2px var(--red);animation:packetBlock .7s ease-in forwards}.topo-packet.allowed,.topo-packet.logged{background:var(--accent-2);box-shadow:0 0 12px 2px var(--accent-2)}.topo-packet.rce,.topo-packet.pwned{background:var(--red);box-shadow:0 0 14px 3px var(--red)}@keyframes packetGo{0%{left:130px;opacity:1}to{left:calc(100% - 140px);opacity:1}}@keyframes packetBlock{0%{left:130px;opacity:1}60%{left:50%;opacity:1;transform:scale(1)}to{left:50%;opacity:0;transform:scale(2.4)}}.topo-cap{text-align:center;font-size:11px;color:var(--text-3);margin-top:8px;font-family:var(--mono)}.kill-steps{display:flex;gap:8px;margin:16px 0 4px;flex-wrap:wrap}.kill-step{flex:1;min-width:110px;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--border-soft);background:var(--bg-1);font-size:12px;color:var(--text-3);transition:all .2s}.kill-step .n{font-family:var(--mono);font-weight:800;font-size:11px;color:var(--text-3)}.kill-step.done{border-color:#ef444466;background:var(--attacker-soft);color:var(--text-0)}.kill-step.done .n{color:var(--attacker)}.metric-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:16px 0}@media (max-width: 720px){.metric-grid{grid-template-columns:1fr}}.metric{background:var(--bg-1);border:1px solid var(--border-soft);border-radius:var(--radius);padding:16px 18px}.metric .mk{font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3)}.metric .mv{font-size:26px;font-weight:800;font-family:var(--mono);color:var(--text-0);margin:6px 0 2px}.metric .md{font-size:12px;color:var(--text-2)}.metric.bad{border-color:#ef444459}.metric.bad .mv{color:var(--attacker)}.metric.good{border-color:#22c55e59}.metric.good .mv{color:var(--green)}.contain-status{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:12.5px;padding:9px 13px;border-radius:var(--radius-sm);background:var(--bg-2);border:1px solid var(--border-soft);margin:4px 0}.contain-status .led{width:9px;height:9px;border-radius:50%;flex-shrink:0}.contain-status .led.run{background:var(--amber);animation:pulse 1.4s infinite}.contain-status .led.ok{background:var(--green)}.pir{background:#fbfcfe;color:#1b2433;border-radius:var(--radius);padding:30px 34px;margin:16px 0;border:1px solid var(--border)}.pir h2,.pir h3,.pir h4,.pir b{color:#0d1422}.pir h2{font-size:22px;margin-bottom:4px;border-bottom:2px solid #0d1422;padding-bottom:8px}.pir .pir-meta{font-size:12px;color:#5a6477;font-family:var(--mono);margin-bottom:18px}.pir h3{font-size:14px;text-transform:uppercase;letter-spacing:.05em;margin:20px 0 8px;color:#334}.pir p,.pir li{font-size:13.5px;color:#2a3445;line-height:1.6}.pir ul{margin:6px 0 6px 18px}.pir .pir-row{display:grid;grid-template-columns:140px 1fr;gap:4px 16px;font-size:13px;margin:3px 0}.pir .pir-row dt{color:#5a6477;font-family:var(--mono)}.pir table{width:100%;border-collapse:collapse;margin:8px 0;font-size:12.5px}.pir th,.pir td{text-align:left;padding:7px 10px;border:1px solid #d8dee8}.pir th{background:#eef1f6;color:#334}@media print{.sidebar,.byte-panel,.byte-launcher,.mod-footer,.mod-band{display:none!important}.main,.main-inner{overflow:visible!important;padding:0!important;max-width:100%!important}.pir{border:none}}.cast-you{display:inline-flex;align-items:center;justify-content:center;flex:none;border-radius:50%;background:var(--bg-3);color:var(--text-2);font-family:var(--mono);font-weight:700;letter-spacing:.5px;border:1px solid var(--border);box-shadow:0 0 0 2px var(--bg-1)}.dialogue{background:linear-gradient(180deg,var(--bg-1),var(--bg-0));border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px 14px;margin:22px 0}.dialogue-head{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.4px;color:var(--text-3);margin-bottom:14px}.dlg-live{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--accent-soft);animation:dlgPulse 1.8s ease-in-out infinite}@keyframes dlgPulse{0%,to{opacity:1}50%{opacity:.35}}.dialogue-stream{display:flex;flex-direction:column;gap:12px}.dlg-line{display:flex;align-items:flex-start;gap:11px;max-width:88%}.dlg-line.me{flex-direction:row-reverse;align-self:flex-end;text-align:right}.dlg-bubble{background:var(--bg-2);border:1px solid var(--border);border-left:3px solid var(--who, var(--accent));border-radius:12px;padding:9px 13px}.dlg-line.me .dlg-bubble{border-left:1px solid var(--border);border-right:3px solid var(--who, var(--text-2));background:var(--bg-3)}.dlg-name{font-size:11px;font-weight:700;color:var(--who, var(--accent));margin-bottom:3px}.dlg-text{font-size:13.5px;line-height:1.55;color:var(--text-1)}.dlg-text code{background:var(--bg-0);border:1px solid var(--border-soft);border-radius:4px;padding:1px 5px;font-family:var(--mono);font-size:12px;color:var(--accent-2)}.dialogue-foot{display:flex;justify-content:flex-end;gap:8px;margin-top:14px}.dlg-btn{font:inherit;font-size:13px;font-weight:600;padding:7px 15px;border-radius:8px;cursor:pointer;border:1px solid var(--border);transition:filter .15s ease,background .15s ease}.dlg-btn.ghost{background:transparent;color:var(--text-2)}.dlg-btn.ghost:hover{background:var(--bg-2);color:var(--text-1)}.dlg-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.dlg-btn.primary:hover{filter:brightness(1.1)}
