.diagram-container.svelte-1gc2rad{position:relative;background:var(--card-bg);border-radius:16px;padding:16px;border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden}.controls-overlay.svelte-1gc2rad{position:absolute;top:12px;right:12px;z-index:10;background:color-mix(in srgb,var(--card-bg) 90%,transparent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:10px;padding:8px 10px;display:flex;flex-direction:column;gap:4px;box-shadow:var(--shadow);max-width:200px}.control-group.svelte-1gc2rad{display:flex;flex-direction:column;gap:3px}.group-label.svelte-1gc2rad{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text);opacity:.5;padding:2px 0}.control-btn.svelte-1gc2rad{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text-h);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}.control-btn.svelte-1gc2rad:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.control-btn.svelte-1gc2rad:disabled{opacity:.35;cursor:not-allowed}.control-btn.state-ok.svelte-1gc2rad{border-color:var(--green);color:var(--green);background:var(--green-light)}.control-btn.state-ok.svelte-1gc2rad:hover{color:#047857;border-color:#047857}.control-btn.state-broken.svelte-1gc2rad{border-color:#ef4444;color:#ef4444;background:color-mix(in srgb,var(--error-red) 15%,var(--card-bg))}.control-btn.state-broken.svelte-1gc2rad:hover{border-color:#dc2626;color:#dc2626}.control-divider.svelte-1gc2rad{height:1px;background:var(--border);margin:2px 0}.control-status.svelte-1gc2rad{font-size:11px;font-weight:600;padding:4px 0 0;border-top:1px solid var(--border);color:var(--text);line-height:1.3;text-align:center}.control-status.degraded.svelte-1gc2rad{color:#dc2626}.status-alert.svelte-1gc2rad{display:block;font-weight:700}.status-detail.svelte-1gc2rad{display:block;color:var(--text);font-weight:500}.diagram-svg.svelte-1gc2rad{width:100%;height:auto;color:var(--accent)}.legend.svelte-1gc2rad{display:flex;gap:24px;justify-content:center;padding:12px 0 0}.legend-item.svelte-1gc2rad{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text);font-weight:500}.legend-icon.svelte-1gc2rad{flex-shrink:0}.legend-blue-icon.svelte-1gc2rad{color:var(--accent)}.legend-dot.svelte-1gc2rad{width:14px;height:14px;border-radius:50%;flex-shrink:0}.vpn-line.svelte-1gc2rad{stroke:var(--accent);stroke-width:1.5;opacity:.4}.vpn-direct-line.svelte-1gc2rad{stroke:var(--accent);stroke-width:1.5;opacity:.35}.vpn-label.svelte-1gc2rad{font-size:12px;fill:var(--accent);text-anchor:middle;opacity:.45;font-weight:600}.https-line.svelte-1gc2rad{stroke:var(--green);stroke-width:2;stroke-dasharray:8 4;opacity:.45;animation:svelte-1gc2rad-dash 1.5s linear infinite}.portal-https-line.svelte-1gc2rad{stroke:#ef4444;opacity:.6}@keyframes svelte-1gc2rad-dash{to{stroke-dashoffset:-12}}.rdp-conn-line.svelte-1gc2rad{stroke:#f97316;stroke-width:2.5;stroke-dasharray:10 6}.https-label.svelte-1gc2rad{font-size:12px;fill:var(--green);text-anchor:middle;opacity:.5;font-weight:600}.wan-conn.svelte-1gc2rad{stroke-width:2.5;stroke-linecap:round}.wan-ftto.svelte-1gc2rad{stroke-width:4}.wan-ftto-thin.svelte-1gc2rad{stroke-width:2.5}.wan-4g.svelte-1gc2rad{stroke-dasharray:8 4}.wan-line-active.svelte-1gc2rad{stroke:var(--green);stroke-dasharray:none;opacity:.7}.wan-line-standby.svelte-1gc2rad{stroke:var(--border);stroke-dasharray:6 4;opacity:.4}.wan-line-failed.svelte-1gc2rad{stroke:#ef4444;stroke-dasharray:6 4;opacity:.8;animation:svelte-1gc2rad-blink .5s ease-in-out infinite}@keyframes svelte-1gc2rad-blink{0%,to{opacity:.8}50%{opacity:.2}}.wan-conn-label.svelte-1gc2rad{font-size:12px;fill:var(--text);text-anchor:middle;opacity:.55;font-weight:600}.node.svelte-1gc2rad{cursor:pointer}.node-bg.svelte-1gc2rad{fill:var(--accent-light);stroke:var(--accent);stroke-width:2;transition:fill .15s}.node.svelte-1gc2rad:hover .node-bg:where(.svelte-1gc2rad){fill:var(--accent)}.hub-bg.svelte-1gc2rad{fill:var(--accent-light);stroke:var(--accent);stroke-width:2.5}.node.svelte-1gc2rad:hover .hub-bg:where(.svelte-1gc2rad){fill:var(--accent)}.shield-passive.svelte-1gc2rad{color:var(--bg-muted);opacity:.4}.shield-active.svelte-1gc2rad{color:var(--accent)}.shield-failed.svelte-1gc2rad{color:#ef4444;animation:svelte-1gc2rad-blink .5s ease-in-out infinite}.fw-failed.svelte-1gc2rad{stroke:#ef4444!important;fill:#fef2f2!important;animation:svelte-1gc2rad-blink .5s ease-in-out infinite}.fw-standby.svelte-1gc2rad{stroke:#d1d5db!important;fill:#f9fafb!important}.site-bg.svelte-1gc2rad{fill:var(--accent-light);stroke:var(--accent);stroke-width:2}.node.svelte-1gc2rad:hover .site-bg:where(.svelte-1gc2rad){fill:var(--accent)}.remote-bg.svelte-1gc2rad{fill:var(--surface);stroke:var(--surface-stroke)}.node.svelte-1gc2rad:hover .remote-bg:where(.svelte-1gc2rad){fill:var(--surface-stroke)}.user-bg.svelte-1gc2rad{fill:var(--surface);stroke:var(--surface-stroke);stroke-width:2}.node.svelte-1gc2rad:hover .user-bg:where(.svelte-1gc2rad){fill:var(--surface-stroke)}.node.svelte-1gc2rad:hover{color:#fff}.node-dark.svelte-1gc2rad{color:var(--surface-stroke)}.node-dark.svelte-1gc2rad:hover{color:#fff}.node-label.svelte-1gc2rad{font-size:15px;fill:var(--text-h);text-anchor:middle;font-weight:600}.hub-label.svelte-1gc2rad{fill:var(--accent-dark);font-size:16px}.server-node.svelte-1gc2rad{cursor:default}.server-link.svelte-1gc2rad{stroke:var(--accent);stroke-width:1.5;opacity:.3}.server-label.svelte-1gc2rad{font-size:12px;fill:var(--text);text-anchor:middle;font-weight:600}.particle-blue.svelte-1gc2rad{fill:var(--accent)}.particle-green.svelte-1gc2rad{fill:var(--green)}.particle-red.svelte-1gc2rad{fill:#ef4444}.particle-glow.svelte-1gc2rad{fill:none}.particle-blue-glow.svelte-1gc2rad{stroke:var(--accent);stroke-width:2;opacity:.3;animation:svelte-1gc2rad-pulse .6s ease-in-out infinite}.particle-green-glow.svelte-1gc2rad{stroke:var(--green);stroke-width:2;opacity:.3}.particle-red-glow.svelte-1gc2rad{stroke:#ef4444;stroke-width:2;opacity:.3;animation:svelte-1gc2rad-pulse .6s ease-in-out infinite}.particle-orange.svelte-1gc2rad{fill:#f97316}.particle-orange-glow.svelte-1gc2rad{stroke:#f97316;stroke-width:2;opacity:.3;animation:svelte-1gc2rad-pulse .6s ease-in-out infinite}.port-badge-text.svelte-1gc2rad{font-size:11px;fill:#fff;font-weight:700}.backup-bg.svelte-1gc2rad{fill:#fff7ed;stroke:#f97316;stroke-width:2}.backup-label.svelte-1gc2rad{fill:#f97316}.backup-line.svelte-1gc2rad{stroke:#f97316;stroke-width:2.5;opacity:.7}.backup-line-wan.svelte-1gc2rad{stroke:#f97316;stroke-width:2;stroke-dasharray:8 4;opacity:.5}@keyframes svelte-1gc2rad-pulse{0%,to{opacity:.3}50%{opacity:.1}}.phone-blink.svelte-1gc2rad{animation:svelte-1gc2rad-phone-blink-anim .8s ease-in-out infinite}@keyframes svelte-1gc2rad-phone-blink-anim{0%,to{opacity:1}50%{opacity:.2}}.user-auth.svelte-1gc2rad{animation:svelte-1gc2rad-auth-pulse .8s ease-in-out infinite}@keyframes svelte-1gc2rad-auth-pulse{0%,to{stroke-width:2}50%{stroke-width:4}}.auth-check-blink.svelte-1gc2rad{animation:svelte-1gc2rad-check-blink .5s ease-in-out infinite}@keyframes svelte-1gc2rad-check-blink{0%,to{opacity:1}50%{opacity:.2}}.portal-steps.svelte-1gc2rad{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;padding:10px 14px;font-family:inherit}.portal-step.svelte-1gc2rad{font-size:13px;line-height:1.7;color:var(--text);opacity:.4;white-space:nowrap}.portal-step-active.svelte-1gc2rad{color:#f97316;opacity:1;font-weight:700}.https-step-active.svelte-1gc2rad{color:#ef4444;opacity:1;font-weight:700}.fileshare-steps.svelte-1gc2rad{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;padding:10px 14px;font-family:inherit}.fileshare-step.svelte-1gc2rad{font-size:13px;line-height:1.7;color:var(--text);opacity:.4;white-space:nowrap}.fileshare-step-active.svelte-1gc2rad{color:#2563eb;opacity:1;font-weight:700}.fileshare-name.svelte-1gc2rad{font-style:italic}.tooltip.svelte-1gc2rad{position:absolute;top:16px;right:16px;z-index:20;background:var(--card-bg);border:1px solid var(--accent);border-radius:12px;padding:16px 20px;box-shadow:var(--shadow);min-width:180px;opacity:0;transform:translateY(-4px);transition:opacity .15s,transform .15s;pointer-events:none}.tooltip-dark.svelte-1gc2rad{border-color:var(--surface-stroke)}.tooltip-left.svelte-1gc2rad{right:auto;left:16px}.tooltip.visible.svelte-1gc2rad{opacity:1;transform:translateY(0)}.tooltip.svelte-1gc2rad strong:where(.svelte-1gc2rad){font-size:15px;color:var(--text-h);display:block;margin-bottom:6px}.tooltip.svelte-1gc2rad p:where(.svelte-1gc2rad){font-size:13px;color:var(--text);margin:0 0 8px}.tooltip.svelte-1gc2rad ul:where(.svelte-1gc2rad){list-style:none;padding:0;margin:0}.tooltip.svelte-1gc2rad li:where(.svelte-1gc2rad){font-size:13px;color:var(--text);padding:3px 0 3px 18px;position:relative}.tooltip.svelte-1gc2rad li:where(.svelte-1gc2rad):before{content:"→";position:absolute;left:0;color:var(--accent);font-weight:700}.tooltip-devices.svelte-1gc2rad{display:flex;gap:16px;margin:8px 0 6px}.tooltip-device.svelte-1gc2rad{display:flex;flex-direction:column;align-items:center;gap:4px}.tooltip-device.svelte-1gc2rad span:where(.svelte-1gc2rad){font-size:13px;color:var(--text);font-weight:600}.tooltip-icon.svelte-1gc2rad{width:28px;height:28px;padding:4px;background:var(--accent-light);border-radius:8px;color:var(--accent)}.tooltip-badge.svelte-1gc2rad{display:inline-block;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;margin-top:4px}.cluster-badge.svelte-1gc2rad{background:var(--accent-light);color:var(--accent-dark)}.wan-badge.svelte-1gc2rad{background:var(--green-light);color:var(--green)}@media(max-width:700px){.tooltip.svelte-1gc2rad{inset:auto 8px 8px;min-width:auto}.controls-overlay.svelte-1gc2rad{position:relative;top:auto;right:auto;max-width:100%;margin-bottom:8px;flex-direction:row;flex-wrap:wrap}.control-group.svelte-1gc2rad{flex-direction:row;flex-wrap:wrap;gap:4px}.control-divider.svelte-1gc2rad{width:1px;height:auto;margin:0 4px}}h2[data-astro-cid-rhmjqv3b] small[data-astro-cid-rhmjqv3b]{display:block;font-size:16px;font-weight:500;color:var(--accent);margin-top:4px}.resilience-intro[data-astro-cid-rhmjqv3b]{font-size:17px;line-height:1.6;margin-bottom:24px}.ha-pillars[data-astro-cid-rhmjqv3b]{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:12px}.scenario-card[data-astro-cid-rhmjqv3b]{padding:28px 24px;margin-bottom:28px}.scenario-timeline[data-astro-cid-rhmjqv3b]{display:flex;flex-direction:column;gap:0;position:relative}.scenario-step[data-astro-cid-rhmjqv3b]{display:flex;align-items:flex-start;gap:16px;padding:12px 0}.step-time[data-astro-cid-rhmjqv3b]{font-size:13px;font-weight:700;color:var(--text);opacity:.5;min-width:44px;padding-top:4px;text-align:center}.step-dot[data-astro-cid-rhmjqv3b]{width:14px;height:14px;border-radius:50%;flex-shrink:0;margin-top:6px}.step-dot-red[data-astro-cid-rhmjqv3b]{background:#ef4444}.step-dot-orange[data-astro-cid-rhmjqv3b]{background:#f97316}.step-dot-green[data-astro-cid-rhmjqv3b]{background:var(--green)}.step-dot-gray[data-astro-cid-rhmjqv3b]{background:var(--text)}.step-content[data-astro-cid-rhmjqv3b] h3[data-astro-cid-rhmjqv3b]{font-size:15px;font-weight:700;color:var(--text-h);margin:0 0 4px}.step-content[data-astro-cid-rhmjqv3b] p[data-astro-cid-rhmjqv3b]{font-size:14px;color:var(--text);margin:0;line-height:1.55}.scenario-connector[data-astro-cid-rhmjqv3b]{width:2px;height:16px;background:var(--border);margin-left:50px}.resilience-pillars[data-astro-cid-rhmjqv3b]{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px}.pillar[data-astro-cid-rhmjqv3b]{padding:20px}.pillar-icon[data-astro-cid-rhmjqv3b]{width:36px;height:36px;border-radius:10px;background:var(--accent-light);color:var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:12px}.pillar-icon[data-astro-cid-rhmjqv3b] svg[data-astro-cid-rhmjqv3b]{width:20px;height:20px}.pillar[data-astro-cid-rhmjqv3b] h3[data-astro-cid-rhmjqv3b]{font-size:15px;font-weight:700;color:var(--text-h);margin:0 0 6px}.pillar[data-astro-cid-rhmjqv3b] p[data-astro-cid-rhmjqv3b]{font-size:14px;color:var(--text);margin:0;line-height:1.55}.proxy-grid[data-astro-cid-rhmjqv3b]{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:12px}.resilience-cta[data-astro-cid-rhmjqv3b]{font-size:14px;color:var(--text);text-align:center;margin:0;padding:12px;background:var(--bg);border-radius:10px;border:1px solid var(--border)}.access-intro[data-astro-cid-rhmjqv3b]{font-size:17px;line-height:1.6;margin-bottom:16px}.access-flow[data-astro-cid-rhmjqv3b]{padding:28px 24px;margin-bottom:28px}.flow-steps[data-astro-cid-rhmjqv3b]{display:flex;align-items:flex-start;gap:0}.flow-step[data-astro-cid-rhmjqv3b]{flex:1;display:flex;align-items:flex-start;gap:12px;padding:8px 0}.flow-number[data-astro-cid-rhmjqv3b]{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.flow-content[data-astro-cid-rhmjqv3b] h3[data-astro-cid-rhmjqv3b]{font-size:15px;font-weight:700;color:var(--text-h);margin:0 0 4px}.flow-content[data-astro-cid-rhmjqv3b] p[data-astro-cid-rhmjqv3b]{font-size:14px;color:var(--text);margin:0;line-height:1.55}.flow-connector[data-astro-cid-rhmjqv3b]{width:24px;height:2px;background:var(--border);flex-shrink:0;margin-top:18px}.access-pillars[data-astro-cid-rhmjqv3b]{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:12px}@media(max-width:700px){.resilience-pillars[data-astro-cid-rhmjqv3b],.access-pillars[data-astro-cid-rhmjqv3b],.ha-pillars[data-astro-cid-rhmjqv3b],.proxy-grid[data-astro-cid-rhmjqv3b]{grid-template-columns:1fr}.flow-steps[data-astro-cid-rhmjqv3b]{flex-direction:column;align-items:stretch}.flow-connector[data-astro-cid-rhmjqv3b]{width:2px;height:16px;margin:0 auto}}
