:root{--bg:#060a11;--bg-1:#0a0f18;--bg-2:#0d131e;--card:#0f1622;--card-hi:#131c2a;--line:rgba(150,170,200,.09);--line-2:rgba(150,170,200,.16);--text:#e8eef7;--muted:#8b99af;--faint:#586377;--mint:#3ee6a3;--mint-dim:rgba(62,230,163,.12);--mint-glow:rgba(62,230,163,.35);--cyan:#46c6f5;--amber:#f5b14a;--red:#ff6a72;--display:"Archivo",sans-serif;--mono:"IBM Plex Mono",monospace;--r:14px}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:var(--display);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font-feature-settings:"ss01","cv01";overflow:hidden}body:before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(900px 500px at 8% -8%,rgba(62,230,163,.1),transparent 60%),radial-gradient(1000px 700px at 100% 0%,rgba(70,198,245,.06),transparent 55%),linear-gradient(to right,var(--line) 1px,transparent 1px) 0 0/48px 48px,linear-gradient(to bottom,var(--line) 1px,transparent 1px) 0 0/48px 48px;-webkit-mask:linear-gradient(to bottom,rgba(0,0,0,.6),rgba(0,0,0,.18));mask:linear-gradient(to bottom,rgba(0,0,0,.6),rgba(0,0,0,.18))}body:after{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.035;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}.app{position:relative;z-index:1;display:grid;grid-template-columns:236px 1fr;height:100vh}.sidebar{border-right:1px solid var(--line);background:linear-gradient(180deg,var(--bg-1),var(--bg));display:flex;flex-direction:column;padding:22px 16px}.brand{display:flex;align-items:center;gap:11px;padding:6px 8px 22px}.brand .mark{width:30px;height:30px;flex:none}.brand .wordmark{font-weight:800;font-size:19px;letter-spacing:-.02em}.brand .wordmark b{color:var(--mint)}.brand .tag{font-family:var(--mono);font-size:9.5px;letter-spacing:.22em;color:var(--faint);text-transform:uppercase;margin-top:2px}.nav-label{font-family:var(--mono);font-size:9.5px;letter-spacing:.2em;color:var(--faint);text-transform:uppercase;padding:18px 10px 8px}.nav a{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:9px;color:var(--muted);text-decoration:none;font-size:13.5px;font-weight:500;position:relative;transition:.18s}.nav a svg{width:16px;height:16px;opacity:.8}.nav a:hover{color:var(--text);background:var(--bg-2)}.nav a.active{color:var(--text);background:linear-gradient(90deg,var(--mint-dim),transparent)}.nav a.active:before{content:"";position:absolute;left:0;top:7px;bottom:7px;width:2.5px;border-radius:3px;background:var(--mint);box-shadow:0 0 12px var(--mint-glow)}.nav a .count{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--faint)}.side-foot{margin-top:auto;border-top:1px solid var(--line);padding-top:14px}.fabric-stat{display:flex;align-items:center;gap:9px;font-family:var(--mono);font-size:11px;color:var(--muted)}.fabric-stat .dot{width:7px;height:7px;border-radius:50%;background:var(--mint);box-shadow:0 0 0 0 var(--mint-glow);animation:pulse 2.6s infinite}@keyframes pulse{0%{box-shadow:0 0 0 0 var(--mint-glow)}70%{box-shadow:0 0 0 7px transparent}to{box-shadow:0 0 0 0 transparent}}.main{display:flex;flex-direction:column;min-width:0;overflow:hidden}.topbar{height:60px;flex:none;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:16px;padding:0 26px;background:#080c1399;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.crumb{font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.04em}.crumb b{color:var(--text);font-weight:500}.search{margin-left:8px;flex:1;max-width:340px;display:flex;align-items:center;gap:9px;background:var(--bg-2);border:1px solid var(--line);border-radius:9px;padding:8px 12px;color:var(--faint);font-family:var(--mono);font-size:12px}.search:focus-within{border-color:var(--line-2)}.search input{flex:1;background:none;border:0;color:var(--text);font-family:var(--mono);font-size:12px;outline:none}.search kbd{font-family:var(--mono);font-size:10px;border:1px solid var(--line-2);border-radius:5px;padding:1px 5px;color:var(--faint)}.topbar .spacer{margin-left:auto}.region-pill{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11.5px;color:var(--muted);border:1px solid var(--line);border-radius:20px;padding:6px 13px}.avatar{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,#16324a,#0c1a28);border:1px solid var(--line-2);display:grid;place-items:center;font-weight:700;font-size:12px;color:var(--mint)}.content{flex:1;overflow-y:auto;padding:30px 34px 60px}.content::-webkit-scrollbar{width:10px}.content::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:10px;border:3px solid var(--bg)}.eyebrow{font-family:var(--mono);font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--mint);display:flex;align-items:center;gap:9px}.eyebrow:before{content:"";width:22px;height:1px;background:var(--mint);opacity:.6}.h1{font-size:34px;font-weight:800;letter-spacing:-.025em;margin:11px 0 4px;display:flex;align-items:baseline;gap:14px}.h1 .meta{font-family:var(--mono);font-size:12px;font-weight:400;color:var(--faint);letter-spacing:0}.lede{color:var(--muted);font-size:14px;max-width:560px}.fabric{margin:26px 0 30px;border:1px solid var(--line);border-radius:var(--r);background:linear-gradient(180deg,var(--bg-2),var(--bg-1));overflow:hidden;position:relative}.fabric .head{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--line)}.fabric .head h3{font-size:13px;font-weight:600;letter-spacing:.01em}.fabric .head .legend{display:flex;gap:18px;font-family:var(--mono);font-size:10.5px;color:var(--muted)}.fabric .head .legend span{display:flex;align-items:center;gap:6px}.fabric .head .legend i{width:8px;height:8px;border-radius:2px;display:inline-block}.topo{height:148px;width:100%;display:block}.topo .edge{stroke:var(--cyan);stroke-width:1.4;fill:none;opacity:.25}.topo .flow{stroke:var(--mint);stroke-width:1.6;fill:none;stroke-dasharray:3 12;stroke-linecap:round;filter:drop-shadow(0 0 4px var(--mint-glow));animation:flow 1.5s linear infinite}@keyframes flow{to{stroke-dashoffset:-30}}.topo .node circle{fill:var(--card-hi);stroke:var(--mint);stroke-width:1.5}.topo .node .halo{fill:none;stroke:var(--mint);opacity:.4;animation:halo 3s ease-out infinite}@keyframes halo{0%{r:14px;opacity:.5}to{r:30px;opacity:0}}.topo text{font-family:var(--mono);font-size:10px;fill:var(--muted)}.topo .ip{fill:var(--faint);font-size:8.5px}.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:30px}.kpi{border:1px solid var(--line);border-radius:var(--r);background:var(--card);padding:16px 18px}.kpi .k{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint)}.kpi .v{font-size:27px;font-weight:800;letter-spacing:-.02em;margin-top:8px;font-variant-numeric:tabular-nums}.kpi .v small{font-size:13px;color:var(--muted);font-weight:500;margin-left:3px}.kpi .v.mint{color:var(--mint)}.kpi .v.amber{color:var(--amber)}.kpi .d{font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:5px}.sec{display:flex;align-items:center;justify-content:space-between;margin:6px 0 16px}.sec h2{font-size:16px;font-weight:700;letter-spacing:-.01em}.btn{font-family:var(--display);font-weight:600;font-size:13px;display:inline-flex;align-items:center;gap:8px;padding:9px 15px;border-radius:9px;border:1px solid var(--line-2);background:var(--bg-2);color:var(--text);cursor:pointer;transition:.16s;text-decoration:none}.btn:hover{border-color:var(--mint);color:var(--mint)}.btn.primary{background:var(--mint);color:#04130c;border-color:var(--mint)}.btn.primary:hover{box-shadow:0 0 26px var(--mint-glow);color:#04130c}.btn svg{width:15px;height:15px}.hosts{display:grid;grid-template-columns:repeat(auto-fill,minmax(370px,1fr));gap:16px}.host{border:1px solid var(--line);border-radius:var(--r);background:linear-gradient(180deg,var(--card),var(--bg-1));overflow:hidden;transition:.2s;opacity:0;transform:translateY(10px);animation:rise .6s forwards}.host:hover{border-color:var(--line-2);transform:translateY(-3px);box-shadow:0 18px 50px -22px #000c}@keyframes rise{to{opacity:1;transform:none}}.host .h{display:flex;align-items:flex-start;gap:13px;padding:18px 18px 14px}.flag{width:38px;height:38px;border-radius:10px;flex:none;display:grid;place-items:center;font-family:var(--mono);font-weight:600;font-size:13px;background:var(--card-hi);border:1px solid var(--line-2);color:var(--cyan)}.host .h .who{flex:1;min-width:0}.host .h .who .r{font-size:15.5px;font-weight:700;letter-spacing:-.01em;display:flex;align-items:center;gap:8px}.host .h .who .c{font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:3px}.pill{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;padding:3px 9px;border-radius:20px;display:inline-flex;align-items:center;gap:6px;border:1px solid}.pill i{width:6px;height:6px;border-radius:50%}.pill.up{color:var(--mint);border-color:#3ee6a34d;background:var(--mint-dim)}.pill.up i{background:var(--mint);box-shadow:0 0 8px var(--mint-glow)}.pill.warn{color:var(--amber);border-color:#f5b14a4d;background:#f5b14a1a}.pill.warn i{background:var(--amber)}.pill.prov{color:var(--cyan);border-color:#46c6f54d;background:#46c6f51a}.pill.prov i{background:var(--cyan);animation:pulse 1.6s infinite}.host .grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.host .grid .cell{background:var(--bg-1);padding:13px 18px}.host .grid .cell .k{font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint)}.host .grid .cell .val{font-family:var(--mono);font-size:13px;margin-top:5px;color:var(--text)}.bw{padding:14px 18px}.bw .top{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;color:var(--muted);margin-bottom:8px}.bw .top b{color:var(--text)}.bar{height:7px;border-radius:6px;background:var(--bg-2);overflow:hidden;border:1px solid var(--line)}.bar i{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,var(--cyan),var(--mint));box-shadow:0 0 12px var(--mint-glow);width:0;animation:fill 1.1s .3s cubic-bezier(.2,.7,.2,1) forwards}@keyframes fill{to{width:var(--w)}}.nodes{padding:6px 18px 16px}.nodes .cap{font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);padding:10px 0 8px}.nrow{display:grid;grid-template-columns:1fr auto auto auto;align-items:center;gap:12px;padding:8px 0;border-top:1px solid var(--line);font-family:var(--mono);font-size:12px}.nrow .t{color:var(--text);display:flex;align-items:center;gap:8px}.nrow .t .tdot{width:6px;height:6px;border-radius:2px;background:var(--cyan)}.nrow .role{color:var(--muted);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase}.nrow .port{color:var(--faint)}.nrow .st{width:7px;height:7px;border-radius:50%;background:var(--mint);box-shadow:0 0 7px var(--mint-glow);justify-self:end}.nrow .st.warn{background:var(--amber);box-shadow:none}.add{border:1.5px dashed var(--line-2);border-radius:var(--r);background:transparent;display:flex;flex-direction:column;justify-content:center;gap:14px;padding:24px;min-height:200px}.add h4{font-size:15px;font-weight:700;display:flex;align-items:center;gap:9px}.check{list-style:none;display:flex;flex-direction:column;gap:9px}.check li{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:12px;color:var(--muted)}.check li .b{width:16px;height:16px;border-radius:5px;border:1px solid var(--line-2);display:grid;place-items:center;flex:none}.check li.done .b{background:var(--mint-dim);border-color:var(--mint)}.check li.done .b svg{stroke:var(--mint)}.check li.todo .b svg{stroke:var(--faint)}.toolbar{display:flex;align-items:center;gap:9px;margin:2px 0 18px;flex-wrap:wrap}.toolbar .grow{flex:1}.chip{font-family:var(--mono);font-size:11.5px;color:var(--muted);border:1px solid var(--line);background:var(--bg-2);border-radius:8px;padding:7px 12px;cursor:pointer;transition:.15s;display:inline-flex;gap:7px;align-items:center}.chip:hover{border-color:var(--line-2);color:var(--text)}.chip.on{color:var(--mint);border-color:#3ee6a359;background:var(--mint-dim)}.chip .n{color:var(--faint)}.chip.on .n{color:var(--mint)}.tbl{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--card)}.thead,.trow{display:grid;grid-template-columns:2.5fr 1fr 1.5fr 1.2fr .95fr 1fr .95fr 34px;align-items:center;gap:14px;padding:0 18px}.thead{height:42px;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:9.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--faint);background:var(--bg-1)}.trow{height:58px;border-bottom:1px solid var(--line);font-size:13px;transition:.14s;opacity:0;animation:rise .5s forwards}.trow:last-child{border-bottom:0}.trow:hover{background:var(--bg-1)}.dev{display:flex;align-items:center;gap:11px;min-width:0}.dev .ic{width:31px;height:31px;border-radius:8px;flex:none;display:grid;place-items:center;background:var(--card-hi);border:1px solid var(--line-2);color:var(--cyan)}.dev .ic svg{width:16px;height:16px}.dev .nm{min-width:0}.dev .nm b{font-weight:600;font-size:13.5px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dev .nm span{font-family:var(--mono);font-size:10.5px;color:var(--faint)}.mono{font-family:var(--mono);font-size:12px;color:var(--muted)}.mono.tx{color:var(--text)}.tags{display:flex;gap:5px;flex-wrap:wrap}.tg{font-family:var(--mono);font-size:10px;padding:2px 7px;border-radius:6px;border:1px solid var(--line-2);color:var(--muted)}.tg.m{color:var(--cyan);border-color:#46c6f54d}.stat{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:11.5px}.stat i{width:7px;height:7px;border-radius:50%}.stat.up{color:var(--mint)}.stat.up i{background:var(--mint);box-shadow:0 0 7px var(--mint-glow)}.stat.down{color:var(--red)}.stat.down i{background:var(--red)}.stat.pend{color:var(--cyan)}.stat.pend i{background:var(--cyan);animation:pulse 1.6s infinite}.stat.rev{color:var(--faint)}.stat.rev i{background:var(--faint)}.lk{font-family:var(--mono);font-size:11px;display:inline-flex;align-items:center;gap:6px;color:var(--muted)}.lk i{width:6px;height:6px;border-radius:50%;background:var(--mint)}.lk.relay i{background:var(--amber)}.lk.relay{color:var(--amber)}.lk.none i{background:var(--faint)}.cert{font-family:var(--mono);font-size:11.5px;color:var(--muted)}.cert.soon{color:var(--amber)}.cert.exp{color:var(--red)}.rowbtn{width:26px;height:26px;border-radius:7px;border:1px solid transparent;background:none;color:var(--faint);cursor:pointer;display:grid;place-items:center;justify-self:end}.rowbtn:hover{border-color:var(--line-2);color:var(--text)}.tbl.t-certs .thead,.tbl.t-certs .trow{grid-template-columns:2.2fr 1fr 1.6fr 1.2fr 1.05fr .9fr 34px}.rev-panel{border:1px solid rgba(255,106,114,.25);border-radius:var(--r);background:linear-gradient(180deg,rgba(255,106,114,.06),var(--bg-1));overflow:hidden;margin-bottom:30px}.rev-panel .rh{display:flex;align-items:center;gap:14px;padding:16px 20px;border-bottom:1px solid var(--line)}.rev-panel .rh .badge{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--red);border:1px solid rgba(255,106,114,.3);background:#ff6a721a;border-radius:20px;padding:4px 10px;display:inline-flex;gap:6px;align-items:center;flex:none}.rev-panel .rh .badge i{width:6px;height:6px;border-radius:50%;background:var(--red)}.rev-panel .rh .who{flex:1;min-width:0}.rev-panel .rh .who b{font-size:14px}.rev-panel .rh .who span{font-family:var(--mono);font-size:11px;color:var(--muted);display:block;margin-top:2px}.rev-panel .rh .lat{text-align:right;font-family:var(--mono);flex:none}.rev-panel .rh .lat b{font-size:22px;color:var(--mint)}.rev-panel .rh .lat span{font-size:9px;color:var(--faint);display:block;text-transform:uppercase;letter-spacing:.14em;margin-top:2px}.steps{display:flex;align-items:center;padding:20px 20px 8px}.step{display:flex;align-items:center;gap:10px;flex:none}.step .sd{width:26px;height:26px;border-radius:50%;flex:none;display:grid;place-items:center;border:1px solid var(--line-2);background:var(--bg-2);color:var(--faint)}.step.done .sd{background:var(--mint-dim);border-color:var(--mint);color:var(--mint)}.step .lbl{font-family:var(--mono);font-size:11px;color:var(--muted)}.step.done .lbl{color:var(--text)}.step .lbl span{display:block;font-size:9.5px;color:var(--faint)}.conn{flex:1;height:1px;background:var(--line-2);margin:0 12px}.conn.on{background:var(--mint);opacity:.45}.acks{display:flex;gap:8px;padding:6px 20px 18px;flex-wrap:wrap}.ack{font-family:var(--mono);font-size:11px;display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);border-radius:8px;padding:6px 11px;color:var(--muted)}.ack i{width:6px;height:6px;border-radius:50%}.ack.ok{color:var(--mint);border-color:#3ee6a34d}.ack.ok i{background:var(--mint);box-shadow:0 0 7px var(--mint-glow)}.ack.na{color:var(--faint)}.ack.na i{background:var(--faint)}.cas{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;margin-bottom:30px}.ca{border:1px solid var(--line);border-radius:var(--r);background:linear-gradient(180deg,var(--card),var(--bg-1));padding:16px 18px}.ca .top{display:flex;align-items:center;gap:11px;margin-bottom:12px}.ca .top .shield{width:34px;height:34px;border-radius:9px;flex:none;display:grid;place-items:center;background:var(--card-hi);border:1px solid var(--line-2);color:var(--mint)}.ca .top b{font-size:14px;flex:1}.ca .crow{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11.5px;padding:7px 0;border-top:1px solid var(--line);color:var(--muted)}.ca .crow span:last-child{color:var(--text)}.kms{color:var(--mint);display:inline-flex;gap:5px;align-items:center}.flag.pfx{font-size:11px;color:var(--mint);letter-spacing:-.02em}.add.form{justify-content:flex-start;gap:12px}.poolform{display:grid;grid-template-columns:1fr 1fr;gap:10px}.poolform .f{display:flex;flex-direction:column;gap:5px}.poolform .f.wide{grid-column:1/-1}.poolform label{font-family:var(--mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint)}.poolform input{background:var(--bg-2);border:1px solid var(--line);border-radius:7px;padding:7px 10px;color:var(--text);font-family:var(--mono);font-size:12px;outline:none}.poolform input:focus{border-color:var(--mint)}.poolform input::placeholder{color:var(--faint)}.matrix{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--card);margin-bottom:30px}.matrix .mt{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--line)}.matrix .mt h3{font-size:13px;font-weight:600}.matrix .mt .hint{font-family:var(--mono);font-size:10.5px;color:var(--faint)}.mx{display:grid;grid-template-columns:130px repeat(5,1fr)}.mx .cap{font-family:var(--mono);font-size:9.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--faint);padding:12px;border-bottom:1px solid var(--line);display:flex;align-items:center}.mx .cap.col{justify-content:center}.mx .cap.src{color:var(--muted);border-right:1px solid var(--line)}.mx .cap.corner{border-right:1px solid var(--line);font-size:8.5px;color:var(--faint)}.mx .cell{display:grid;place-items:center;text-align:center;padding:10px 6px;border-bottom:1px solid var(--line);border-left:1px solid var(--line);font-family:var(--mono);min-height:50px}.mx .cell.allow{color:var(--mint);background:#3ee6a30d}.mx .cell.allow b{font-size:12px}.mx .cell.allow small{font-size:9px;color:var(--faint);display:block;margin-top:2px}.mx .cell.deny{color:var(--faint);font-size:14px}.mx .cell.self{background:repeating-linear-gradient(45deg,transparent,transparent 5px,rgba(150,170,200,.045) 5px,rgba(150,170,200,.045) 10px);color:var(--faint);font-size:9.5px}.rules{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--card)}.rule{display:grid;grid-template-columns:64px 1fr auto;align-items:center;gap:14px;padding:14px 18px;border-bottom:1px solid var(--line)}.rule:last-child{border-bottom:0}.rule .dir{font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;padding:4px 0;border-radius:7px;text-align:center;border:1px solid var(--line-2)}.rule .dir.out{color:var(--cyan);border-color:#46c6f54d}.rule .dir.in{color:var(--mint);border-color:#3ee6a34d}.rule .dir.deny{color:var(--faint)}.rule .desc{display:flex;align-items:center;gap:9px;flex-wrap:wrap;font-size:13px}.rule .desc .arrow{color:var(--faint);font-family:var(--mono)}.rule .meta2{font-family:var(--mono);font-size:11px;color:var(--muted);justify-self:end}.rule .sys{font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);border:1px solid var(--line);border-radius:6px;padding:3px 8px;margin-left:8px}.foot{margin-top:34px;display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:11px;color:var(--faint);border-top:1px solid var(--line);padding-top:18px}.foot a{color:var(--muted);text-decoration:none}.foot a:hover{color:var(--mint)}.tbl .thead,.tbl .trow{display:grid;align-items:center;gap:14px;padding:0 18px}.tbl-state{padding:30px 18px;font-family:var(--mono);font-size:12.5px;color:var(--muted);text-align:center}.tbl-error{color:var(--red)}.rowacts{display:flex;gap:6px;justify-content:flex-end}.rowacts .btn{padding:5px 10px;font-size:11.5px}.rowacts .ico{width:28px;height:28px;border-radius:7px;border:1px solid var(--line-2);background:var(--bg-2);color:var(--muted);cursor:pointer;display:grid;place-items:center;transition:.15s}.rowacts .ico:hover{border-color:var(--mint);color:var(--mint)}.rowacts .ico.danger:hover{border-color:var(--red);color:var(--red)}.modal-backdrop{position:fixed;inset:0;z-index:50;background:#04070ca8;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;padding:24px;animation:fade .14s ease}@keyframes fade{0%{opacity:0}to{opacity:1}}.modal{width:100%;max-width:480px;background:linear-gradient(180deg,var(--card),var(--bg-1));border:1px solid var(--line-2);border-radius:var(--r);box-shadow:0 30px 80px -20px #000c;overflow:hidden;animation:rise .2s forwards}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line)}.modal-head h3{font-size:15px;font-weight:700;letter-spacing:-.01em}.modal-x{background:none;border:0;color:var(--faint);font-size:22px;line-height:1;cursor:pointer;padding:0 4px;transition:.15s}.modal-x:hover{color:var(--text)}.modal-body{padding:20px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:22px}.confirm-msg{color:var(--muted);font-size:13.5px;line-height:1.55}.form{display:grid;gap:14px}.form.two{grid-template-columns:1fr 1fr}.f{display:flex;flex-direction:column;gap:6px}.f.wide{grid-column:1/-1}.f label{font-family:var(--mono);font-size:9.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--faint)}.f input,.f select,.f textarea{background:var(--bg-2);border:1px solid var(--line);border-radius:8px;padding:9px 11px;color:var(--text);font-family:var(--mono);font-size:12.5px;outline:none;transition:.15s;width:100%}.f input:focus,.f select:focus,.f textarea:focus{border-color:var(--mint)}.f input::placeholder{color:var(--faint)}.f-hint{font-family:var(--mono);font-size:10px;color:var(--faint)}.btn[disabled]{opacity:.45;cursor:not-allowed}.btn[disabled]:hover{box-shadow:none;border-color:var(--line-2);color:var(--text)}.btn.danger{background:var(--red);color:#1a0405;border-color:var(--red)}.btn.danger:hover{box-shadow:0 0 22px #ff6a7266;color:#1a0405}.form-err{font-family:var(--mono);font-size:11.5px;color:var(--red);border:1px solid rgba(255,106,114,.3);background:#ff6a7214;border-radius:8px;padding:8px 11px}.banner{font-family:var(--mono);font-size:12px;border-radius:var(--r);padding:14px 18px;margin-bottom:18px}.banner.err{color:var(--red);border:1px solid rgba(255,106,114,.3);background:#ff6a7214}.statepill{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;padding:3px 9px;border-radius:20px;display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line-2);color:var(--muted)}.statepill i{width:6px;height:6px;border-radius:50%;background:var(--faint)}.statepill.active,.statepill.online{color:var(--mint);border-color:#3ee6a34d;background:var(--mint-dim)}.statepill.active i,.statepill.online i{background:var(--mint);box-shadow:0 0 8px var(--mint-glow)}.statepill.suspended,.statepill.pending{color:var(--amber);border-color:#f5b14a4d;background:#f5b14a1a}.statepill.suspended i,.statepill.pending i{background:var(--amber)}.statepill.archived,.statepill.revoked{color:var(--faint)}.gate{position:relative;z-index:1;min-height:100vh;display:grid;place-items:center;padding:24px}.gate-card{width:100%;max-width:420px;background:linear-gradient(180deg,var(--card),var(--bg-1));border:1px solid var(--line-2);border-radius:var(--r);padding:30px 28px;display:flex;flex-direction:column;gap:14px;box-shadow:0 30px 80px -20px #000c}.gate-brand{display:flex;align-items:center;gap:11px;margin-bottom:6px}.gate-brand .mark{width:30px;height:30px}.gate-h1{font-size:24px;font-weight:800;letter-spacing:-.02em;margin-top:4px}.gate-lede{color:var(--muted);font-size:13px;line-height:1.5}.gate-card .btn{margin-top:4px;justify-content:center}
