.fv-container{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#0d1117;border:1px solid #ffffff14;border-radius:12px;flex-direction:column;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 24px #0006}.fv-header{background:linear-gradient(135deg,#161b22,#1a1f2e);border-bottom:1px solid #ffffff0f;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding:8px 12px;display:flex}.fv-title{align-items:center;gap:8px;min-width:0;display:flex}.fv-figure-num{color:#e94560;letter-spacing:0;text-transform:uppercase;white-space:nowrap;background:#e9456026;border-radius:6px;align-items:center;padding:2px 8px;font-size:12px;font-weight:700;display:inline-flex}.fv-label{color:#a7a7c4;text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.fv-controls{align-items:center;gap:4px;display:flex}.fv-btn{color:#e0e0e0;cursor:pointer;-webkit-user-select:none;user-select:none;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;transition:all .15s;display:inline-flex}.fv-btn:hover:not(:disabled){background:#ffffff1a;border-color:#fff3}.fv-btn:active:not(:disabled){transform:scale(.92)}.fv-btn:disabled{opacity:.3;cursor:not-allowed}.fv-btn-reset{margin-left:4px;font-size:16px}.fv-zoom-level{color:#6c7086;font-variant-numeric:tabular-nums;text-align:center;min-width:36px;font-size:11px}.fv-viewport{aspect-ratio:4/3;touch-action:none;background:#0b0e14;width:100%;position:relative;overflow:hidden}.fv-transform-layer{will-change:transform;width:100%;height:100%;transition:transform .16s cubic-bezier(.16,1,.3,1);position:relative}.fv-image{object-fit:contain;opacity:0;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;pointer-events:none;width:100%;height:100%;transition:opacity .3s}.fv-image-loaded{opacity:1}.fv-hotspot{cursor:pointer;background:#e9456014;border:2px solid #e94560;border-radius:50%;outline:none;padding:0;transition:all .2s;position:absolute;transform:translate(-50%,-50%)}.fv-hotspot:before{content:"";border:1px solid #0000;border-radius:50%;transition:border-color .2s;position:absolute;inset:-4px}.fv-hotspot:hover{background:#e9456033;box-shadow:0 0 16px #e945604d}.fv-hotspot:hover:before{border-color:#e9456066}.fv-hotspot-active{background:#e9456040;border-width:3px;box-shadow:0 0 24px #e9456080}.fv-hotspot:after{content:"";border:1px solid #e9456080;border-radius:50%;animation:2s ease-in-out infinite fv-pulse;position:absolute;inset:-2px}@keyframes fv-pulse{0%,to{opacity:0;transform:scale(1)}50%{opacity:1;transform:scale(1.15)}}.fv-bottom-sheet{background:linear-gradient(#161b22f7 0%,#161b22 100%);border-top:1px solid #ffffff14;max-height:160px;padding:12px 16px;animation:.25s ease-out fv-sheet-in;position:relative;overflow-y:auto}@keyframes fv-sheet-in{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.fv-sheet-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.fv-sheet-title{color:#e94560;margin:0;font-size:14px;font-weight:600}.fv-sheet-close{color:#6c7086;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px;font-size:16px;transition:color .15s}.fv-sheet-close:hover{color:#e0e0e0}.fv-sheet-body{color:#a7a7c4;margin:0;font-size:13px;line-height:1.5}.fv-source{text-align:right;padding:4px 12px 6px}.fv-source span{color:#3a3a5a;font-size:10px;font-style:italic}.fv-focus-overlay{z-index:80;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.fv-focus-backdrop{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#03060bc7;position:absolute;inset:0}.fv-focus-shell{background:#0f1115f0;border:1px solid #d2e8ff29;border-radius:12px;width:min(1180px,100vw - 32px);max-height:calc(100vh - 32px);padding:14px;position:relative;overflow:auto;box-shadow:0 34px 120px #00000094}.fv-focus-close{z-index:2;color:#e8ecf4;cursor:pointer;background:#ffffff14;border:1px solid #d2e8ff24;border-radius:8px;justify-content:center;align-items:center;min-height:36px;margin-bottom:10px;margin-left:auto;padding:0 12px;font-size:13px;font-weight:650;display:flex;position:sticky;top:0}.fv-focus-viewer{min-height:min(720px,100vh - 150px)}.fv-landscape-overlay{background:linear-gradient(135deg,#0d1117,#1a1f2e);border:1px solid #ffffff14;border-radius:12px;justify-content:center;align-items:center;min-height:260px;display:flex}.fv-landscape-content{text-align:center;padding:32px 24px}.fv-rotate-icon{color:#e94560;margin-bottom:12px;font-size:48px;animation:2s ease-in-out infinite fv-rotate-hint}@keyframes fv-rotate-hint{0%,to{transform:rotate(0)}25%{transform:rotate(15deg)}75%{transform:rotate(-15deg)}}.fv-landscape-content h3{color:#e0e0e0;margin:0 0 8px;font-size:18px;font-weight:600}.fv-landscape-content p{color:#6c7086;max-width:280px;margin:0;font-size:14px}.fv-figure-badge{color:#e94560;background:#e945601f;border-radius:6px;padding:4px 12px;font-size:12px;font-weight:600;display:inline-block;margin-top:12px!important}@media (min-width:769px){.fv-viewport{aspect-ratio:16/10}}@media (max-width:480px){.fv-header{padding:6px 8px}.fv-btn{width:28px;height:28px;font-size:16px}.fv-figure-num,.fv-label{font-size:11px}}
