/**
 * Frogames Global Portal Dock Styles 🚀
 */
.fg-global-dock {
    position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(100px);
    background: rgba(15, 23, 42, 0.85); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.1); border-radius: 9999px; padding: 8px 16px;
    display: flex; align-items: center; gap: 12px; z-index: 999999;
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.4); opacity: 0; pointer-events: none;
    transition: all 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}
.fg-global-dock.visible { transform: translateX(-50%) translateY(0); opacity: 1; pointer-events: all; }
.fg-dock-brand { cursor: pointer; width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, #3b82f6, #2563eb); border-radius: 50%; }
.fg-dock-item { cursor: pointer; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; color: #94a3b8; border-radius: 50%; position: relative; background: rgba(255, 255, 255, 0.03); transition: all 0.3s ease; }
.fg-dock-item:hover { background: rgba(55, 65, 81, 0.5); color: white; transform: translateY(-4px); }
.fg-dock-divider { width: 1px; height: 24px; background: rgba(255, 255, 255, 0.1); }
.fg-dock-item::before { content: attr(data-tooltip); position: absolute; bottom: calc(100% + 12px); left: 50%; transform: translateX(-50%) translateY(10px); background: #0f172a; color: white; padding: 6px 12px; border-radius: 6px; font-size: 11px; opacity: 0; pointer-events: none; transition: 0.2s; border: 1px solid rgba(255,255,255,0.1); white-space: nowrap; }
.fg-dock-item:hover::before { opacity: 1; transform: translateX(-50%) translateY(0); }
/* Pulse animation on click */
.fg-dock-item.active-pulse::after { content: ''; position: absolute; top: 50%; left: 50%; width: 100%; height: 100%; background: rgba(255, 255, 255, 0.2); border-radius: 50%; transform: translate(-50%, -50%) scale(1); animation: fg-pulse 0.4s ease-out; }
@keyframes fg-pulse { 0% { transform: translate(-50%,-50%) scale(1); opacity: 0.5; } 100% { transform: translate(-50%,-50%) scale(2); opacity: 0; } }
/* Info Modal Overlay */
.fg-dock-info-modal { position: absolute; bottom: calc(100% + 20px); left: 0; width: 280px; background: #0f172a; border: 1px solid rgba(255,255,255,0.1); border-radius: 16px; display: none; flex-direction: column; box-shadow: 0 20px 25px -5px rgba(0,0,0,0.5); }
.fg-dock-info-modal.active { display: flex; }
.fg-dock-info-header { padding: 16px; border-bottom: 1px solid rgba(255,255,255,0.1); display: flex; align-items: center; gap: 10px; }
.fg-dock-info-body { padding: 16px; }
.fg-dock-info-links { display: flex; flex-direction: column; gap: 8px; }
.fg-dock-info-link { display: flex; align-items: center; gap: 8px; color: white; text-decoration: none; font-size: 13px; padding: 8px; background: rgba(255,255,255,0.05); border-radius: 8px; }
.fg-dock-info-link:hover { background: rgba(255,255,255,0.1); }
.fg-dock-info-footer { padding: 8px; background: rgba(0,0,0,0.2); font-size: 10px; color: #475569; text-align: center; }
