@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:wght,FILL@100..700,0..1&display=swap";:root,:root[data-theme=dark]{--bg: #000;--bg-gradient: radial-gradient(circle at top right, #1d0e04 0%, #000 40%);--panel: #111827;--panel-border: #263149;--surface: #1a2438;--surface-border: #334155;--sidebar: #02050a;--sidebar-border: #1f2b44;--card: #0d1423;--card-border: #273349;--text: #e6edf3;--text-muted: #8a99b3;--text-inverse: #ffffff;--text-label: #c9d4e8;--input-bg: #1b2438;--input-border: #34435f;--muted-bg: #242c3e;--header-bg: rgba(0, 0, 0, .7);--login-card: #0f1729;--tag-border: #334155;--tag-color: #cbd5e1;--avatar-bg: #243453;--nav-active: rgba(249, 115, 22, .12);--nav-active-border: rgba(249, 115, 22, .35);--orange: #f97316;--green: #10b981;--red: #ef4444}:root[data-theme=light]{--bg: #f1f5f9;--bg-gradient: linear-gradient(135deg, #e8eef5 0%, #d9e2ef 100%);--panel: #ffffff;--panel-border: #d1d9e6;--surface: #edf2f7;--surface-border: #c3cde0;--sidebar: #c9d8ec;--sidebar-border: #b0c2d8;--card: #ffffff;--card-border: #d1d9e6;--text: #0f172a;--text-muted: #64748b;--text-inverse: #0f172a;--text-label: #334155;--input-bg: #ffffff;--input-border: #c3cde0;--muted-bg: #dde4ef;--header-bg: rgba(232, 237, 245, .92);--login-card: #ffffff;--tag-border: #c3cde0;--tag-color: #64748b;--avatar-bg: #c3cde0;--nav-active: rgba(234, 88, 12, .1);--nav-active-border: rgba(234, 88, 12, .3);--orange: #ea580c;--green: #059669;--red: #dc2626}*{box-sizing:border-box}body{margin:0;font-family:Space Grotesk,sans-serif;background:var(--bg-gradient);background-attachment:fixed;color:var(--text);transition:background .3s ease,color .3s ease}a{color:inherit;text-decoration:none}button,input{font:inherit}.btn-primary,.btn-muted,.btn-outline{border:0;border-radius:10px;padding:.75rem 1rem;cursor:pointer;transition:background .2s ease,color .2s ease}.btn-primary{background:var(--orange);color:#fff;font-weight:700}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-muted{background:var(--muted-bg);color:var(--text)}.btn-outline{background:transparent;border:1px solid var(--orange);color:var(--orange)}.landing-page{min-height:100vh}.landing-header{display:flex;align-items:center;justify-content:space-between;min-height:72px;padding:.9rem 2rem;border-bottom:1px solid var(--sidebar-border);position:sticky;top:0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:var(--header-bg)}.landing-brand{display:flex;gap:.8rem;align-items:center}.landing-brand strong{color:var(--text-inverse);font-size:1.05rem;line-height:1;letter-spacing:.2px;white-space:nowrap}.brand-logo{display:inline-flex;align-items:center}.brand-logo img{width:148px;height:auto;display:block}.landing-brand-logo{filter:drop-shadow(0 0 8px rgba(0,0,0,.22))}.landing-header nav{display:flex;gap:1.25rem;align-items:center}.landing-header nav a{text-decoration:none;font-weight:500;color:var(--text-muted);font-size:.95rem;padding:.45rem 1.1rem;border-radius:999px;transition:all .25s cubic-bezier(.4,0,.2,1);border:1px solid transparent;position:relative}.landing-header nav a:hover{color:var(--orange);background:var(--nav-active);border-color:var(--nav-active-border)}.landing-header nav a.active,.landing-header nav a.active-section{background:var(--orange);color:#fff!important;box-shadow:0 4px 12px #ea580c59;transform:translateY(-1px)}.lang-toggle{display:inline-flex;align-items:center;gap:.2rem;padding:.2rem;border:1px solid var(--surface-border);border-radius:999px;background:var(--surface);color:var(--text-muted);cursor:pointer}.lang-toggle span{font-size:.78rem;font-weight:700;line-height:1;padding:.35rem .55rem;border-radius:999px;transition:background .2s ease,color .2s ease}.lang-toggle .active{background:var(--orange);color:#fff}.theme-toggle{min-width:42px;padding:.3rem .6rem;border:1px solid var(--surface-border);color:var(--text);background:transparent;display:inline-flex;align-items:center;justify-content:center}.theme-toggle.is-dark{border-color:#f9731673;box-shadow:0 0 0 2px #f9731626,0 0 16px #f9731647}.theme-toggle.is-light{border-color:#0ea5e973;box-shadow:0 0 0 2px #0ea5e91f,0 0 16px #0ea5e938}.theme-icon{font-size:1.1rem;line-height:1}.hero{display:grid;grid-template-columns:1.2fr 1fr;gap:2rem;max-width:1200px;margin:0 auto;padding:4rem 2rem}.pill{color:var(--orange);border:1px solid rgba(249,115,22,.4);padding:.35rem .75rem;border-radius:999px;font-size:.75rem;text-transform:uppercase;letter-spacing:1px}.hero h1{margin:1rem 0;font-size:clamp(2rem,6vw,4.5rem);line-height:1}.hero h1 span{color:var(--orange)}.hero p{color:var(--text-muted);max-width:560px}.hero-actions{display:flex;gap:1rem;margin-top:1.5rem}.hero-map{display:flex;align-items:center;justify-content:center}.map-frame{width:100%;max-width:420px;aspect-ratio:16 / 9;border-radius:18px;border:2px solid var(--surface-border);background:linear-gradient(120deg,#bae6fd,#dbeafe 45%,#bfdbfe)}.feature-grid{max-width:1200px;margin:0 auto;padding:1rem 2rem 4rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem}.feature-grid article{background:var(--surface);border:1px solid var(--surface-border);border-radius:14px;padding:1.5rem}.feature-grid h3{margin:.7rem 0}.feature-grid p{color:var(--text-muted)}.cta{padding:4rem 2rem;text-align:center;max-width:900px;margin:0 auto}.cta p{color:var(--text-muted)}.cta-row{margin-top:1rem;display:flex;gap:.75rem;justify-content:center}.cta-row input{width:min(450px,75vw);background:var(--input-bg);border:1px solid var(--input-border);border-radius:10px;color:var(--text);padding:.8rem}.landing-footer{border-top:1px solid var(--sidebar-border);padding:1rem 2rem;display:flex;justify-content:space-between;color:var(--text-muted)}.landing-footer div{display:flex;gap:1rem}.login-page{min-height:100vh;display:grid;grid-template-rows:auto 1fr}.login-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:72px;border-bottom:1px solid var(--sidebar-border);padding:.9rem 2rem}.login-card{width:min(460px,92vw);margin:auto;background:var(--login-card);border:1px solid var(--panel-border);border-radius:16px;padding:2rem;display:flex;flex-direction:column;gap:1rem}.login-card p{color:var(--text-muted);margin-top:-.5rem}.login-card label{display:flex;flex-direction:column;gap:.4rem;color:var(--text-label);font-size:.9rem}.login-card input{border:1px solid var(--input-border);background:var(--input-bg);color:var(--text);border-radius:10px;padding:.75rem}.error-box{background:#ef44441f;border:1px solid rgba(239,68,68,.5);color:#fecaca;border-radius:10px;padding:.6rem .8rem;font-size:.9rem}:root[data-theme=light] .error-box{color:#b91c1c}.app-layout{height:100vh;display:grid;grid-template-columns:290px 1fr;transition:grid-template-columns .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.app-layout.sidebar-collapsed{grid-template-columns:68px 1fr}.sidebar{border-right:1px solid var(--sidebar-border);padding:1rem;background:var(--sidebar);display:flex;flex-direction:column;gap:1rem;overflow:hidden;transition:width .3s cubic-bezier(.4,0,.2,1);width:290px}.sidebar.collapsed{padding:1rem .6rem;width:68px;align-items:center;cursor:pointer}.brand-block{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--sidebar-border);min-height:56px;padding-bottom:.85rem;width:100%;gap:.5rem}.sidebar.collapsed .brand-block{justify-content:center;padding-bottom:0;border-bottom:none}.sidebar-brand-logo img{width:140px}.sidebar-brand-logo--mini img{width:42px}.sidebar-collapse-toggle{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.3rem;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s ease,color .15s ease}.sidebar-collapse-toggle:hover{background:var(--surface);color:var(--text)}.sidebar-collapse-toggle--close{margin-left:auto}.brand-mark{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;background:var(--orange);color:#000}.brand-title{margin:0;font-size:.95rem;font-weight:700}.sidebar-brand-logo{filter:none}.sidebar-brand-logo img{width:122px}.brand-subtitle{margin:0;color:var(--text-muted);font-size:.72rem}.sidebar-nav{display:flex;flex-direction:column;gap:.25rem;width:100%}.nav-item{display:flex;gap:.6rem;align-items:center;padding:.65rem .7rem;border-radius:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;width:100%}.sidebar.collapsed .nav-item{justify-content:center;padding:.65rem;gap:0}.nav-item small{display:block;color:var(--text-muted);opacity:.8}.nav-item.active{background:var(--nav-active);border:1px solid var(--nav-active-border);color:var(--orange)}.logout-btn{margin-top:auto;border:1px solid var(--surface-border);background:var(--surface);color:var(--text);padding:.6rem;cursor:pointer}.sidebar-footer{margin-top:auto;display:flex;align-items:center;gap:.5rem;width:100%;border-top:1px solid var(--sidebar-border);padding-top:.85rem}.sidebar-user-pill{display:flex;align-items:center;gap:.55rem;flex:1;min-width:0;background:var(--surface);border:1px solid var(--surface-border);border-radius:999px;padding:.3rem .65rem .3rem .3rem;box-shadow:0 2px 4px #0000000f;overflow:hidden}.sidebar-user-info{min-width:0;overflow:hidden}.sidebar-user-info p,.sidebar-user-info small{margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.sidebar-user-info p{font-size:.82rem;font-weight:600;color:var(--text)}.sidebar-user-info small{font-size:.7rem;color:var(--text-muted)}.sidebar-logout-icon{background:transparent;border:1px solid var(--surface-border);border-radius:999px;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:.35rem;flex-shrink:0;transition:background .15s ease,color .15s ease,border-color .15s ease}.sidebar-logout-icon:hover{background:#ef44441f;border-color:#ef444466;color:var(--red)}.sidebar-logout-icon .material-symbols-outlined{font-size:1.1rem}.sidebar-user{display:flex;gap:.6rem;align-items:center;border-top:1px solid var(--sidebar-border);padding-top:1rem;width:100%}.sidebar-user--mini{margin-top:auto;justify-content:center;border-top:1px solid var(--sidebar-border);padding-top:1rem}.sidebar-user p,.sidebar-user small{margin:0}.sidebar-user small{color:var(--text-muted)}.user-avatar{width:35px;height:35px;border-radius:999px;background:var(--orange);color:#fff;display:grid;place-items:center;font-weight:700;overflow:hidden}.user-avatar-initial{color:#fff!important;font-weight:700;font-size:.95rem;line-height:1;-webkit-user-select:none;user-select:none}.user-avatar-image{width:100%;height:100%;object-fit:cover}.main-panel{min-width:0;display:grid;grid-template-rows:auto 1fr;overflow-y:auto;height:100vh}.topbar{border-bottom:1px solid var(--sidebar-border);display:flex;justify-content:space-between;align-items:center;min-height:72px;padding:.9rem 2rem;background:var(--sidebar)}.topbar h1{margin:0;font-size:1.1rem}.topbar-actions{display:flex;align-items:center;gap:.65rem;color:var(--text-muted);font-size:.9rem}.topbar-connection{display:inline-flex;align-items:center;gap:.4rem;margin-left:.5rem;white-space:nowrap;padding:.35rem .75rem;border:1px solid var(--surface-border);border-radius:999px;background:var(--surface);color:var(--text-muted);font-size:.78rem;font-weight:700;box-shadow:0 2px 4px #0000000d}.status-dot{width:7px;height:7px;border-radius:99px;background:var(--green)}.main-content{padding:1.25rem 2rem}.topbar-left{display:flex;align-items:center;gap:1rem}.menu-toggle{display:none;background:transparent;border:none;color:var(--text);cursor:pointer;padding:.4rem;border-radius:8px;align-items:center;justify-content:center}.menu-toggle:hover{background:var(--surface)}.mobile-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:40;opacity:0;pointer-events:none;transition:opacity .3s ease}.mobile-overlay.open{opacity:1;pointer-events:auto}.panel-page{display:flex;flex-direction:column;gap:1.15rem}.panel-heading-row{display:flex;justify-content:space-between;align-items:flex-end;min-height:56px;gap:1rem;padding:.15rem 0 .35rem;border-bottom:1px solid var(--panel-border)}.panel-heading-row>div{display:flex;flex-direction:column;justify-content:center;gap:.25rem}.panel-heading-row h2,.panel-page h3{margin:0;line-height:1.15}.panel-heading-row p,.panel-page p{color:var(--text-muted);margin:0}.analytics-card,.table-card,.form-card{background:var(--panel);border:1px solid var(--panel-border);border-radius:14px;padding:1rem}.analytics-card{min-height:240px;display:grid;place-content:center;text-align:center}.analytics-card .material-symbols-outlined{color:var(--orange);font-size:2rem}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.8rem}.stats-row article{background:var(--panel);border:1px solid var(--panel-border);border-radius:12px;padding:1rem}.stats-row small{color:var(--text-muted);display:block}.stats-row strong{font-size:1.6rem}.dashboard-filters{padding:.9rem 1rem}.dashboard-filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.8rem;align-items:end}.dashboard-filter-actions{display:flex;align-items:center;gap:.55rem}.dashboard-stats{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.dashboard-stats article strong{font-size:1.2rem;line-height:1.2}.dashboard-chart-card{min-height:0;display:block;text-align:left}.dashboard-sensors-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:.9rem}.sensor-chart-card{display:flex;flex-direction:column;gap:.6rem}.sensor-chart-head{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.sensor-chart-head h3{margin:0}.trend-chart{width:100%;height:auto;margin-top:.6rem;border:1px solid var(--surface-border);border-radius:12px;background:linear-gradient(to bottom,#f973161f,#f9731608)}.trend-line{fill:none;stroke:var(--orange);stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}.trend-area{pointer-events:none}.trend-grid{stroke:color-mix(in srgb,var(--text-muted) 35%,transparent);stroke-width:1}.trend-grid-base{stroke:color-mix(in srgb,var(--text-muted) 55%,transparent)}.trend-label{fill:var(--text-muted);font-size:9.5px;letter-spacing:.15px}.trend-point{fill:var(--orange)}.trend-legend{display:flex;flex-wrap:wrap;gap:.45rem .75rem;margin-top:.6rem;color:var(--text-muted);font-size:.82rem}.trend-legend-item{display:inline-flex;align-items:center;gap:.35rem}.trend-legend-item i{width:12px;height:3px;border-radius:999px;display:inline-block}.sensor-mini-stats{display:flex;flex-wrap:wrap;gap:.45rem .8rem;color:var(--text-muted);font-size:.82rem}.node-map-card{overflow:hidden}.node-map-frame{width:100%;min-height:220px;border:1px solid var(--surface-border);border-radius:10px}.node-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem}.node-card{background:var(--card);border:1px solid var(--card-border);border-radius:12px;padding:1rem}.node-card header{display:flex;gap:.5rem;margin-bottom:.5rem}.tag{padding:.2rem .45rem;border-radius:999px;font-size:.7rem;border:1px solid var(--tag-border);color:var(--tag-color)}.tag.green{color:#86efac;border-color:#14532d;background:#22c55e26}:root[data-theme=light] .tag.green{color:#166534;border-color:#166534;background:#22c55e1a}.tag.gray{color:var(--tag-color);border-color:var(--tag-border)}.tag.red{color:#fecaca;border-color:#7f1d1d;background:#ef444426}:root[data-theme=light] .tag.red{color:#991b1b;border-color:#991b1b;background:#ef44441a}.tag.red-soft{color:#fca5a5;border-color:#991b1b}.node-metrics{margin-top:.8rem;display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.node-metrics div{background:var(--surface);border:1px solid var(--surface-border);border-radius:8px;padding:.4rem}.node-metrics small{color:var(--text-muted);display:block}.landing-controls{display:flex;gap:1rem;align-items:center}.table-header{display:flex;justify-content:space-between;align-items:center;min-height:44px;gap:.75rem;margin-bottom:.75rem}.table-header span{color:var(--orange);font-size:.8rem}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:.55rem;border-bottom:1px solid var(--panel-border);font-size:.92rem}th{color:var(--text-muted)}.status-pill{display:inline-block;padding:.2rem .45rem;border-radius:999px;text-transform:capitalize;font-size:.75rem}.status-pill.ok{color:#86efac;background:#22c55e1a;border:1px solid rgba(34,197,94,.35)}:root[data-theme=light] .status-pill.ok{color:#166534;background:#22c55e1a;border-color:#166534}.status-pill.off{color:var(--tag-color);background:#64748b1f;border:1px solid var(--tag-border)}.form-card{display:flex;flex-direction:column;gap:.75rem}.form-card label{display:flex;flex-direction:column;gap:.35rem;color:var(--text-label)}.form-card input,.form-card select{background:var(--input-bg);border:1px solid var(--input-border);color:var(--text);border-radius:10px;padding:.65rem}.about-page-content,.download-page-content{min-height:calc(100vh - 132px);display:flex;flex-direction:column;justify-content:center}.about-section,.download-section{padding:4rem 2rem;max-width:1000px;margin:0 auto;text-align:center}.download-section h2{font-size:2.2rem;margin-bottom:.5rem}.download-subtitle{color:var(--text-muted);margin-bottom:3rem}.download-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.download-card{background:var(--surface);border:1px solid var(--surface-border);border-radius:16px;padding:2.5rem;display:flex;flex-direction:column;align-items:center;gap:1.2rem;transition:transform .2s ease,box-shadow .2s ease}.download-card:hover{transform:translateY(-5px);box-shadow:0 8px 24px #0000001a}.download-icon{font-size:3rem!important;color:var(--orange)}.download-card h3{margin:0;font-size:1.5rem}.download-card p{color:var(--text-muted);line-height:1.6;margin-bottom:1rem}.highlighted-card{border:2px solid var(--orange);background:var(--panel)}.about-section h2{font-size:2.2rem;margin-bottom:.5rem}.about-subtitle{color:var(--text-muted);margin-bottom:3rem}.about-grid{display:flex;flex-direction:column;gap:2rem}.about-card{display:flex;align-items:center;gap:2.5rem;background:var(--surface);border:1px solid var(--surface-border);border-radius:16px;padding:2.5rem;text-align:left}.about-card:nth-child(2n){flex-direction:row-reverse}.about-photo{width:160px;height:160px;border-radius:50%;object-fit:cover;border:4px solid var(--panel);box-shadow:0 4px 16px #0000001a;flex-shrink:0}.about-info{display:flex;flex-direction:column;justify-content:center}.about-info h3{margin:0 0 .5rem;color:var(--orange);font-size:1.4rem}.about-info p{margin:0;color:var(--text-muted);line-height:1.6}@media (max-width: 1000px){.hero{grid-template-columns:1fr;padding-top:2rem}.app-layout{grid-template-columns:1fr}.sidebar{position:fixed;top:0;left:-100%;width:280px;height:100vh;z-index:50;transition:left .3s cubic-bezier(.4,0,.2,1);box-shadow:4px 0 15px #0000004d}.sidebar.open{left:0}.menu-toggle{display:flex}.landing-header nav{display:none}.landing-controls{gap:.55rem}.landing-header,.login-header,.topbar{padding:.85rem 1rem}.main-content{padding:1rem}.panel-heading-row{align-items:flex-start;flex-direction:column}.node-grid{grid-template-columns:repeat(2,1fr)}.about-card,.about-card:nth-child(2n){flex-direction:column;text-align:center;padding:1.5rem;gap:1.5rem}.landing-footer{flex-direction:column;gap:.7rem}}@media (max-width: 480px){.hero h1{font-size:2.2rem}.login-card{padding:1.5rem}.cta-row input{width:100%}.dashboard-filters{padding:.6rem}.node-grid{grid-template-columns:1fr}}.ws-status-badge{display:flex;align-items:center;gap:.45rem;font-size:.8rem;color:var(--text-muted)}.log-toolbar{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}.log-level-select{background:var(--input-bg);border:1px solid var(--input-border);color:var(--text);border-radius:8px;padding:.35rem .65rem;font-size:.82rem;cursor:pointer;font-family:inherit}.log-autoscroll-label{display:flex;align-items:center;gap:.4rem;font-size:.82rem;color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none}.log-autoscroll-label input{accent-color:var(--orange);cursor:pointer}.log-clear-btn{display:flex;align-items:center;gap:.3rem;padding:.35rem .75rem;font-size:.82rem;border-radius:8px}.log-clear-btn .material-symbols-outlined{font-size:1rem}.log-count{margin-left:auto;font-size:.78rem;color:var(--text-muted)}.log-terminal{background:#050c17;border:1px solid var(--panel-border);border-radius:12px;padding:.75rem 1rem;min-height:420px;max-height:60vh;overflow-y:auto;font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:.78rem;line-height:1.6;scroll-behavior:smooth}[data-theme=light] .log-terminal{background:#f8fafc;border-color:var(--card-border)}.log-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;height:200px;color:var(--text-muted);font-family:inherit}.log-empty .material-symbols-outlined{font-size:2rem;color:var(--orange)}.log-entry{display:flex;gap:.75rem;align-items:baseline;padding:.1rem 0;border-bottom:1px solid rgba(255,255,255,.03)}.log-entry:hover{background:#f973160a}.log-ts{color:#4a5568;flex-shrink:0;min-width:7ch}.log-node{color:#63b3ed;flex-shrink:0;min-width:4ch}.log-level{font-weight:600;flex-shrink:0;min-width:9ch;letter-spacing:.3px}.log-message{color:#cbd5e0;word-break:break-all}[data-theme=light] .log-node{color:#2563eb}[data-theme=light] .log-message{color:#1e293b}[data-theme=light] .log-entry{border-bottom-color:#0000000a}:focus-visible{outline:2px solid var(--orange);outline-offset:2px}.lang-toggle:focus-visible,.sidebar-logout-icon:focus-visible{outline-offset:3px;border-radius:999px}.btn-primary,.btn-muted,.btn-outline{min-height:44px}.nav-item:hover:not(.active){background:var(--surface);color:var(--text)}.node-card{transition:border-color .2s ease,box-shadow .2s ease}.node-card:hover{border-color:var(--orange);box-shadow:0 4px 16px #f973161f}.node-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}@media (max-width: 1000px){.node-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}}@media (max-width: 480px){.node-grid{grid-template-columns:1fr}}.node-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;flex-wrap:unset}.trend-chart{background:var(--surface)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-dialog{width:400px;max-width:90%;box-shadow:0 10px 25px #00000080}.success-box{background:#10b9811a;border:1px solid rgba(16,185,129,.35);color:var(--green);border-radius:10px;padding:.75rem 1rem;font-size:.88rem}.form-actions{display:flex;gap:10px}.table-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.last-updated{font-size:.8em;color:var(--text-muted)}.ws-status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0;box-shadow:0 0 6px currentColor}@keyframes ws-pulse{0%,to{opacity:1}50%{opacity:.3}}.ws-status-dot.connecting,.status-dot.connecting{animation:ws-pulse 1.2s ease-in-out infinite}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.log-ts{color:#718096}[data-theme=light] .log-ts{color:#94a3b8}.log-entry{border-bottom:1px solid var(--panel-border)}.sidebar-collapse-toggle{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;display:flex;align-items:center;border-radius:6px;transition:color .2s ease,background .2s ease}.sidebar-collapse-toggle:hover{color:var(--text);background:var(--surface)}@media (max-width: 480px){.topbar-connection span:last-child{display:none}.log-terminal{max-height:45vh}}
