@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;600&family=Barlow+Condensed:wght@400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0c0e;--bg2: #0f1215;--bg3: #141820;--bg4: #1a2030;--border: #1e2530;--border2: #253040;--accent: #00e5a0;--accent-dim: #00b87a;--accent-glow: rgba(0,229,160,.12);--accent-glow2: rgba(0,229,160,.06);--danger: #ff4455;--danger-dim: #cc2233;--danger-glow: rgba(255,68,85,.12);--warn: #ffaa00;--text: #c8d8e8;--text2: #7a92a8;--text3: #445566;--online: #00e5a0;--offline: #445566;--font-display: "Barlow Condensed", sans-serif;--font-mono: "IBM Plex Mono", monospace;--radius: 4px;--radius2: 8px}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:var(--font-display);letter-spacing:.02em}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg2)}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text3)}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:56px;background:var(--bg2);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:16px}.logo{font-family:var(--font-mono);font-size:1rem;font-weight:600;color:var(--accent);letter-spacing:.1em}.logo-bracket{color:var(--text3)}.header-title{display:flex;flex-direction:column}.title-main{font-size:1rem;font-weight:700;color:var(--text);letter-spacing:.15em}.title-sub{font-family:var(--font-mono);font-size:.65rem;color:var(--text3)}.status-indicator{display:flex;align-items:center;gap:8px}.pulse{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;box-shadow:0 0 8px var(--accent)}50%{opacity:.5;box-shadow:0 0 4px var(--accent)}}.status-text{font-family:var(--font-mono);font-size:.7rem;color:var(--accent);letter-spacing:.1em}.app-nav{display:flex;gap:0;background:var(--bg2);border-bottom:1px solid var(--border);padding:0 24px}.nav-btn{background:none;border:none;border-bottom:2px solid transparent;color:var(--text3);font-family:var(--font-display);font-size:.85rem;font-weight:600;letter-spacing:.12em;padding:12px 20px;cursor:pointer;transition:color .2s,border-color .2s}.nav-btn:hover{color:var(--text)}.nav-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.app-main{flex:1;padding:24px;max-width:1200px;width:100%;margin:0 auto}.view-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.view-title{display:flex;align-items:baseline;gap:12px}.view-title h2{font-size:1.6rem;font-weight:700;letter-spacing:.15em;color:var(--text)}.view-subtitle{font-family:var(--font-mono);font-size:.75rem;color:var(--accent)}.view-actions{display:flex;align-items:center;gap:12px}.last-refresh{font-family:var(--font-mono);font-size:.65rem;color:var(--text3)}.device-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.device-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius2);padding:20px;cursor:pointer;transition:border-color .2s,box-shadow .2s,transform .15s;position:relative;overflow:hidden}.device-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--border2);transition:background .2s}.device-card.online:before{background:var(--accent);box-shadow:0 0 12px var(--accent-glow)}.device-card:hover{border-color:var(--border2);box-shadow:0 4px 24px #0006;transform:translateY(-2px)}.device-card.online:hover{border-color:var(--accent-dim);box-shadow:0 4px 24px var(--accent-glow)}.device-card-header{display:flex;align-items:center;gap:10px;margin-bottom:4px}.device-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.device-card.online .device-status-dot{background:var(--accent);box-shadow:0 0 6px var(--accent)}.device-card.offline .device-status-dot{background:var(--offline)}.device-name{font-size:1.1rem;font-weight:700;letter-spacing:.1em;flex:1}.device-serial{font-family:var(--font-mono);font-size:.65rem;color:var(--text3);margin-bottom:16px}.device-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;margin-bottom:16px}.stat{display:flex;flex-direction:column;gap:2px}.stat-label{font-size:.65rem;color:var(--text3);letter-spacing:.1em}.stat-value{font-size:.85rem;color:var(--text)}.device-metrics{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.metric{display:flex;align-items:center;gap:8px}.metric-label{font-size:.65rem;color:var(--text3);width:28px;letter-spacing:.05em}.metric-bar{flex:1;height:3px;background:var(--border2);border-radius:2px;overflow:hidden}.metric-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .5s}.metric-value{font-family:var(--font-mono);font-size:.7rem;color:var(--text2);width:30px;text-align:right}.device-card-footer{border-top:1px solid var(--border);padding-top:12px;margin-top:4px}.view-details{font-size:.75rem;color:var(--accent);letter-spacing:.1em}.badge,.device-badge{font-family:var(--font-mono);font-size:.6rem;font-weight:600;padding:2px 6px;border-radius:2px;letter-spacing:.1em}.badge-online{background:#00e5a01a;color:var(--accent);border:1px solid rgba(0,229,160,.3)}.badge-offline{background:#4563;color:var(--text3);border:1px solid var(--border)}.count-badge{font-family:var(--font-mono);font-size:.7rem;color:var(--accent)}.detail-header{display:flex;align-items:center;gap:16px;margin-bottom:0;padding-bottom:20px;border-bottom:1px solid var(--border)}.btn-back{background:none;border:1px solid var(--border);border-radius:var(--radius);color:var(--text2);font-family:var(--font-display);font-size:.8rem;letter-spacing:.1em;padding:6px 12px;cursor:pointer;transition:border-color .2s,color .2s}.btn-back:hover{border-color:var(--text2);color:var(--text)}.detail-title{display:flex;align-items:center;gap:12px;flex:1}.detail-status-dot{width:10px;height:10px;border-radius:50}.detail-status-dot[data-online=true]{background:var(--accent);box-shadow:0 0 8px var(--accent);border-radius:50%}.detail-status-dot[data-online=false]{background:var(--offline);border-radius:50%}.detail-title h2{font-size:1.4rem;font-weight:700;letter-spacing:.12em}.detail-serial{font-family:var(--font-mono);font-size:.7rem;color:var(--text3)}.detail-actions{display:flex;gap:10px}.detail-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:24px;margin-top:0}.tab-btn{background:none;border:none;border-bottom:2px solid transparent;color:var(--text3);font-family:var(--font-display);font-size:.8rem;font-weight:600;letter-spacing:.1em;padding:14px 18px;cursor:pointer;transition:color .2s,border-color .2s}.tab-btn:hover{color:var(--text2)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-content{display:flex;flex-direction:column;gap:24px}.section{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius2);padding:20px}.section h3{font-size:.8rem;font-weight:700;letter-spacing:.15em;color:var(--text3);margin-bottom:16px;text-transform:uppercase}.section-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-header-row h3{margin-bottom:0}.section-note{font-size:.8rem;color:var(--text3);margin-bottom:16px}.overview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.info-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius2);padding:20px}.info-card h3{font-size:.75rem;font-weight:700;letter-spacing:.15em;color:var(--text3);margin-bottom:14px}.info-table{width:100%;border-collapse:collapse}.info-table td{padding:6px 0;font-size:.85rem;vertical-align:middle}.info-table td:first-child{color:var(--text3);font-size:.75rem;width:40%}.info-table td:last-child{color:var(--text);text-align:right}.metric-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}.metric-label{font-size:.7rem;color:var(--text3);width:55px;letter-spacing:.08em}.metric-bar-lg{flex:1;height:4px;background:var(--border2);border-radius:2px;overflow:hidden}.metric-val{font-family:var(--font-mono);font-size:.75rem;color:var(--text2);width:36px;text-align:right}.mem-detail{font-size:.7rem;color:var(--text3);margin-top:4px}button{font-family:var(--font-display);letter-spacing:.1em}.btn-primary{background:var(--accent);color:#000;border:none;border-radius:var(--radius);font-size:.8rem;font-weight:700;padding:8px 16px;cursor:pointer;transition:background .2s,box-shadow .2s}.btn-primary:hover{background:#00ffb0;box-shadow:0 0 12px var(--accent-glow)}.btn-primary:disabled{background:var(--border2);color:var(--text3);cursor:not-allowed;box-shadow:none}.btn-primary.btn-lg{padding:10px 24px;font-size:.85rem}.btn-secondary{background:transparent;color:var(--text2);border:1px solid var(--border2);border-radius:var(--radius);font-size:.8rem;font-weight:600;padding:8px 16px;cursor:pointer;transition:border-color .2s,color .2s}.btn-secondary:hover{border-color:var(--text2);color:var(--text)}.btn-secondary:disabled{opacity:.4;cursor:not-allowed}.btn-action{background:transparent;color:var(--text2);border:1px solid var(--border2);border-radius:var(--radius);font-size:.75rem;font-weight:600;letter-spacing:.1em;padding:7px 14px;cursor:pointer;transition:border-color .2s,color .2s}.btn-action:hover{border-color:var(--accent);color:var(--accent)}.btn-action:disabled{opacity:.6;cursor:not-allowed}.btn-danger{background:transparent;color:var(--danger);border:1px solid rgba(255,68,85,.4);border-radius:var(--radius);font-size:.75rem;font-weight:600;letter-spacing:.1em;padding:7px 14px;cursor:pointer;transition:background .2s,border-color .2s}.btn-danger:hover{background:var(--danger-glow);border-color:var(--danger)}.btn-danger:disabled{opacity:.4;cursor:not-allowed}.btn-delete{background:none;border:none;color:var(--text3);font-size:.9rem;cursor:pointer;padding:2px 6px;border-radius:var(--radius);transition:color .2s,background .2s}.btn-delete:hover{color:var(--danger);background:var(--danger-glow)}.toggle-btn{font-family:var(--font-mono);font-size:.65rem;font-weight:600;letter-spacing:.1em;padding:4px 10px;border-radius:var(--radius);cursor:pointer;border:1px solid;transition:all .2s}.toggle-btn.on{background:var(--accent-glow);color:var(--accent);border-color:#00e5a066}.toggle-btn.off{background:transparent;color:var(--text3);border-color:var(--border)}.toggle-btn.large{padding:8px 18px;font-size:.75rem}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-grid-3{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.7rem;color:var(--text3);letter-spacing:.1em}.field-hint{font-size:.65rem;color:var(--text3)}.form-input{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius);color:var(--text);font-family:var(--font-display);font-size:.9rem;padding:8px 12px;width:100%;transition:border-color .2s,box-shadow .2s;outline:none}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow2)}.form-input::placeholder{color:var(--text3)}.form-select{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius);color:var(--text);font-family:var(--font-display);font-size:.9rem;padding:8px 32px 8px 12px;width:100%;cursor:pointer;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23445566' fill='none' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;transition:border-color .2s}.form-select:focus{border-color:var(--accent)}.form-select option{background:var(--bg3)}.input-row{display:flex;gap:8px}.input-row .form-input{flex:1}.input-with-hint{position:relative}.input-hint{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-family:var(--font-mono);font-size:.65rem;color:var(--accent);pointer-events:none}.channel-row{display:flex;align-items:center;gap:8px}.channel-row .form-select{flex:1}.checkbox-label{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--text2);cursor:pointer;white-space:nowrap}.checkbox-label input[type=checkbox]{accent-color:var(--accent);width:14px;height:14px}.toggles-row{align-items:center;gap:20px;flex-wrap:wrap;padding-top:4px}.toggles-row.form-row{display:flex}.wifi-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius2);overflow:hidden}.wifi-card-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--bg3);border-bottom:1px solid var(--border)}.wifi-label{display:flex;align-items:center;gap:10px}.wifi-name{font-size:1rem;font-weight:700;letter-spacing:.08em}.wifi-band-badge{font-family:var(--font-mono);font-size:.65rem;background:var(--bg4);border:1px solid var(--border2);color:var(--text2);padding:2px 8px;border-radius:var(--radius)}.toggle-group{display:flex;align-items:center;gap:10px}.toggle-label{font-size:.65rem;color:var(--text3);letter-spacing:.1em}.wifi-form{padding:20px;display:flex;flex-direction:column;gap:16px}.wifi-card-footer{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:12px 20px;background:var(--bg3);border-top:1px solid var(--border)}.firewall-levels{display:flex;flex-direction:column;gap:10px}.firewall-level-card{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:var(--radius);border:1px solid var(--border);cursor:pointer;transition:border-color .2s,background .2s;background:var(--bg3)}.firewall-level-card:hover{border-color:var(--border2);background:var(--bg4)}.firewall-level-card.selected{border-color:var(--accent);background:var(--accent-glow2)}.level-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.firewall-level-card.level-low .level-dot{background:var(--warn)}.firewall-level-card.level-medium .level-dot{background:#48f}.firewall-level-card.level-high .level-dot{background:var(--accent)}.level-info{display:flex;flex-direction:column;gap:2px;flex:1}.level-name{font-size:.9rem;font-weight:700;letter-spacing:.1em}.level-desc{font-size:.75rem;color:var(--text3)}.level-check{color:var(--accent);font-size:1rem}.toggle-card{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-radius:var(--radius);border:1px solid var(--border);cursor:pointer;background:var(--bg3);transition:border-color .2s}.toggle-card:hover{border-color:var(--border2)}.toggle-card-info{display:flex;flex-direction:column;gap:4px}.toggle-card-label{font-size:.85rem;font-weight:600;letter-spacing:.08em}.toggle-card-desc{font-size:.75rem;color:var(--text3);max-width:480px}.data-table{width:100%;border-collapse:collapse;margin-top:4px}.data-table th{font-size:.65rem;color:var(--text3);letter-spacing:.1em;padding:8px 12px;text-align:left;border-bottom:1px solid var(--border)}.data-table td{padding:10px 12px;font-size:.85rem;border-bottom:1px solid var(--border);color:var(--text)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--bg3)}.data-table tr.row-inactive td{opacity:.5}.empty-state{padding:24px;text-align:center;font-family:var(--font-mono);font-size:.7rem;color:var(--text3);letter-spacing:.1em;background:var(--bg3);border-radius:var(--radius)}.add-row-form{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-end;padding:16px;background:var(--bg3);border-radius:var(--radius);margin-bottom:16px}.add-row-form .form-input{min-width:150px;flex:1}.add-port-form{background:var(--bg3);border-radius:var(--radius);padding:16px;margin-bottom:16px}.add-row-actions{display:flex;justify-content:flex-end;margin-top:12px}.save-row{display:flex;align-items:center;justify-content:flex-end;gap:14px;padding-top:4px}.status-ok{font-family:var(--font-mono);font-size:.75rem;color:var(--accent)}.status-err{font-family:var(--font-mono);font-size:.75rem;color:var(--danger)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius2);padding:28px;max-width:420px;width:90%}.modal h3{font-size:1rem;font-weight:700;letter-spacing:.1em;color:var(--danger);margin-bottom:14px}.modal-warning{font-size:.85rem;color:var(--text2);margin-bottom:20px;line-height:1.6}.modal-warning strong{color:var(--text)}.reset-code-box{display:flex;flex-direction:column;align-items:center;gap:4px;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius);padding:14px;margin-bottom:16px}.reset-code-label{font-size:.65rem;color:var(--text3);letter-spacing:.12em}.reset-code{font-family:var(--font-mono);font-size:1.4rem;color:var(--danger);letter-spacing:.3em;font-weight:600}.modal-instruction{font-size:.8rem;color:var(--text3);margin-bottom:10px}.reset-input{width:100%;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius);color:var(--text);font-size:1rem;padding:10px 12px;margin-bottom:16px;outline:none;text-align:center;letter-spacing:.3em}.reset-input:focus{border-color:var(--danger)}.modal-actions{display:flex;gap:10px;justify-content:flex-end}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:60px;color:var(--text3);font-family:var(--font-mono);font-size:.75rem;letter-spacing:.1em}.loading-spinner{width:24px;height:24px;border:2px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-banner{background:var(--danger-glow);border:1px solid rgba(255,68,85,.3);border-radius:var(--radius);padding:12px 16px;font-family:var(--font-mono);font-size:.75rem;color:var(--danger);margin-bottom:16px}.mono{font-family:var(--font-mono)!important}.muted{color:var(--text3)}@media (max-width: 640px){.app-main{padding:16px}.device-grid,.form-grid,.form-row,.form-grid-3{grid-template-columns:1fr}.detail-header{flex-wrap:wrap;gap:10px}.detail-actions{width:100%;justify-content:flex-end}.view-header{flex-direction:column;align-items:flex-start;gap:12px}}
