:root{--bg-0:#050809;--bg-1:#0a0f10;--bg-2:#0f1718;--bg-3:#152022;--line:#1f2c2e;--text:#e8f5f2;--muted:#7a9290;--hl:#97FCE4;--hl-dim:#50d2c1;--hl-glow:rgba(151,252,228,0.35);--shadow:0 20px 60px rgba(0,0,0,0.6)}*{box-sizing:border-box;margin:0;padding:0}body,html{height:100%;background:#04080a;color:var(--text);font-family:ui-sans-serif,-apple-system,Inter,SF Pro Text,system-ui,sans-serif;-webkit-font-smoothing:antialiased;overflow:hidden}.app{display:grid;grid-template-rows:auto 1fr;height:100vh;position:relative}header{justify-content:space-between;gap:28px;flex-wrap:wrap;padding:14px 28px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,rgba(15,23,24,.96),rgba(15,23,24,.7));-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10}.brand,header{display:flex;align-items:center}.brand{gap:14px}.brand-mark{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;background:#03100d;border:1.5px solid var(--hl-dim);overflow:hidden;box-shadow:0 0 24px var(--hl-glow);flex-shrink:0}.brand-mark img{width:100%;height:100%;object-fit:cover;display:block}.brand-text h1{font-size:16px;font-weight:700;letter-spacing:-.2px}.brand-text p{font-size:11px;color:var(--muted);margin-top:2px;text-transform:uppercase;letter-spacing:1.4px}.header-right{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.docs-link{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;letter-spacing:1.4px;text-transform:uppercase;color:var(--muted);text-decoration:none;padding:8px 14px;border-radius:999px;border:1px solid var(--line);background:rgba(15,23,24,.6);transition:color .15s,border-color .15s,transform .15s,background .15s}.docs-link:hover{color:var(--hl);border-color:var(--hl-dim);transform:translateY(-1px)}.docs-link.built-by{background:rgba(151,252,228,.08);color:var(--hl);border-color:rgba(151,252,228,.3)}.docs-link.built-by:hover{background:rgba(151,252,228,.14);border-color:var(--hl)}main{position:relative;overflow:hidden;isolation:isolate}#bg-particles,#bg-waves{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;display:block}#bg-waves{z-index:0}#bg-particles{z-index:1;opacity:.55}#map{position:relative;z-index:2;width:100%;height:100%;display:block;cursor:-webkit-grab;cursor:grab;background:transparent}#map:active{cursor:-webkit-grabbing;cursor:grabbing}.protocol-tile{cursor:pointer;transition:transform .2s ease,filter .2s ease,opacity .2s ease;transform-origin:center;transform-box:fill-box}.protocol-tile:hover{filter:brightness(1.25) drop-shadow(0 0 18px var(--hl-glow))}.protocol-tile:hover .tile-lift{transform:translateY(-6px)}.protocol-tile.tile-dim{opacity:.18;filter:grayscale(.4)}.tile-lift{transition:transform .2s ease}.hub-pulse{transform-origin:center;transform-box:fill-box;animation:pulse 3s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.18;transform:scale(1)}50%{opacity:.55;transform:scale(1.15)}}.conn-line{fill:none;stroke-width:1.2;opacity:.55;transition:opacity .2s,stroke .2s}.conn-line.active{opacity:.9;filter:drop-shadow(0 0 4px var(--hl-glow))}.cat-label{font-size:11px;font-weight:700;letter-spacing:1.6px;text-transform:uppercase;pointer-events:none}.cat-sub{fill:var(--muted);font-size:9px;letter-spacing:1.2px;pointer-events:none}.map-controls{position:absolute;top:18px;left:18px;z-index:6;display:flex;flex-direction:column;gap:12px;padding:14px;border-radius:14px;background:rgba(10,16,18,.78);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--line);width:300px;box-shadow:0 12px 38px rgba(0,0,0,.45)}.search-wrap{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}.search-input{width:100%;padding:9px 30px 9px 32px;background:rgba(8,12,14,.7);border:1px solid var(--line);border-radius:9px;color:var(--text);font-size:12px;outline:none;font-family:inherit;transition:border-color .15s,background .15s}.search-input:focus{border-color:var(--hl-dim);background:rgba(8,12,14,.9)}.search-input::placeholder{color:var(--muted)}.search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:18px;height:18px;display:grid;place-items:center;background:var(--bg-3);border:none;border-radius:50%;color:var(--muted);cursor:pointer;font-size:14px;line-height:1;transition:color .15s,background .15s}.search-clear:hover{color:var(--text);background:var(--line)}.filter-head{display:flex;justify-content:space-between;align-items:center;padding:0 2px}.filter-title{font-weight:700;letter-spacing:1.4px;color:var(--muted)}.filter-title,.filter-toggle-all{font-size:10px;text-transform:uppercase}.filter-toggle-all{font-weight:600;letter-spacing:1px;color:var(--hl);background:transparent;border:none;cursor:pointer;padding:2px 4px;font-family:inherit;transition:opacity .15s}.filter-toggle-all:hover{opacity:.75}.filter-chips{display:flex;flex-wrap:wrap;gap:6px}.chip{display:inline-flex;align-items:center;gap:7px;padding:6px 10px;border-radius:999px;border:1px solid var(--line);background:rgba(8,12,14,.6);color:var(--text);font-size:11px;font-weight:600;cursor:pointer;transition:border-color .15s,opacity .15s,transform .15s,background .15s;font-family:inherit;-webkit-user-select:none;-moz-user-select:none;user-select:none}.chip:hover{border-color:var(--c);transform:translateY(-1px)}.chip.off{opacity:.4}.chip.on{background:color-mix(in srgb,var(--c) 8%,rgba(8,12,14,.6));border-color:color-mix(in srgb,var(--c) 35%,var(--line))}.chip-dot{width:8px;height:8px;border-radius:50%;background:var(--c);box-shadow:0 0 8px color-mix(in srgb,var(--c) 50%,transparent)}.chip-label{letter-spacing:.2px}.chip-count{color:var(--muted);font-size:10px;font-weight:500}.details{position:absolute;top:20px;right:20px;width:360px;max-height:calc(100% - 40px);background:linear-gradient(180deg,rgba(20,30,32,.96),rgba(10,15,16,.96));-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:var(--shadow);z-index:20;transform:translateX(20px);opacity:0;pointer-events:none;transition:transform .25s ease,opacity .25s ease;overflow-y:auto}.details.open{transform:translateX(0);opacity:1;pointer-events:auto}.details-close{position:absolute;top:14px;right:14px;width:28px;height:28px;border-radius:8px;border:1px solid var(--line);background:transparent;color:var(--muted);cursor:pointer;display:grid;place-items:center;transition:color .15s,border-color .15s;font-size:18px;line-height:1}.details-close:hover{color:var(--text);border-color:var(--hl-dim)}.details-header{display:flex;align-items:center;gap:14px;margin-bottom:18px}.details-logo{width:56px;height:56px;border-radius:14px;background:var(--bg-3);border:1px solid var(--line);overflow:hidden;flex-shrink:0;display:grid;place-items:center;font-weight:800;color:var(--hl)}.details-logo img{width:100%;height:100%;object-fit:cover}.details-title h2{font-size:18px;font-weight:700;letter-spacing:-.3px;margin-bottom:4px}.details-tag{display:inline-block;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1.2px;padding:3px 8px;border-radius:6px;background:var(--bg-3);color:var(--hl)}.details-desc{font-size:13px;line-height:1.6;color:#c4d6d3;margin-bottom:16px}.details-meta{display:grid;grid-gap:8px;gap:8px;margin-bottom:16px}.meta-row{display:grid;grid-template-columns:80px 1fr;grid-gap:10px;gap:10px;font-size:12px;align-items:center}.meta-label{color:var(--muted);text-transform:uppercase;letter-spacing:1px;font-size:10px}.meta-value a{color:var(--hl);text-decoration:none;word-break:break-all}.meta-value a:hover{text-decoration:underline}.details-actions{display:flex;gap:8px;flex-wrap:wrap}.btn{flex:1 1;min-width:100px;padding:9px 12px;border-radius:9px;border:1px solid var(--line);background:var(--bg-2);color:var(--text);font-size:12px;font-weight:600;cursor:pointer;text-decoration:none;text-align:center;transition:border-color .15s,background .15s,color .15s}.btn:hover{border-color:var(--hl-dim);color:var(--hl)}.btn-primary{background:var(--hl);color:#03100d;border-color:var(--hl)}.btn-primary:hover{background:var(--hl-dim);border-color:var(--hl-dim);color:#03100d}.hint{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);color:var(--muted);font-size:11px;letter-spacing:1.4px;text-transform:uppercase;pointer-events:none;opacity:.7;z-index:5}@media (max-width:900px){header{gap:14px;padding:12px 16px}.map-controls{max-width:360px;top:12px}.details,.map-controls{width:calc(100% - 24px);left:12px}.details{right:12px;top:auto;bottom:12px;max-height:60%}}