*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;overflow:hidden}body{background:#070a14;color:#e2e8f0;font-family:Geist,Inter,system-ui,-apple-system,sans-serif}#root{height:100vh;display:flex;flex-direction:column;transform-origin:top left;transform:scale(.8);width:125%;height:125%}.gridflow-root:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle,rgba(100,120,200,.045) 1px,transparent 1px);background-size:28px 28px;pointer-events:none;z-index:0}@keyframes flowDash{0%{stroke-dashoffset:0}to{stroke-dashoffset:-18}}@keyframes flowDashRev{0%{stroke-dashoffset:0}to{stroke-dashoffset:18}}@keyframes liveBlink{0%,to{opacity:1}50%{opacity:.15}}@keyframes modeIn{0%{opacity:0;transform:translateY(-2px)}to{opacity:1;transform:translateY(0)}}@keyframes hubPulse{0%,to{opacity:.4}50%{opacity:.7}}@keyframes fiberPulse{0%,to{opacity:1}50%{opacity:.72}}@keyframes blink{0%,to{opacity:1}50%{opacity:.14}}@keyframes loginSpin{to{transform:rotate(360deg)}}@keyframes loginShake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(5px)}60%{transform:translate(-3px)}80%{transform:translate(2px)}}.mono{font-family:Geist Mono,JetBrains Mono,ui-monospace,monospace;font-variant-numeric:tabular-nums}#canvas-wrap{position:relative;flex:1;min-height:0;z-index:1}#canvas-wrap>svg{display:block;width:100%;height:100%;overflow:visible}.fc{all:initial;display:block;box-sizing:border-box;font-family:Geist,Inter,system-ui,sans-serif}.src-card{width:100%;height:100%;background:#0c0f1e;border:1px solid rgba(255,255,255,.08);border-radius:11px;padding:11px 14px 11px 19px;display:flex;flex-direction:column;gap:8px;justify-content:center;cursor:default;position:relative;transition:border-color .25s,box-shadow .25s;color:#e2e8f0}.src-card:hover{border-color:var(--c,rgba(255,255,255,.18));box-shadow:0 0 28px var(--g,transparent)}.hub-card{width:100%;height:100%;background:#0b0e1c;border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:17px 17px 15px;display:flex;flex-direction:column;gap:10px;color:#e2e8f0}.ep-card{width:100%;height:100%;background:#0c0f1e;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:13px 15px;display:flex;flex-direction:column;gap:9px;color:#e2e8f0}.label{font-size:9px;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:#afc3e159}.val{font-size:13px;font-weight:600}.dot-live{display:inline-block;width:5px;height:5px;border-radius:50%;background:#4ade80;animation:liveBlink 2.2s ease-in-out infinite}.topbar,.btmbar{position:relative;z-index:2;background:#070a14f7;display:flex;align-items:center;padding:0 32px;flex-shrink:0}.topbar{height:73px;border-bottom:1px solid rgba(255,255,255,.055);gap:20px}.btmbar{height:81px;border-top:1px solid rgba(255,255,255,.055)}.brand-icon{width:38px;height:38px;border-radius:10px;flex-shrink:0;background:linear-gradient(135deg,#22d3ee21,#818cf821);border:1px solid rgba(129,140,248,.3);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#818cf8}.mode-btn{padding:9px 19px;border-radius:9999px;cursor:pointer;font-size:12px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;font-family:inherit;border:1px solid;transition:all .35s;display:flex;align-items:center;gap:8px}.stat-cell{flex:1;padding:0 22px;border-right:1px solid rgba(255,255,255,.048)}.stat-cell:last-child{border-right:none}.btmbar .label{font-size:11px}.btmbar .val{font-size:16px;margin-top:5px}.lbl{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.09em;color:#afc3e157}.card{background:#0b0e1c;border:1px solid rgba(255,255,255,.072);border-radius:14px;padding:18px 20px;display:flex;flex-direction:column;gap:10px;position:relative;overflow:hidden}.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:minmax(0,1fr) minmax(0,1fr) minmax(0,1fr) auto;gap:12px;padding:14px 16px 16px;flex:1;min-height:0;overflow:hidden}.bento>.card{min-height:0;overflow:hidden}
