*{box-sizing:border-box;margin:0;padding:0}body{color:#e6edf3;background:#0d1117;min-height:100vh;font-family:Segoe UI,system-ui,sans-serif;overflow-x:auto}.app{min-width:900px;max-width:1400px;margin:0 auto;padding:24px 16px}.app-header{border-bottom:1px solid #30363d;justify-content:space-between;align-items:center;margin-bottom:28px;padding-bottom:16px;display:flex}.app-header h1{color:#58a6ff;letter-spacing:.02em;font-size:1.4rem;font-weight:700}.chain-status{color:#3fb950;background:#0d2d1a;border:1px solid #238636;border-radius:12px;padding:4px 12px;font-size:.8rem}.app-main{flex-direction:row;align-items:flex-start;gap:24px;display:flex}.app-left{flex-direction:column;flex:1;gap:12px;min-width:0;display:flex}.app-right{flex-shrink:0;width:260px}.section-title{color:#8b949e;text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px;font-size:.85rem;font-weight:600}.network-container{background:#161b22;border:1px solid #30363d;border-radius:10px;padding:10px}.network-svg{margin:0 auto;display:block}.peer-line{stroke:#30363d;stroke-width:1.5px;stroke-dasharray:5 4}.node-circle{fill:#1c2637;stroke:#388bfd;stroke-width:2px}.node-circle.mining{stroke:#f0883e;stroke-width:3px}.node-label{text-anchor:middle;fill:#e6edf3;font-size:13px;font-weight:700}.node-balance{text-anchor:middle;fill:#3fb950;font-size:11px;font-weight:600}.node-address{text-anchor:middle;fill:#8b949e;font-family:monospace;font-size:9px}.mempool-badge{fill:#da3633}.mempool-count{text-anchor:middle;fill:#fff;font-size:10px;font-weight:700}.mining-label{text-anchor:middle;fill:#f0883e;font-size:11px}.msg-dot{opacity:.9}.msg-dot.tx{fill:#58a6ff}.msg-dot.block{fill:#f0883e}.msg-label{fill:#cae8ff;font-family:monospace;font-size:9px}.tx-form{background:#161b22;border:1px solid #30363d;border-radius:10px;padding:20px}.form-row{flex-wrap:wrap;align-items:flex-end;gap:12px;display:flex}.form-group{flex-direction:column;gap:4px;display:flex}.form-group label{color:#8b949e;font-size:.75rem;font-weight:600}.form-group select,.form-group input{color:#e6edf3;background:#0d1117;border:1px solid #30363d;border-radius:6px;outline:none;padding:7px 10px;font-size:.875rem}.form-group select:focus,.form-group input:focus{border-color:#58a6ff}.form-group input{width:90px}.arrow{color:#8b949e;padding-bottom:6px;font-size:1.2rem}.btn-send{color:#fff;cursor:pointer;white-space:nowrap;background:#238636;border:none;border-radius:6px;padding:8px 18px;font-size:.875rem;font-weight:600;transition:background .2s}.btn-send:hover{background:#2ea043}.error{color:#f85149;margin-top:8px;font-size:.8rem}.success{color:#3fb950;margin-top:8px;font-size:.8rem}.mine-row{flex-wrap:wrap;align-items:center;gap:12px;margin-top:14px;display:flex}.mempool-info{color:#8b949e;font-size:.8rem}.mine-buttons{flex-wrap:wrap;gap:8px;display:flex}.btn-mine{color:#e6edf3;cursor:pointer;background:#1c2637;border:1px solid #30363d;border-radius:6px;padding:6px 14px;font-size:.8rem;transition:all .2s}.btn-mine:hover:not(:disabled){color:#f0883e;background:#2d3748;border-color:#f0883e}.btn-mine:disabled{opacity:.4;cursor:not-allowed}.btn-mine.mining{color:#f0883e;border-color:#f0883e;animation:.8s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.hint{color:#6e7681;font-size:.75rem}.blockchain-container{background:#161b22;border:1px solid #30363d;border-radius:10px;padding:20px}.chain-scroll{flex-direction:column;align-items:stretch;gap:0;max-height:calc(100vh - 200px);padding-right:4px;display:flex;overflow-y:auto}.block-wrapper{flex-direction:column;align-items:center;display:flex}.block-card{cursor:pointer;background:#0d1117;border:1.5px solid #30363d;border-radius:8px;width:100%;padding:10px 14px;transition:border-color .2s,background .2s}.block-card:hover,.block-card.selected{background:#1c2637;border-color:#58a6ff}.block-card.genesis{border-color:#8b949e}.block-index{color:#58a6ff;margin-bottom:4px;font-size:.7rem;font-weight:700}.block-info{flex-direction:column;gap:2px;display:flex}.block-hash{color:#e6edf3;font-family:monospace;font-size:.75rem}.block-tx-count{color:#3fb950;font-size:.7rem}.block-nonce{color:#8b949e;margin-top:4px;font-size:.65rem}.chain-arrow{color:#58a6ff;padding:4px 0;font-size:1.2rem}.block-popup-overlay{z-index:100;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.block-popup{background:#161b22;border:1px solid #30363d;border-radius:12px;width:min(680px,90vw);max-height:80vh;padding:20px;overflow-y:auto}.block-popup-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.block-popup-header h3{color:#58a6ff;font-size:1rem;font-weight:700}.popup-miner{color:#f0883e;margin-top:2px;font-size:.75rem;display:block}.popup-close{color:#8b949e;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:1rem;transition:color .2s,background .2s}.popup-close:hover{color:#e6edf3;background:#30363d}.detail-grid{background:#0d1117;border:1px solid #30363d;border-radius:8px;grid-template-columns:1fr 1fr;gap:16px;padding:16px;display:grid}@media (width<=700px){.detail-grid{grid-template-columns:1fr}}.detail-section h3{color:#8b949e;text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;font-size:.8rem;font-weight:600}.detail-row{align-items:flex-start;gap:8px;margin-bottom:6px;display:flex}.detail-key{color:#8b949e;min-width:80px;padding-top:2px;font-size:.7rem}.detail-val{color:#cae8ff;word-break:break-all;font-family:monospace;font-size:.7rem}.detail-val.hash{color:#79c0ff}.tx-item{background:#161b22;border-radius:6px;margin-bottom:6px;padding:8px 10px}.tx-parties{align-items:center;gap:6px;font-size:.8rem;display:flex}.tx-from{color:#f0883e;font-weight:600}.tx-arrow{color:#8b949e}.tx-to{color:#58a6ff;font-weight:600}.tx-amount{color:#3fb950;margin-left:auto;font-weight:600}.tx-sig{color:#6e7681;margin-top:4px;font-family:monospace;font-size:.65rem}.no-tx{color:#6e7681;font-size:.8rem;font-style:italic}.log-window{z-index:200;flex-direction:column;align-items:flex-end;gap:8px;display:flex;position:fixed;bottom:20px;right:20px}.log-toggle{color:#e6edf3;cursor:pointer;background:#1c2637;border:1px solid #30363d;border-radius:20px;align-items:center;gap:6px;padding:8px 14px;font-size:.8rem;font-weight:600;transition:background .2s,border-color .2s;display:flex;box-shadow:0 2px 8px #0006}.log-toggle:hover{background:#2d3748;border-color:#58a6ff}.log-toggle-icon{font-size:.9rem}.log-toggle-label{color:#8b949e}.log-badge{color:#fff;text-align:center;background:#da3633;border-radius:10px;min-width:18px;padding:1px 6px;font-size:.65rem;font-weight:700}.log-panel{background:#161b22;border:1px solid #30363d;border-radius:10px;width:380px;overflow:hidden;box-shadow:0 4px 24px #00000080}.log-panel-header{color:#8b949e;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid #30363d;justify-content:space-between;align-items:center;padding:10px 14px;font-size:.8rem;font-weight:600;display:flex}.log-panel-actions{gap:8px;display:flex}.log-clear-btn{color:#8b949e;cursor:pointer;background:0 0;border:1px solid #30363d;border-radius:4px;padding:2px 8px;font-size:.7rem;transition:color .2s,border-color .2s}.log-clear-btn:hover{color:#f85149;border-color:#f85149}.log-close-btn{color:#8b949e;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:.9rem;transition:color .2s,background .2s}.log-close-btn:hover{color:#e6edf3;background:#30363d}.log-list{max-height:320px;padding:8px 0;overflow-y:auto}.log-empty{text-align:center;color:#484f58;padding:20px;font-size:.8rem}.log-entry{border-left:2px solid #0000;gap:8px;padding:5px 14px;font-size:.75rem;transition:background .1s;display:flex}.log-entry:hover{background:#1c2637}.log-entry.log-info{border-left-color:#58a6ff}.log-entry.log-success{border-left-color:#3fb950}.log-entry.log-warn{border-left-color:#f0883e}.log-time{color:#484f58;flex-shrink:0;font-family:monospace}.log-msg{color:#c9d1d9;word-break:break-all;line-height:1.5}.log-entry.log-success .log-msg{color:#3fb950}.log-entry.log-warn .log-msg{color:#f0883e}
