*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-root: #070c18;--bg-surface: #0f172a;--bg-card: #1e293b;--bg-input: #0f1e33;--border: #2d3f5a;--text-primary:#e2e8f0;--text-muted: #64748b;--text-dim: #94a3b8;--rip: #f97316;--rip-dim: #431407;--ospf: #06b6d4;--ospf-dim: #0c2540;--green: #4ade80;--purple: #818cf8;--yellow: #fbbf24;--red: #f87171;--font-mono: "Courier New", "Consolas", monospace;--radius: 8px;--shadow: 0 4px 24px rgba(0,0,0,.4)}html,body,#root{height:100%;font-family:Segoe UI,system-ui,sans-serif;background:var(--bg-root);color:var(--text-primary);font-size:14px;line-height:1.5}.app-root{display:flex;flex-direction:column;height:100vh;min-height:600px;overflow:hidden}.app-header{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0;gap:12px}.header-left{display:flex;align-items:center;gap:16px}.app-logo{display:flex;align-items:center;gap:8px}.logo-icon{font-size:22px}.logo-title{font-size:18px;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.header-subtitle{font-size:12px;color:var(--text-muted);border-left:1px solid var(--border);padding-left:16px}.header-right{display:flex;align-items:center;gap:12px}.active-protocol-badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:700;color:#000;letter-spacing:.5px}.phase-indicator{font-size:12px;color:var(--text-dim);background:var(--bg-card);border:1px solid var(--border);padding:4px 10px;border-radius:20px}.control-panel{display:flex;align-items:center;gap:16px;padding:10px 20px;background:var(--bg-surface);border-bottom:2px solid var(--border);flex-shrink:0;flex-wrap:wrap}.control-section{display:flex;align-items:center;gap:8px}.control-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.protocol-toggle{display:flex;background:var(--bg-root);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.proto-btn{padding:6px 16px;background:transparent;border:none;color:var(--text-muted);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:4px}.proto-btn:hover{color:var(--text-primary);background:var(--bg-card)}.proto-btn--active-rip{background:var(--rip-dim);color:var(--rip);border-right:1px solid var(--border)}.proto-btn--active-ospf{background:var(--ospf-dim);color:var(--ospf)}.proto-icon{font-size:14px}.endpoint-select{background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);font-size:12px;padding:5px 8px;border-radius:var(--radius);cursor:pointer;font-family:var(--font-mono)}.endpoint-select:focus{outline:none;border-color:var(--ospf)}.playback-controls{display:flex;gap:4px}.ctrl-btn{width:34px;height:34px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:14px;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.ctrl-btn:hover:not(:disabled){background:var(--bg-input);border-color:var(--text-dim)}.ctrl-btn:disabled{opacity:.3;cursor:not-allowed}.ctrl-btn--play{width:40px;background:var(--green);border-color:var(--green);color:#000;font-size:16px}.ctrl-btn--play:hover{opacity:.85}.ctrl-btn--pause{background:var(--yellow);border-color:var(--yellow);color:#000}.speed-buttons{display:flex;gap:3px}.speed-btn{padding:4px 10px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);font-size:11px;font-weight:600;cursor:pointer;transition:all .15s}.speed-btn:hover{color:var(--text-primary)}.speed-btn--active{background:#1d4ed8;border-color:#3b82f6;color:#bfdbfe}.progress-section{flex:1;min-width:200px;flex-direction:column;align-items:flex-start;gap:4px}.progress-bar-wrap{width:100%;height:6px;background:var(--bg-root);border-radius:3px;overflow:hidden;border:1px solid var(--border)}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#06b6d4);border-radius:3px;transition:width .3s ease}.step-counter{font-size:11px;color:var(--text-muted);font-family:var(--font-mono)}.app-main{display:grid;grid-template-columns:1fr 380px;gap:0;flex:1;overflow:hidden;min-height:0}.map-section{display:flex;flex-direction:column;border-right:1px solid var(--border);overflow:hidden;background:var(--bg-root)}.section-title{padding:8px 16px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;border-bottom:1px solid var(--border);background:var(--bg-surface)}.section-subtitle{font-weight:400;color:var(--text-muted)}.map-container{flex:1;overflow:hidden;padding:8px;display:flex;align-items:center;justify-content:center}.network-map-svg{width:100%;height:100%;max-height:100%;object-fit:contain}.teaching-section{display:flex;flex-direction:column;overflow:hidden;background:var(--bg-surface)}.app-footer{height:180px;flex-shrink:0;border-top:2px solid var(--border);background:var(--bg-surface);display:flex;flex-direction:column;overflow:hidden}.teaching-panel{display:flex;flex-direction:column;height:100%;overflow:hidden}.tp-header{padding:8px 12px;border-bottom:2px solid;display:flex;align-items:center;gap:10px;flex-shrink:0;background:var(--bg-card)}.tp-protocol-badge{padding:3px 10px;border-radius:4px;font-size:11px;font-weight:800;color:#000;letter-spacing:1px}.tp-phase-badge{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.tp-tabs{display:flex;background:var(--bg-root);border-bottom:1px solid var(--border);flex-shrink:0}.tp-tab{flex:1;padding:7px 4px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}.tp-tab:hover{color:var(--text-primary);background:var(--bg-card)}.tp-tab--active{color:var(--ospf);border-bottom-color:currentColor;background:var(--bg-surface)}.tp-body{flex:1;overflow-y:auto;padding:10px 12px}.tp-step-content{display:flex;flex-direction:column;gap:10px}.step-title{font-size:14px;font-weight:700;line-height:1.3}.packet-badge{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:6px 10px}.packet-badge-label{font-size:10px;color:var(--text-muted);text-transform:uppercase}.packet-badge-name{font-size:13px;font-weight:700;margin-left:6px}.packet-desc{font-size:11px;color:var(--text-dim);margin-top:4px}.step-description{font-size:12px;color:var(--text-dim);font-family:var(--font-mono);background:var(--bg-card);padding:6px 10px;border-radius:var(--radius);border-left:3px solid var(--border)}.teaching-note{background:#0e1f35;border:1px solid #1d4ed8;border-radius:var(--radius);padding:8px 10px}.note-label{font-size:10px;font-weight:700;color:#60a5fa;margin-bottom:4px}.note-text{font-size:12px;color:var(--text-dim);line-height:1.5}.calculation-box{background:#0a1a0a;border:1px solid #166534;border-radius:var(--radius);padding:8px 10px}.calc-label{font-size:10px;font-weight:700;color:var(--green);margin-bottom:4px}.calc-text{font-size:11px;color:#86efac;font-family:var(--font-mono);white-space:pre-wrap;word-break:break-all;line-height:1.6}.slow-link-warning{background:#3b0000;border:1px solid var(--red);border-radius:var(--radius);padding:8px 10px;font-size:12px;color:#fca5a5;font-weight:600;line-height:1.5}.routing-table-container{margin-bottom:12px}.routing-table-header{font-size:11px;font-weight:700;color:var(--text-dim);border-left:3px solid;padding-left:8px;margin-bottom:6px;font-family:var(--font-mono)}.routing-table{width:100%;border-collapse:collapse;font-size:11px}.routing-table th{background:var(--bg-card);color:var(--text-muted);font-weight:600;text-align:left;padding:5px 8px;border-bottom:1px solid var(--border);font-size:10px;text-transform:uppercase}.routing-table td{padding:5px 8px;border-bottom:1px solid #1a2640}.routing-table tr:last-child td{border-bottom:none}.table-row-direct td{background:#0a1f0a}.table-row-learned:hover td{background:var(--bg-card)}.badge-direct{background:#14532d;color:var(--green);font-size:10px;padding:1px 6px;border-radius:3px;font-family:var(--font-mono)}.metric-cell{font-weight:700}.mono{font-family:var(--font-mono)}.table-router-select-row{display:flex;align-items:center;gap:8px;margin-bottom:10px}.all-tables-hint{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:8px;font-size:11px;color:var(--text-muted)}.router-chip{background:var(--bg-card);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-family:var(--font-mono);font-size:10px}.lsdb-panel{display:flex;flex-direction:column;gap:8px}.lsdb-title{font-size:12px;font-weight:700;color:var(--ospf);margin-bottom:4px}.lsa-entry{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:8px}.lsa-router{font-size:11px;font-weight:700;color:var(--ospf);font-family:var(--font-mono);margin-bottom:4px}.lsa-links{display:flex;flex-direction:column;gap:2px}.lsa-link-row{display:flex;align-items:center;gap:8px;font-size:11px;font-family:var(--font-mono)}.lsa-arrow{color:var(--text-muted)}.lsa-cost{color:var(--ospf);font-weight:600}.lsa-bw{color:var(--text-muted);font-size:10px}.spf-table-container{margin-top:8px}.spf-title{font-size:11px;font-weight:700;color:var(--ospf);margin-bottom:6px}.spf-current td{background:#0c2540}.spf-visited td{background:#0a1f0a;opacity:.8}.spf-improved td{background:#1a1a00}.protocol-info{display:flex;flex-direction:column;gap:12px}.info-section{display:flex;flex-direction:column;gap:6px}.info-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);padding-bottom:4px;margin-bottom:2px}.packet-type-row{display:flex;align-items:flex-start;gap:8px}.packet-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:2px}.packet-type-name{font-size:12px;font-weight:600}.packet-type-desc{font-size:11px;color:var(--text-muted)}.facts-table{width:100%;border-collapse:collapse}.facts-table td{padding:4px 8px;font-size:11px;border-bottom:1px solid #1a2640}.facts-table td:first-child{color:var(--text-muted);font-weight:600;width:40%}.facts-table td:last-child{color:var(--text-dim);font-family:var(--font-mono)}.pros-cons{display:grid;grid-template-columns:1fr 1fr;gap:8px}.pros-box,.cons-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:8px}.pros-title{font-size:11px;font-weight:700;color:var(--green);margin-bottom:4px}.cons-title{font-size:11px;font-weight:700;color:var(--red);margin-bottom:4px}.pro-item,.con-item{font-size:10.5px;color:var(--text-dim);line-height:1.6}.formula-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:10px}.formula{font-family:var(--font-mono);font-size:13px;color:var(--green);font-weight:700;margin-bottom:8px}.formula-examples{display:flex;flex-direction:column;gap:2px;font-size:11px;color:var(--text-muted)}.formula-examples strong{color:var(--text-primary)}.trace-table-wrapper{display:flex;flex-direction:column;height:100%;overflow:hidden}.trace-header{display:flex;align-items:center;justify-content:space-between;padding:6px 16px;background:var(--bg-card);border-bottom:1px solid var(--border);flex-shrink:0}.trace-title{font-size:12px;font-weight:700;color:var(--text-dim)}.trace-count{font-size:11px;font-family:var(--font-mono)}.trace-body{flex:1;overflow-y:auto}.trace-table{width:100%;border-collapse:collapse;font-size:11px}.trace-table th{background:var(--bg-root);color:var(--text-muted);font-weight:600;text-align:left;padding:5px 10px;border-bottom:1px solid var(--border);font-size:10px;text-transform:uppercase;position:sticky;top:0;z-index:1}.trace-table td{padding:5px 10px;border-bottom:1px solid #111d2e}.trace-row:hover td{background:var(--bg-card)}.trace-row--current td{background:#0f1e33}.trace-row--current{border-left-width:3px!important}.trace-num{color:var(--text-muted);font-family:var(--font-mono);width:40px}.trace-phase-badge{font-size:10px;font-weight:700}.trace-event{display:flex;align-items:center;gap:6px;white-space:nowrap}.trace-icon{font-size:13px}.trace-title-cell{font-weight:600;color:var(--text-primary)}.trace-desc{color:var(--text-muted);font-size:11px;font-family:var(--font-mono)}.trace-empty{text-align:center;color:var(--text-muted);padding:24px;font-style:italic;font-size:13px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-root)}::-webkit-scrollbar-thumb{background:#2d3f5a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#3d5270}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.pulse{animation:pulse 1.5s ease-in-out infinite}*,*:before,*:after{box-sizing:border-box}body{margin:0;padding:0;overflow:hidden}#root{width:100vw;height:100vh}button{font-family:inherit}
