@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap";:root{--bg-dark: #0a0a0a;--bg-panel: #111111;--bg-accent: #1a1a1a;--text-primary: #efefef;--text-dim: #666666;--text-muted: #888888;--border-color: #333333;--border-active: #555555;--color-green: #00ff9d;--color-red: #ff4757;--color-orange: #ffa502;--color-blue: #3742fa;--color-gray: #747d8c;--font-ui: "Inter", sans-serif;--font-mono: "JetBrains Mono", monospace;--radius-sm: 2px;--radius-md: 4px}body{margin:0;background-color:var(--bg-dark);color:var(--text-primary);font-family:var(--font-ui);-webkit-font-smoothing:antialiased;overflow-y:hidden}#root{height:100vh;display:flex;flex-direction:column}*{box-sizing:border-box}input,button{font-family:var(--font-mono)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-dark)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-active)}.app-container{max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex;flex-direction:column;gap:1.5rem;height:100%}.app-header{display:flex;justify-content:space-between;align-items:flex-end;padding-bottom:1rem;border-bottom:1px solid var(--border-color);margin-top:1rem}.logo{font-family:var(--font-mono);font-weight:700;font-size:1.5rem;letter-spacing:-.05em;color:var(--text-primary)}.logo-brace{color:var(--text-dim)}.logo-text{margin:0 .2rem}.subtitle{font-family:var(--font-mono);font-size:.75rem;color:var(--text-dim);margin:0;letter-spacing:.1em}.main-content{flex:1;display:flex;flex-direction:column;gap:1.5rem;overflow:hidden}.control-grid{display:grid;grid-template-columns:2fr 1.5fr auto;gap:1rem}.control-module{background:var(--bg-panel);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:1rem;display:flex;flex-direction:column;gap:.5rem}.control-module label{font-family:var(--font-mono);font-size:.7rem;color:var(--text-dim);font-weight:600;letter-spacing:.05em}.input-row{display:flex;gap:.5rem;height:100%}.control-module input{background:var(--bg-dark);border:1px solid var(--border-color);color:var(--color-green);padding:.6rem;font-size:.9rem;border-radius:var(--radius-sm);outline:none;transition:border-color .2s;height:48px}.control-module input:focus{border-color:var(--text-dim)}.info-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-dim);width:48px;height:48px;border-radius:var(--radius-sm);cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:all .2s}.info-btn:hover{color:var(--text-primary);border-color:var(--text-primary);background:#ffffff0d}.port-inputs{display:flex;align-items:center;gap:.5rem}.port-inputs input{width:100%}.separator{color:var(--text-dim)}.action-module{padding:0;border:none;background:transparent;justify-content:flex-end}.scan-btn{background:var(--text-primary);color:var(--bg-dark);border:none;font-size:.9rem;font-weight:700;letter-spacing:.05em;padding:0 2rem;height:100%;min-height:48px;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;text-transform:uppercase;flex:1}.scan-btn:hover:not(:disabled){background:#fff;box-shadow:0 0 10px #fff3}.scan-btn.scanning{background:var(--bg-panel);border:1px solid var(--color-red);color:var(--color-red)}.terminal-window{flex:1;background:#050505;border:1px solid var(--border-color);border-radius:var(--radius-md);display:flex;flex-direction:column;overflow:hidden;font-family:var(--font-mono)}.terminal-header{background:var(--bg-panel);padding:.5rem 1rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:.5rem}.dot{width:10px;height:10px;border-radius:50%;opacity:.7}.dot.red{background:#ff5f56}.dot.yellow{background:#ffbd2e}.dot.green{background:#27c93f}.terminal-header .title{margin-left:.5rem;font-size:.75rem;color:var(--text-dim)}.terminal-body{flex:1;padding:.5rem;overflow-y:auto;font-size:.85rem}.log-table-header{display:flex;padding:.5rem;border-bottom:1px solid var(--border-color);color:var(--text-dim);font-size:.75rem;margin-bottom:.5rem;font-weight:700}.log-row{display:flex;padding:.2rem .5rem;color:var(--text-muted)}.log-row:hover{background:#ffffff08}.col-time{width:100px;opacity:.6}.col-port{width:80px}.col-status{width:120px;font-weight:600}.col-msg{flex:1}.status-info{color:var(--text-primary)}.status-open{color:var(--color-green)}.status-closed{color:var(--color-red);opacity:.7}.status-blocked{color:var(--color-gray);font-style:italic}.status-filtered{color:var(--color-orange)}.status-error{color:var(--color-red)}.status-bar{background:var(--bg-panel);border-top:1px solid var(--border-color);padding:.5rem 1rem;display:flex;gap:2rem;align-items:center;font-family:var(--font-mono);font-size:.75rem;margin-bottom:1rem}.status-section{display:flex;align-items:center;gap:.5rem}.status-label{color:var(--text-dim);font-weight:600}.status-value{color:var(--text-primary)}.status-value.scanning{color:var(--color-orange);animation:pulse 1.5s infinite}.status-value.idle{color:var(--text-dim)}.flex-grow{flex:1}.progress-track{flex:1;height:4px;background:var(--bg-dark);border-radius:2px;overflow:hidden;min-width:100px;margin:0 .5rem}.progress-fill{height:100%;background:var(--text-primary);transition:width .2s}.progress-text{width:35px;text-align:right}@keyframes pulse{0%{opacity:.6}50%{opacity:1}to{opacity:.6}}.modal-backdrop{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:999}.modal-content{background:var(--bg-panel);border:1px solid var(--border-color);border-radius:var(--radius-md);width:90%;max-width:600px;box-shadow:0 20px 50px #00000080;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;font-size:1rem;font-family:var(--font-mono);color:var(--text-primary);letter-spacing:.05em}.close-btn{background:transparent;border:none;color:var(--text-dim);font-size:1.5rem;cursor:pointer;line-height:1;padding:0}.close-btn:hover{color:var(--color-red)}.modal-body{padding:1.5rem;font-size:.9rem;line-height:1.6;color:var(--text-primary)}.modal-body section{margin-bottom:1.5rem}.modal-body section:last-child{margin-bottom:0}.modal-body h3{font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted);margin:0 0 .5rem;text-transform:uppercase}.modal-body p{margin:0}.modal-body ul{margin:.5rem 0 0 1rem;padding:0;color:var(--text-dim)}.modal-body li{margin-bottom:.25rem}
