.cfd-wrap{position:relative;width:100%;max-width:480px;aspect-ratio:1;margin:0 auto;padding:0 clamp(4px,2vw,12px);box-sizing:border-box;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.cfd-svg{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}.cfd-line{stroke:#6b4eff;stroke-width:.3;stroke-dasharray:1.5 1;opacity:.25;animation:cfdDash 10s linear infinite}.l2{animation-delay:-1.6s}.l3{animation-delay:-3.2s}.l4{animation-delay:-4.8s}.l5{animation-delay:-6.4s}.l6{animation-delay:-8s}@keyframes cfdDash{to{stroke-dashoffset:-20}}.cfd-hub{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:110px;height:110px;background:linear-gradient(135deg,#6b4eff,#b878ff);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;box-shadow:0 12px 40px #6b4eff59;border:3px solid white;z-index:10}.cfd-hub span{font-size:10px;font-weight:700;color:#fff;opacity:.9}.cfd-hub img{border-radius:8px}.cfd-pulse{position:absolute;left:50%;top:50%;width:110px;height:110px;border:2px solid #6b4eff;border-radius:50%;opacity:0;transform:translate(-50%,-50%);animation:cfdPulse 3s ease-out infinite;pointer-events:none}.cfd-pulse.p2{animation-delay:1.5s}@keyframes cfdPulse{0%{transform:translate(-50%,-50%) scale(1);opacity:.4}to{transform:translate(-50%,-50%) scale(2.2);opacity:0}}.cfd-node{position:absolute;background:#fff;border-radius:12px;padding:9px 11px;border:1px solid #e5e7eb;box-shadow:0 2px 8px #0000000f;display:flex;align-items:center;gap:8px;z-index:5;transform:translate(-50%,-50%);min-width:0;max-width:158px;transition:box-shadow .2s,border-color .2s}.cfd-node:hover{box-shadow:0 4px 16px #6b4eff1f;border-color:#6b4eff}.cfd-node img{border-radius:6px;flex-shrink:0}.cfd-node-text{min-width:0;flex:1;overflow:hidden}.cfd-name{font-size:12px;font-weight:700;color:#111827;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cfd-type{font-size:9px;color:#6b7280;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.n1{left:24%;top:22%}.n2{left:76%;top:22%}.n3{left:20%;top:50%}.n4{left:80%;top:50%}.n5{left:24%;top:78%}.n6{left:76%;top:78%}@media(prefers-reduced-motion:reduce){.cfd-line,.cfd-pulse{animation:none!important}}@media(max-width:480px){.cfd-hub{width:80px;height:80px}.cfd-hub img{width:28px!important;height:28px!important}.cfd-hub span{font-size:9px}.cfd-node{padding:6px 8px;max-width:132px}.cfd-name{font-size:10px}.cfd-type{font-size:8px}.cfd-node img{width:22px!important;height:22px!important}}.gallery-card *{box-sizing:border-box;margin:0;padding:0}.gallery-card{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:#fff;border-radius:20px;border:1px solid #f3f4f6;box-shadow:0 8px 24px #0000000f;padding:28px;max-width:600px;margin:0 auto}.gallery-header{text-align:center;margin-bottom:24px}.gallery-title{font-size:18px;font-weight:700;color:#111827}.gallery-subtitle{font-size:13px;color:#6b7280;margin-top:4px}.gallery-tabs{display:flex;gap:8px;justify-content:center;margin-bottom:24px;flex-wrap:wrap}.tab{padding:10px 18px;border-radius:12px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;border:1px solid transparent}.tab.inactive{background:#f9fafb;color:#6b7280}.tab.inactive:hover{background:#f3f4f6;color:#374151}.tab.active{background:linear-gradient(135deg,#6b4eff,#8b5cf6);color:#fff;box-shadow:0 4px 12px #6b4eff4d}.content-preview{background:#f9fafb;border-radius:16px;padding:24px}.preview-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.preview-icon{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#6b4eff15,#6b4eff08);display:flex;align-items:center;justify-content:center}.preview-icon svg{width:20px;height:20px;color:#6b4eff}.preview-type{font-size:14px;font-weight:600;color:#111827}.preview-desc{font-size:12px;color:#6b7280}.preview-content{background:#fff;border-radius:12px;padding:20px;border:1px solid #e5e7eb}.preview-title{font-size:16px;font-weight:700;color:#111827;margin-bottom:12px}.preview-text{font-size:13px;color:#374151;line-height:1.7}.preview-text .highlight{background:linear-gradient(135deg,#6b4eff20,#8b5cf620);padding:2px 6px;border-radius:4px;font-weight:600;color:#6b4eff}.preview-meta{display:flex;gap:16px;margin-top:16px;padding-top:16px;border-top:1px solid #f3f4f6}.meta-item{display:flex;align-items:center;gap:6px;font-size:12px;color:#6b7280}.meta-item svg{width:14px;height:14px}.meta-item strong{color:#111827;font-weight:600}
